Docker环境下的nginx 网络和权限配置
前期准备
创建docker下的nginx
–-name 给你启动的容器起个名字,以后可以使用这个名字启动或者停止容器 -p 映射端口,将docker宿主机的80端口和容器的80端口进行绑定
-v 挂载文件用的,第一个-v 表示将你本地的nginx.conf覆盖你要起启动的容器的nginx.conf文件,第二个表示将日志文件进行挂载,就是把nginx服务器的日志写到你docker宿主机的/home/docker-nginx/log/下面
第三个-v 表示的和第一个-v意思一样的。
-d 表示后台启动
-itd 也表示后台运行
docker pull nginx:1.19.3-alpine
# 启动容器
docker run -itd --name nginx -p 80:80 nginx:1.19.3-alpine
# 创建容器挂载路径
mkdir -p /data/nginx/{conf,conf.d,html,logs}
# 复制配置文件到挂载路径 注意Mac下尽量把文件建在当前用户下 否则会存在各种权限问题
docker cp nginx:/etc/nginx/nginx.conf /Users/shangshuaishuai/data/nginx/conf/
docker cp nginx:/etc/nginx/conf.d/default.conf /Users/shangshuaishuai/data/nginx/conf.d/
docker cp nginx:/usr/share/nginx/html /Users/shangshuaishuai/data/nginx/
# 强制关闭删除容器
docker rm -f nginx
#以挂载的方式启动容器 -p 端口映射
docker run -id --name=nginx \
-p 80:80 \
-p 8085:8085 \
-v /Users/shangshuaishuai/data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /Users/shangshuaishuai/data/nginx/conf.d:/etc/nginx/conf.d \
-v /Users/shangshuaishuai/data/nginx/logs:/var/log/nginx \
-v /Users/shangshuaishuai/data/nginx/html:/usr/share/nginx/html \
-d nginx:1.19.3-alpine
nginx配置
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
server {
listen 8085;
server_name localhost;
add_header Access-Control-Allow-Origin '*';
add_header Access-Control-Allow-Credentials "true";
add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
add_header Access-Control-Allow-Headers 'token,DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,XRequested-With';
location / {
proxy_pass http://10.10.60.248:8080;
}
}
}
遇到的问题
curl: (7) Failed to connect to 127.0.0.1 port 8080: Connection refused
#注意 可以先进入容器
docker exec -it nginx sh
curl http://127.0.0.1:8080
#网络不通 因为容器的网络问题 要不network 切 要不 使用 宿主机的ip访问
curl http://10.10.60.248:8080
#权限问题 将文件赋予权限访问
sudo chmod -R 777 /data
其他排查用到的docker命令
#查看正在运行的容器
docker ps
docker ps -a #所有容器
# 关闭该容器
docker stop nginx
# 删除该容器
docker rm nginx
# 删除正在运行的nginx容器
docker rm -f nginx