当前位置:   article > 正文

Mac Docker安装配置nginx,配置代理前端访问服务器后端访问本地启动项目_mac docker 安装nginx

mac docker 安装nginx

1、查看可用源

docker search nginx

 2、安装nginx镜像

docker pull nginx

3、查看已安装的nginx

docker images

 或者直接通过docker客户端查看

4、运行nginx

docker run --name NginxTest -p 8080:8080 -d nginx

--name NginxTest:容器名称

-p 8080:8080:映射端口

-d nginx:设置容器后台运行

5、查看已运行容器

docker ps -a ### 所有容器,包括未运行

 docker客户端查看

6、访问测试 

7、创建本地挂载文件

  1. mkdir -p /Users/huakai-mozhiqi/docker/nginx/log
  2. mkdir -p /Users/huakai-mozhiqi/docker/nginx/html
  3. mkdir -p /Users/huakai-mozhiqi/docker/nginx/conf
  4. mkdir -p /Users/huakai-mozhiqi/docker/nginx/conf.d(注意:这是文件夹)

8、将nginx容器中的文件复制到主机

  1. docker cp NginxTest:/etc/nginx/nginx.conf /Users/huakai-mozhiqi/nginx/conf/nginx.conf
  2. docker cp NginxTest:/etc/nginx/conf.d/default.conf /Users/huakai-mozhiqi/docker/nginx/conf/conf.d/default.conf

9、修改nginx/confnginx.conf文件配置

  1. worker_processes 1;
  2. events {
  3. worker_connections 1024;
  4. }
  5. http {
  6. include mime.types;
  7. default_type application/octet-stream;
  8. sendfile on;
  9. keepalive_timeout 65;
  10. client_max_body_size 10m;
  11. client_body_buffer_size 128k;
  12. # 代理配置1
  13. server {
  14. listen 8990;
  15. server_name localhost;
  16. location / {
  17. proxy_pass http://172.16.***.**:****;
  18. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  19. proxy_pass_header Server;
  20. proxy_redirect / /;
  21. proxy_set_header Host $http_host;
  22. proxy_set_header X-Real-IP $remote_addr;
  23. proxy_set_header X-Scheme $scheme;
  24. }
  25. location ~(^\/api)(.*) {
  26. proxy_set_header Host $host:$server_port;
  27. proxy_set_header X-Real-IP $remote_addr;
  28. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  29. proxy_buffering off;
  30. proxy_pass http://127.0.0.1:8013;
  31. }
  32. }
  33. # 代理配置2
  34. server {
  35. listen 8991;
  36. server_name localhost;
  37. location / {
  38. proxy_pass http://172.16.***.**:****;
  39. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  40. proxy_pass_header Server;
  41. proxy_redirect / /;
  42. proxy_set_header Host $http_host;
  43. proxy_set_header X-Real-IP $remote_addr;
  44. proxy_set_header X-Scheme $scheme;
  45. }
  46. location ~(^\/api)(.*) {
  47. proxy_set_header Host $host:$server_port;
  48. proxy_set_header X-Real-IP $remote_addr;
  49. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  50. proxy_buffering off;
  51. proxy_pass http://127.0.0.1:12800;
  52. }
  53. location ~(^\/auth)(.*) {
  54. proxy_set_header Host $host:$server_port;
  55. proxy_set_header X-Real-IP $remote_addr;
  56. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  57. proxy_buffering off;
  58. proxy_pass http://127.0.0.1:12800;
  59. }
  60. }
  61. }

1)全局块:配置服务器整体运行的配置指令

nginx 服务器整体运行的配置指令,主要包括配置运行 Nginx 服务器的用户(组)、允许生成的 worker process 数,进程 PID 存放路径、日志存放路径和类型以及配置文件的引入等。

worker_processes 1;

# Nginx 服务器并发处理服务的关键配置,worker_processes 值越大,可以支持的并发处理量也越多。

2)events 块:影响 Nginx 服务器与用户的网络连接

Nginx 服务器与用户的网络连接配置,包括是否开启对多 work process下的网络连接进行序列化,是否允许同时接收多个网络连接,选取哪种事件驱动模型来处理连接请求,每个 work process 可以同时支持的最大连接数等。

events {

        worker_connections 1024;

}

# 每个 work process 支持的最大连接数为 1024。

3)http 块

        Nginx 服务器代理、缓存和日志定义等绝大多数功能和第三方模块的配置。

http {
    include mime.types;
    default_type application/octet-stream;
    sendfile on;
    keepalive_timeout 65;
    client_max_body_size 10m;
    client_body_buffer_size 128k;
    # 代理配置1
    server {
        listen 8990; 
        server_name localhost;
        location / {
            proxy_pass http://172.16.***.**:****;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass_header Server;

            proxy_redirect / /;
            proxy_set_header Host $http_host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Scheme $scheme;
        }
        location ~(^\/api)(.*) {
            proxy_set_header Host $host:$server_port;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_buffering off;
            proxy_pass http://127.0.0.1:8013;
        }

    }

}

a、http 全局块

        http 全局块配置的指令包括文件引入、MIME-TYPE 定义、日志自定义、连接超时时间、单链接请求数上限等。

b、全局 server 块 

listen 8990; 
server_name localhost;

#需要监听的ip、端口配置

        注意:server_name的配置不需要加“http://”

c、location 块

        一个 server 块可以配置多个 location 块。这块的主要作用是基于 Nginx 服务器接收到的请求字符串(例如 server_name/uri-string),对虚拟主机名称(也可以是 IP 别名)之外的字符串(例如 前面的 /uri-string)进行匹配,对特定的请求进行处理。地址定向、数据缓存和应答控制等功能,还有许多第三方模块的配置也在这里进行。

 location / {}

 location ~(^\/api)(.*) {}

# 需要进行代理的请求路径

proxy_pass http://172.16.***.**:****;

proxy_pass http://127.0.0.1:8013;

# 代理指向的ip:端口

        注意:当通过docker部署nginx时,如指向本机应为 本机IP:端口号


 

10、运行镜像

docker run --name myNginx --restart always -m 2g --cpus 1 -e TZ='Asia/Shanghai' -p 8990:8990 -p 8991:8991 -p 8992:8992 -v /Users/huakai-mozhiqi/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /Users/huakai-mozhiqi/nginx/conf/conf.d:/etc/nginx/conf.d -v /Users/huakai-mozhiqi/nginx/logs:/var/log/nginx -v /Users/huakai-mozhiqi/nginx/html:/usr/share/nginx/html -d nginx

--name myNginx:容器名称

--restart always:重启docker自动启动容器

-m 2g:容器可以使用的最大内存量

--cpus 1:可以使用的CPU数量

-e TZ='Asia/Shanghai':容器时区

-p 8990:8990:映射端口1

-p 8991:8991:映射端口2

-v /Users/huakai-mozhiqi/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:挂载主配置文件"nginx.conf"

-v /Users/huakai-mozhiqi/nginx/conf/conf.d:/etc/nginx/conf.d:挂载docker内子配置文件的路径

-v /Users/huakai-mozhiqi/nginx/logs:/var/log/nginx:挂载ngixn日志

-v /Users/huakai-mozhiqi/nginx/html:/usr/share/nginx/html:挂载项目位置

-d nginx:设置容器后台运行

        注意:mac下文件路径区分大小写

11、查看挂载情况

docker inspect myNginx | grep Mounts -A 200

 
12、访问

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/264446?site
推荐阅读
相关标签
  

闽ICP备14008679号