本地部署前端应用

我们在开发或解决问题后,需要部署代码到线上进行验证,但是有时候去部署环境是可能会直接影响到其他在使用环境的人。这个时候我们可以自己本地去部署代码。去模拟在线上运行的场景。

环境准备

  1. nginx服务器
  2. 可以作为服务器的选择有很多。这里我们选择最常用的nginx 下载
  3. nginx本地部署不成功 nginx部署在哪里_nginx


  4. 下载后,解压到自定义目录下即可。 目录如下
  5. nginx本地部署不成功 nginx部署在哪里_Nginx_02


  6. 现在我们去修改下conf/nginx.conf 文件
  7. nginx.conf
worker_processes  1; # Nginx进程,一般设置和cpu核数一样
      error_log  logs/error.log; #错误日志存放位置
      events {
          worker_connections  1024;
      }


      http {
          include       mime.types; #文件扩展名和类型映射表
          default_type  application/octet-stream; #默认的文件类型

          sendfile        on; #开启高效文件传输模式
          #tcp_nopush     on;

          #keepalive_timeout  0;
          keepalive_timeout  65;

          #gzip  on;

          server {
              listen       80; # 启动后的端口
              server_name  localhost; # 启动时的地址 server name 为虚拟服务器的识别路径。因此不同的域名会通过请求头中的HOST字段,匹配到特定的server块,转发到对应的应用服务器中去。

              #charset koi8-r;

              #access_log  logs/host.access.log  main;

              location / {
                  root   html; #服务默认启动目录
                  index  index.html index.htm; #默认访问文件
              }

              #error_page  404              /404.html;

              # redirect server error pages to the static page /50x.html
              #
              # 其他错误码页面配置 配置后需要重启
              error_page   500 502 503 504  /50x.html;
              location = /50x.html {
                  root   html;
              }

      }

以上是简化后的配置,重点在于,location中的配置。location /代表我们访问根路径会被匹配进行路由到配置的页面。
测试一下。在默认启动的目录下。添加一个我们自己根目录stones 并且添加index.html。添加一个自定义的根目录的原因在于
在微服务的场景下。我们往往不止一个前端项目,为了将不同项目的代码放置在不同的目录下。

<!-- html/stones/index.html -->
<!DOCTYPE html>
<html>
<head>
  <meta charset='utf-8'>
  <meta http-equiv='X-UA-Compatible' content='IE=edge'>
  <title>Page Title</title>
  <meta name='viewport' content='width=device-width, initial-scale=1'>
</head>
<body>
  <h1> hello world! </h1>
</body>
</html>
  1. 修改nginx配置
location / {
      root   html; #服务默认启动目录
      index  stones/index.html; #默认访问文件 (这里路径需要修改)
  }
  1. 启动服务
# 常用的nginx命令
  # 查看Nginx的版本号:nginx -V
  # 启动Nginx:start nginx   或者  nginx
  # 快速停止或关闭Nginx:nginx -s stop
  # 正常停止或关闭Nginx:nginx -s quit
  # 配置文件修改重装载命令:nginx -s reload
  # 查看windows任务管理器下Nginx的进程命令:tasklist /fi "imagename eq nginx.exe"
  # 终止进程 taskkill /F /pid 252288


  PS D:\Software\nginx-1.21.4> start nginx
  PS D:\Software\nginx-1.21.4>

只见cmd黑窗口闪了下。我们访问试一试 server_name + listen = localhost:80; 尝试浏览器访问下

nginx本地部署不成功 nginx部署在哪里_Nginx_03


启动成功。

以上只是一个简单的html页面。下面我们试一试复杂的前端项目

准备前端项目

  1. 这里使用以前的例子 stones7 进行打包。
PS E:\DDD\Vue3CLI\stones7> yarn build
yarn run v1.22.17
$ vue-cli-service build

|  Building for production...
You may use special comments to disable some warnings.
Use // eslint-disable-next-line to ignore the next line.
Use /* eslint-disable */ to ignore all warnings in a file.
  File                                 Size                    Gzipped

  dist\js\chunk-vendors.5e9f437b.js    145.84 KiB              52.14 KiB
  dist\js\app.2169c032.js              5.09 KiB                2.30 KiB
  dist\js\about.56e62a22.js            0.38 KiB                0.29 KiB
  dist\css\app.90dd0e3c.css            0.42 KiB                0.26 KiB

  Images and other types of assets omitted.

 DONE  Build complete. The dist directory is ready to be deployed.
 INFO  Check out deployment instructions at https://cli.vuejs.org/guide/deployment.html   

Done in 42.79s.
  1. 将打好包的目录复制到html/stones目录下。
  2. nginx本地部署不成功 nginx部署在哪里_nginx_04

  3. 重启nginx
D:\Software\nginx-1.21.4>nginx -s reload

注意: 如果像以上单独设置了一个 stones目录 则需要在项目中配置base路径。以便正确的访问到我们的前端静态资源。
以Vue3项目stones7为例

stones7文件

// 1. 根目录下新增env配置文件
  # 根路径
  BASE_URL=/stones
  // 2. vue.config.js 需要配置publicPath
  publicPath: process.env.BASE_URL
  // 3. 如果使用了路由
  const router = createRouter({
    history: createWebHistory(process.env.BASE_URL),
    routes
  });
  // 4. public/index.html 引用路径需要配置 BASE_URL
  <!DOCTYPE html>
  <html lang="">
    <head>
      <meta charset="utf-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width,initial-scale=1.0">


      <link rel="icon" href="<%= BASE_URL %>favicon.ico"> 


      <title><%= htmlWebpackPlugin.options.title %></title>
    </head>
    <body>
      <noscript>
        <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
      </noscript>
      <div id="app"></div>
    </body>
  </html>

nginx本地部署不成功 nginx部署在哪里_nginx_05


访问http://localhost:80, 成功

nginx本地部署不成功 nginx部署在哪里_Nginx_06