获取镜像

  1. docker pull nginx

运行镜像

  1. docker run --name nginx -d -p 80:80 -v /usr/local/nginx/nginx.conf:/etc/nginx/nginx.conf -v /usr/local/nginx/html:/usr/share/nginx/html nginx

关键配置

  1. user nginx;
  2. worker_processes auto;
  3. error_log /var/log/nginx/error.log notice;
  4. pid /var/run/nginx.pid;
  5. events {
  6. worker_connections 1024;
  7. }
  8. http {
  9. include /etc/nginx/mime.types;
  10. default_type application/octet-stream;
  11. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  12. '$status $body_bytes_sent "$http_referer" '
  13. '"$http_user_agent" "$http_x_forwarded_for"';
  14. access_log /var/log/nginx/access.log main;
  15. sendfile on;
  16. #tcp_nopush on;
  17. keepalive_timeout 65;
  18. #gzip on;
  19. server { ## 前端项目
  20. listen 80;
  21. server_name www.itcast.ldt; ## 重要!!!修改成你的前端域名
  22. location / { ## 前端项目
  23. root /usr/share/nginx/html/dist;
  24. index index.html index.htm;
  25. try_files $uri $uri/ /index.html;
  26. }
  27. }
  28. server { ## 后端项目
  29. listen 80;
  30. server_name api.itcast.ltd; ## 重要!!!修改成你的外网 IP/域名
  31. ## 不要使用 location / 转发到后端项目,因为 druid、admin 等监控,不需要外网可访问。或者增加 Nginx IP 白名单限制也可以。
  32. location /admin-api/ { ## 后端项目 - 管理后台
  33. proxy_pass http://118.31.60.98:8888/admin-api/; ## 重要!!!proxy_pass 需要设置为后端项目所在服务器的 IP
  34. proxy_set_header Host $http_host;
  35. proxy_set_header X-Real-IP $remote_addr;
  36. proxy_set_header REMOTE-HOST $remote_addr;
  37. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  38. }
  39. location /app-api/ { ## 后端项目 - 用户 App
  40. proxy_pass http://118.31.60.98:8888/app-api/; ## 重要!!!proxy_pass 需要设置为后端项目所在服务器的 IP
  41. proxy_set_header Host $http_host;
  42. proxy_set_header X-Real-IP $remote_addr;
  43. proxy_set_header REMOTE-HOST $remote_addr;
  44. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  45. }
  46. }
  47. }