微信扫一扫 分享朋友圈

已有 222 人浏览分享

开启左侧

如何使用docker 安装nginx,并配置域名ssl证书

[复制链接]
222 0
1、直接安装最新的nginx
docker pull nginx
2、由于后期需要方便配置与管理nginx,需要把nginx容器内的文件夹进行挂载到宿主机中,所以此处需要进行到自己心仪的盘中创建文件夹(本次说明在/home)
mkdir nginx && cd $_ && mkdir -p {ssl,config,logs}
    ssl放域名对应证书
    config放nginx配置文件
    logs放nginx日志
3、先启动一个nginx容器用于cp对应的文件夹类型,用于后期挂载使用
docker run --name nginx -p 80:80 -d nginx
4、进行容器文件cp
nginx容器内部文件夹详情
image.png
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文件夹中

image.png
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 端口进行代理开放



免责声明:
1,海欣资源网所发布的资源由网友上传和分享,不保证信息的正确性和完整性,且不对因信息的不正确或遗漏导致的任何损失或损害承担责任。
2,海欣资源网的资源来源于网友分享,仅限用于学习交流和测试研究目的,不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。
3,海欣资源网所发布的资源由网友上传和分享,版权争议与本站无关,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。
4,如果您喜欢,请支持正版,购买正版,得到更好的正版服务,如有侵权,请联系我们删除并予以真诚的道歉,联系方式邮箱 haixinst@qq.com
海欣资源-企业信息化分享平台。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

0

关注

0

粉丝

56

主题
热度排行
回复排行
最新贴子

Archiver|手机版|海欣资源 ( 湘ICP备2021008090号-1 )|网站地图

GMT+8, 2023-2-1 18:20 , Gzip On, Redis On.

免责声明:本站所发布的资源和文章均来自网络,仅限用于学习交流和测试研究目的,不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。 本站信息来自网络,版权争议与本站无关,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 如果您喜欢,请支持正版,购买正版,得到更好的正版服务,如有侵权,请联系我们删除并予以真诚的道歉。