nginx的安装
新建立nginx的目录
nginx
防止出现下面的错误
docker: Error response from daemon: oci runtime error: container_linux.go:262: starting container process caused "process_linux.go:339: container init caused "rootfs_linux.go:57: mounting \"/root/conf/nginx/nginx.conf\" to rootfs \"/var/lib/docker/aufs/mnt/edd3b9a8923f13404d42aa73f509b625c7370791c8 25424427eacae6432fecc8\" at \"/var/lib/docker/aufs/mnt/edd3b9a8923f13404d42aa73f509b625c7370791c8 25424427eacae6432fecc8/etc/nginx/nginx.conf\" caused \"not a directo ![](http://upload-images.jianshu.io/upload_images/11223715-3407e1c7ac8d7935?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)ry\""" : Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type.
命令建立
确定文件夹存在
touch conf/nginx.confecho 1 > conf/nginx.conf
创建容器
docker run -d -p 80:80 \ --name five-nginx \ -p 443:443 \ -v /home/user/nginx/cert:/etc/nginx/cert \ -v /home/user/nginx/config/nginx.conf:/etc/nginx/nginx.conf \ -v /home/user/nginx/html:/usr/share/nginx/html \ -v /home/user/nginx/log:/var/log/nginx \ hub.c.163.com/library/nginx
配置nginx文件
#user nginx;worker_processes 1; 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; server { listen 80; server_name www.abc.xyz; rewrite ^ https://$http_host$request_uri? permanent; } server { listen 443; server_name www.abc.xyz; ssl on; ssl_certificate /etc/nginx/cert/www.idig8.xyz.crt; ssl_certificate_key /etc/nginx/cert/www.idig8.xyz.key; ssl_session_timeout 5m; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-NginX-Proxy true; proxy_pass http://172.17.0.3:8888/; proxy_redirect off; } } }
java项目启动使用的是8888端口
nginx的配置 proxy_pass 不能使用127.0.0.1:8888
必须使用java容器内部的ip地址http://172.17.0.3:8888/; 可以通过docker inspect 来进行查看。
https的配置
把cert阿里云中下载的crt,key放入指定的目录cert中。
作者:IT人故事会
链接:https://www.jianshu.com/p/2f7c7135f097
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦