线上部署

代码编译

开发环境下,代码会自动编译、自动更新,但这种机制时间长了会有一定的内存泄露,所以线上不可使用这种方式。

需要在代码上线前执行 npm run compile 命令,将 src/ 目录编译到 app/ 目录,然后将 app/ 目录下的文件上线。

使用 PM2 管理服务

PM2 是一款专业管理 Node.js 服务的模块,非常建议在线上使用。使用 PM2 需要以全局的方式安装,如: sudo npm install -g pm2。安装完成后,命令行下会有 pm2 命令。

创建项目时,会在项目目录下创建名为 pm2.json 的配置文件,内容类似如下:

  1. {
  2. "apps": [{
  3. "name": "demo",
  4. "script": "www/production.js",
  5. "cwd": "/Users/welefen/Develop/git/thinkjs/demo",
  6. "max_memory_restart": "1G",
  7. "autorestart": true,
  8. "node_args": [],
  9. "args": [],
  10. "env": {
  11. }
  12. }]
  13. }

cwd 配置值改为线上真实的项目路径,然后在项目目录下使用下面的命令来启动/重启服务:

  1. pm2 startOrReload pm2.json

如果进程重启之前想进行一些操作,如:保存一些临时数据,那么可以使用 GracefulReload,具体请见:http://pm2.keymetrics.io/docs/usage/pm2-doc-single-page/#graceful-reload。

PM2 详细的配置请见 http://pm2.keymetrics.io/docs/usage/application-declaration/


:如果线上不使用 PM2 来管理 Node.js 服务的话,启动服务需要使用命令 node www/production.js

使用 nginx 做反向代理

创建项目时,会在项目目录创建一个名为 nginx.conf 的 nginx 配置文件。配置文件内容类似如下:

  1. server {
  2. listen 80;
  3. server_name localhost;
  4. root /Users/welefen/Develop/git/thinkjs/demo/www;
  5. set $node_port 8360;
  6. index index.js index.html index.htm;
  7. if ( -f $request_filename/index.html ){
  8. rewrite (.*) $1/index.html break;
  9. }
  10. if ( !-f $request_filename ){
  11. rewrite (.*) /index.js;
  12. }
  13. location = /index.js {
  14. proxy_http_version 1.1;
  15. proxy_set_header Connection "";
  16. proxy_set_header X-Real-IP $remote_addr;
  17. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  18. proxy_set_header Host $http_host;
  19. proxy_set_header X-NginX-Proxy true;
  20. proxy_set_header Upgrade $http_upgrade;
  21. proxy_set_header Connection "upgrade";
  22. proxy_pass http://127.0.0.1:$node_port$request_uri;
  23. proxy_redirect off;
  24. }
  25. location = /production.js {
  26. deny all;
  27. }
  28. location = /testing.js {
  29. deny all;
  30. }
  31. location ~ /static/ {
  32. etag on;
  33. expires max;
  34. }
  35. }

server_name localhost 里的 localhost 修改为对应的域名,将 set $node_port 8360 里的 8360 修改和项目里监听的端口一致。

修改完成后,将该配置文件拷贝到 nginx 的配置文件目录中,然后通过 nginx -s reload 命令 reload 配置,这样就可以通过域名访问了。

线上建议开启配置 proxy_on,这样就可以禁止直接通过 IP + 端口来访问。修改配置文件 src/common/config/env/production.js,如:

  1. export default {
  2. proxy_on: true
  3. }

关闭静态资源处理的配置

为了方便开发,ThinkJS 是支持处理静态资源请求的。但代码部署在线上时,是用 nginx 来处理静态资源请求的,这时可以关闭 ThinkJS 里处理静态资源请求的功能来提高性能。

可以在配置文件 src/common/config/env/production.js 中加入如下的配置:

  1. export default {
  2. resource_on: false
  3. }

使用 cluster

线上可以开启 cluster 功能达到利用多核 CPU 来提升性能,提高并发处理能力。

可以在配置文件 src/common/config/env/production.js 中加入如下的配置:

  1. export default {
  2. cluster_on: true
  3. }

:如果使用 PM2 来部署,并且开启了 cluster 模式,那么就无需在开启 ThinkJS 里的 cluster。

原文: https://thinkjs.org/zh-cn/doc/2.1/deploy.html