Docker 安装 Nginx 容器,反向代理

mkdir -p /home/nginx/log
mkdir -p /home/nginx/html



> 
> 容器中的nginx.conf文件和conf.d文件夹复制到宿主机
> 
> 
> 



生成容器

docker run --name nginx -p 9001:80 -d nginx

将容器nginx.conf文件复制到宿主机

docker cp nginx:/etc/nginx/nginx.conf /home/nginx/conf/nginx.conf

将容器conf.d文件夹下内容复制到宿主机

docker cp nginx:/etc/nginx/conf.d /home/nginx/conf/conf.d

将容器中的html文件夹复制到宿主机

docker cp nginx:/usr/share/nginx/html /home/nginx/


![](https://img-blog.csdnimg.cn/img_convert/cd5c5073a677d58aa7872ed470e67733.png)


## 创建Nginx容器并运行



直接执行docker rm nginx或者以容器id方式关闭容器

找到nginx对应的容器id

docker ps -a

关闭该容器

docker stop nginx

删除该容器

docker rm nginx

删除正在运行的nginx容器

docker rm -f nginx



docker run
-p 9002:80 \ #将容器的 9002(后面那个) 端口映射到主机的 80(前面那个) 端口
–name nginx \
-v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \ #挂载nginx.conf配置文件
-v /home/nginx/conf/conf.d:/etc/nginx/conf.d \ #挂载nginx配置文件
-v /home/nginx/log:/var/log/nginx \ #挂载nginx日志文件
-v /home/nginx/html:/usr/share/nginx/html \ #挂载nginx内容
-d nginx:latest


![](https://img-blog.csdnimg.cn/img_convert/da03a6e657f3f9b982841f5ab678cdea.png)


## 结果检测&修改内容进行展示


![](https://img-blog.csdnimg.cn/img_convert/547a5c7f5d6d1e9c4c63ddf904645d64.png)


![](https://img-blog.csdnimg.cn/img_convert/c03c8e430f9443ee5cfaa55a63a8f77f.png)



重启容器

docker restart nginx


![](https://img-blog.csdnimg.cn/img_convert/9b7fbbd897bd8575a4f15a4c14daf4fa.png)


## 通过docker-compose启动nginx,并进行反向代理


### docker-compose配置



version: ‘3.8’

services:
nginx-gateway:
image: nginx:1.24.0
container_name: nginx-gateway
restart: always
privileged: true
environment:
- TZ=Asia/Shanghai
ports:
- 9002:80 #端口映射,可以映射多个
volumes:
- /home/nginx/conf/conf.d:/etc/nginx/conf.d #挂载nginx配置文件
- /home/nginx/log:/var/log/nginx #挂载nginx日志文件
- /home/nginx/html:/usr/share/nginx/html #挂载nginx内容
networks:
- huoke_net
#depends_on: #在以下服务启动后再启动
# - user_server
# - chat_server
user_server:
image: 自己的服务镜像(ip:5000/user_server:tag)
container_name: user_server
#ports: #不需要映射端口了,直接通过nginx反向代理内部调用
# - “8001:8000”
environment:
# 时区上海
TZ: Asia/Shanghai
privileged: true
restart: always
networks:
- huoke_net # docker-compose自动分配IP
chat_server:
image: 自己的服务镜像(ip:5000/chat_server:tag)
container_name: chat_server
#ports:
# - “8002:8000”
environment:
# 时区上海
TZ: Asia/Shanghai
privileged: true
restart: always
networks:
huoke_net: # 指定docker-compose网络IP
ipv4_address: 172.20.0.11
networks:
huoke_net:
driver: bridge
ipam:
config:
- subnet: 172.20.0.0/16



> 
> 注意上面指定IP和自动分配IP,在反向代理的时候有点区别
> 
> 
> 


### 反向代理


/home/nginx/conf/conf.d 下面创建新文件或者在原来文件基础上编辑,xxx-gateway.conf



server{
# 服务
listen 8080;
listen [::]:8080;
access_log /var/log/nginx/xxx.com_access.log;
error_log /var/log/nginx/xxx.com_error.log;

location ~ /api/user/ {
    proxy_set_header Host $http_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header REMOTE-HOST $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_pass http://user_server:8000; #自动分配IP需要用服务名
}
location ~ /api/chat/ {
    proxy_set_header Host $http_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header REMOTE-HOST $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_pass http://172.20.0.11:8000; #手动分配IP,直接指定IP
}

#提高容错,当以上服务不可用的时候报错,而不是挂了
error_page   500 502 503 504  /50x.html;
location = /50x.html {
    root   /usr/share/nginx/html;
}

}

server {
# 前台
listen 80;
listen [::]:80;
server_name localhost;

access_log /var/log/nginx/xxx_frontende.com_access.log;
error_log /var/log/nginx/xxx_frontende.com_error.log;

location / {
    root   /home/nginx/html; #自定义项目部署路径
    index  index.html index.htm index.nginx-debian.html;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值