It is strongly recommended to use nginx
to host frontend static resources and reverse proxy backend service. The configuration is as follows:
General Configuration
- 1server {
- 2
- 3 listen 8000;
- 4 server_name localhost;
- 5
- 6 set $node_ip 127.0.0.1;
- 7 set $node_port 7002;
- 8
- 9 root /path/to/project/dist/web;
- 10
- 11 location /public {
- 12 root /path/to/home/cabloy/project-name;
- 13 internal;
- 14 }
- 15
- 16 location /api/ {
- 17 proxy_http_version 1.1;
- 18 proxy_set_header X-Real-IP $remote_addr;
- 19 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- 20 proxy_set_header X-Forwarded-Host $server_name;
- 21 proxy_set_header X-Forwarded-Proto $scheme;
- 22 proxy_set_header Host $http_host;
- 23 proxy_set_header X-NginX-Proxy true;
- 24 proxy_set_header Upgrade $http_upgrade;
- 25 proxy_set_header Connection "upgrade";
- 26 proxy_pass http://$node_ip:$node_port$request_uri;
- 27 proxy_redirect off;
- 28 proxy_buffer_size 64k;
- 29 proxy_buffers 4 32k;
- 30 proxy_busy_buffers_size 64k;
- 31 }
- 32
- 33 location /socket.io/ {
- 34 proxy_http_version 1.1;
- 35 proxy_set_header X-Real-IP $remote_addr;
- 36 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- 37 proxy_set_header X-Forwarded-Host $server_name;
- 38 proxy_set_header X-Forwarded-Proto $scheme;
- 39 proxy_set_header Host $http_host;
- 40 proxy_set_header X-NginX-Proxy true;
- 41 proxy_set_header Upgrade $http_upgrade;
- 42 proxy_set_header Connection "upgrade";
- 43 proxy_pass http://$node_ip:$node_port$request_uri;
- 44 proxy_redirect off;
- 45 proxy_buffer_size 64k;
- 46 proxy_buffers 4 32k;
- 47 proxy_busy_buffers_size 64k;
- 48 }
- 49
- 50}
Name | Description |
---|---|
root | frontend static resources |
location /public | resource files generated during system operations, such as uploaded pictures , uploaded files , etc. |
location /api/ | backend service |
About location /public
I want to emphasize location /public
here:
1. Default Configuration
In the production environment, resource files generated by backend service (such as module a-file
) will be automatically stored in the directory {HomeDir}/cabloy/{ProjectName}/public
. We just need to set the root
value of location /public
to {HomeDir}/cabloy/{ProjectName}
in the nginx configuration file
2. Override Configuration
The configuration of module a-Base
can be overrided in the project configuration file
src/backend/config/config.prod.js
- 1config.modules = {
- 2 'a-base': {
- 3 publicDir: '/path/to/public',
- 4 },
- 5};
publicDir
: must be an absolute path, equivalent to overwriting the path in the production environment:{HomeDir}/cabloy/{ProjectName}/public
3. Why is internal
specified for location /public
?
Because CabloyJS uses nginx’s x-accel-redirect
mechanism, and location /public
is used for file redirect on the backend, which is not directly accessible by the frontend
For more information about
x-accel-redirect
, see: X-Accel
4. What effect does location /public
specify internal
?
For example, a picture is uploaded through the module a-file
. The actual storage file name of the picture on the server is: {publicDir}/{instanceId}/file/image/2019-11-18/6fb2784415f949948355ef843d78459a-126_0.jpg
, while the download link is: https://portal.cabloy.com/api/a/file/file/download/46c68dae591b41c3bd2181facc8d0af9.jpg
. The frontend can download the picture directly through the download link, but it does not know the real location and real name of the picture stored in the server
Production Configuration
Generally, HTTPS protocol is used in production environment, so the corresponding configuration is as follows:
- 1server {
- 2
- 3 listen 80;
- 4 server_name yourdomain.com;
- 5
- 6 return 301 https://$server_name$request_uri;
- 7}
- 8
- 9server {
- 10
- 11 listen 443 ssl;
- 12 server_name yourdomain.com;
- 13
- 14 set $node_ip 127.0.0.1;
- 15 set $node_port 7003;
- 16
- 17 root /path/to/project/dist;
- 18
- 19 location /public {
- 20 root /path/to/home/cabloy/project-name;
- 21 internal;
- 22 }
- 23
- 24 location /api/ {
- 25 proxy_http_version 1.1;
- 26 proxy_set_header X-Real-IP $remote_addr;
- 27 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- 28 proxy_set_header X-Forwarded-Host $server_name;
- 29 proxy_set_header X-Forwarded-Proto $scheme;
- 30 proxy_set_header Host $http_host;
- 31 proxy_set_header X-NginX-Proxy true;
- 32 proxy_set_header Upgrade $http_upgrade;
- 33 proxy_set_header Connection "upgrade";
- 34 proxy_pass http://$node_ip:$node_port$request_uri;
- 35 proxy_redirect off;
- 36 }
- 37
- 38 ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem;
- 39 ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem;
- 40}
Developmemt Configuration
If we want to configure the development environment on the server, and then reverse proxy the frontend service and backend service to the frontend through nginx, the corresponding configuration is as follows:
- 1server {
- 2
- 3 listen 80;
- 4 server_name yourdomain.com;
- 5
- 6 return 301 https://$server_name$request_uri;
- 7
- 8
- 9server {
- 10
- 11 listen 443 ssl;
- 12 server_name yourdomain.com;
- 13
- 14 set $node_ip 127.0.0.1;
- 15 set $node_ip2 127.0.0.1;
- 16
- 17 set $node_port 7102;
- 18 set $node_port2 9192;
- 19
- 20 location /api/ {
- 21 proxy_http_version 1.1;
- 22 proxy_set_header X-Real-IP $remote_addr;
- 23 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- 24 proxy_set_header X-Forwarded-Host $server_name;
- 25 proxy_set_header X-Forwarded-Proto $scheme;
- 26 proxy_set_header Host $http_host;
- 27 proxy_set_header X-NginX-Proxy true;
- 28 proxy_set_header Upgrade $http_upgrade;
- 29 proxy_set_header Connection "upgrade";
- 30 proxy_pass http://$node_ip:$node_port$request_uri;
- 31 proxy_redirect off;
- 32 }
- 33
- 34 location /public/ {
- 35 proxy_http_version 1.1;
- 36 proxy_set_header X-Real-IP $remote_addr;
- 37 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- 38 proxy_set_header X-Forwarded-Host $server_name;
- 39 proxy_set_header X-Forwarded-Proto $scheme;
- 40 proxy_set_header Host $http_host;
- 41 proxy_set_header X-NginX-Proxy true;
- 42 proxy_set_header Upgrade $http_upgrade;
- 43 proxy_set_header Connection "upgrade";
- 44 proxy_pass http://$node_ip:$node_port$request_uri;
- 45 proxy_redirect off;
- 46 }
- 47
- 48 location / {
- 49 proxy_http_version 1.1;
- 50 proxy_set_header X-Real-IP $remote_addr;
- 51 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- 52 proxy_set_header X-Forwarded-Host $server_name;
- 53 proxy_set_header X-Forwarded-Proto $scheme;
- 54 proxy_set_header Host $http_host;
- 55 proxy_set_header X-NginX-Proxy true;
- 56 proxy_set_header Upgrade $http_upgrade;
- 57 proxy_set_header Connection "upgrade";
- 58 proxy_pass http://$node_ip2:$node_port2$request_uri;
- 59 proxy_redirect off;
- 60 }
- 61
- 62 ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem;
- 63 ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem;
- 64}
Comments: