docker 安装nginx,并配置域名ssl证书(超详细)
  RW5u4wagFmph 2023年11月13日 23 0

1、直接安装最新的nginx

docker pull nginx

2、由于后期需要方便配置与管理nginx,需要把nginx容器内的文件夹进行挂载到宿主机中,所以此处需要进行到自己心仪的盘中创建文件夹(本次说明在/home)

mkdir nginx && cd $_ && mkdir -p {ssl,config,logs}
  1. ssl放域名对应证书
  2. config放nginx配置文件
  3. logs放nginx日志

3、先启动一个nginx容器用于cp对应的文件夹类型,用于后期挂载使用

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

4、进行容器文件cp

nginx容器内部文件夹详情

docker 安装nginx,并配置域名ssl证书(超详细)_html

docker cp nginx:/etc/nginx/nginx.conf /home/nginx/config/
docker cp nginx:/etc/nginx/conf.d /home/nginx
docker cp nginx:/usr/share/nginx/html /home/nginx

5、此时需要停止并删除已启动容器

docker stop nginx
docker rm nginx

6、把我们域名对应的证书放置ssl文件夹中

docker 安装nginx,并配置域名ssl证书(超详细)_html_02

 7、现在开始配置一下我们的nginx.conf文件了(注意:本例子80端口强制跳转到443,即强https)

user  nginx;
worker_processes  auto;error_log  /var/log/nginx/error.log notice;
pid        /var/run/nginx.pid;events {worker_connections  1024;
}http {client_max_body_size 100m;include mime.types;server {listen 80;server_name www.xxx.com;rewrite ^(.*) https://$server_name$1 permanent;}server {listen 443 ssl;  # 1.1版本后这样写server_name www.xxx.com; #填写绑定证书的域名ssl_certificate /home/xxx.com.pem;  # 指定证书的位置,绝对路径ssl_certificate_key /home/xxx.com.key;  # 绝对路径,同上ssl_session_timeout 5m;ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #按照这个协议配置ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;#按照这个套件配置ssl_prefer_server_ciphers on;ssl_session_cache shared:SSL:1m;fastcgi_param  HTTPS        on;fastcgi_param  HTTP_SCHEME     https;location / {proxy_set_header   X-Real-IP         $remote_addr;proxy_set_header   Host              $http_host;proxy_set_header   X-Forwarded-For   $proxy_add_x_forwarded_for;root   /usr/share/nginx/html;try_files $uri $uri/ /index.html;}}# 引入扩展配置(可以细分服务nginx)include /etc/nginx/conf.d/*.conf;
}

8、此时可以输入命令进行启动容器

docker run --name nginx -p 443:443 -p 80:80 -v /home/nginx/html:/usr/share/nginx/html -v /home/nginx/config/nginx.conf:/etc/nginx/nginx.conf/ -v /home/nginx/logs:/var/log/nginx/ -v /home/nginx/ssl:/etc/nginx/ssl/ --privileged=true -d --restart=always nginx

9、此时启动成功完毕

10、浏览器输入对应域名或者ip即可访问

温馨提示:本例子需要在服务器安全组中开放80和443端口,如果服务器内部也启用了防护墙,也需要进行开放,但docker会根据-p 端口进行代理开放

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月13日 0

暂无评论

推荐阅读
  jnZtF7Co41Wg   2023年12月11日   27   0   0 nginx客户端服务端
  wwLZeziuqjLR   2023年12月11日   30   0   0 Dockercentos
  MCWYWqSAMsot   2023年12月11日   31   0   0 Docker
  stLBpDewCLT1   2023年12月08日   27   0   0 nginx
  DnoStTHsc0vp   2023年12月11日   24   0   0 Docker
  wwLZeziuqjLR   2023年12月08日   98   0   0 Dockercentosbash
  jnZtF7Co41Wg   2023年12月10日   20   0   0 nginx客户端服务端NFS
RW5u4wagFmph