首页 > 系统相关 >docker 安装nginx,并配置域名ssl证书(超详细)

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

时间:2023-09-08 12:33:30浏览次数:37  
标签:nginx ssl conf home docker 80

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证书(超详细)_nginx

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证书(超详细)_docker_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 端口进行代理开放

标签:nginx,ssl,conf,home,docker,80
From: https://blog.51cto.com/u_15988698/7408425

相关文章

  • 利用时间戳切割Nginx日志
    worker_processes2;events{worker_connections1024;}http{includemime.types;default_typeapplication/octet-stream;log_formataka_logs'{"@timestamp":"$time_iso8601",''&q......
  • linux centos 安装 openssl和httpd错误。
    一、出现如下错误;ab.o:Infunction`ssl_print_cert_info':/srv/httpd-2.4.57/support/ab.c:666:undefinedreferenceto`X509_get_version'/srv/httpd-2.4.57/support/ab.c:668:undefinedreferenceto`X509_getm_notBefore'/srv/httpd-2.4.57/support/ab.c......
  • nginx + php procedures
    https://mkyong.com/nginx/nginx-php-on-windows/https://www.youtube.com/watch?v=loSNnt9ZzWI&ab_channel=javafrmhowtostopnginx?nginx-sstophowtostartnginx?startnginx......
  • arm架构docker安装nacos
    前言搞了个hk1box,装了armbian系统,想用这个当服务器调试微服务,需要安装nacos。尝试安装非docker版本的nacos,去github下载arm版本的并且放到linux下面,运行的时候报tomcat错误,装了tomcat后还是报错,改了很多设置老是跑不了,于是决定用docker版本。1、挂载目录mkdir-p/home/nacos/l......
  • 启动nginx
    Docrootis:/usr/local/var/wwwThedefaultporthasbeensetin/usr/local/etc/nginx/nginx.confto8080sothatnginxcanrunwithoutsudo.nginxwillloadallfilesin/usr/local/etc/nginx/servers/.Tohavelaunchdstartnginxnowandrestartatlogin:b......
  • 自动化安装Nginx脚本:简化您的服务器配置
    在如今的网络世界中,Nginx作为一款高性能的Web服务器和反向代理服务器,扮演着至关重要的角色。然而,手动安装和配置Nginx可能会耗费大量时间和精力,特别是对于那些对Linux系统不太熟悉的人来说。幸运的是,我们为您带来了一个自动化的解决方案,能够简化整个Nginx安装和配置过程。我们为您......
  • 深入理解容器化部署与Docker
    什么是容器化部署?容器化部署是将应用程序及其所有依赖项打包到一个独立的容器中的方法。容器是一个轻量级、可移植的单元,它可以在不同的环境中运行,而无需担心依赖项问题。容器化部署通常使用容器编排工具(如Kubernetes)来管理和协调容器的部署。为什么使用容器化部署?使用容器化部署的......
  • 安装docker 镜像之后 进入镜像下载报错
    在学习使用docker技术过程中,基于centos镜像自定义新的镜像,其中基础镜像centos需要提前安装好vim和net-tools,然而在刚开始通过yum-yinstallvim安装vim时,便出现了错误提示信息:Error:Failedtodownloadmetadataforrepo'appstream':Cannotprepareinternalm......
  • Windows上要启动和停止关闭Nginx
    要启动和停止关闭Nginx,在Windows上,你可以使用以下命令:启动Nginx:```nginx```停止关闭Nginx:```nginx-sstop```如果你使用`startnginx`命令在后台启动了Nginx,则可以使用以下命令将其停止关闭:```nginx-squit```使用`stop`参数将会优雅地关闭Nginx,而使用`quit`参数将会......
  • Nginx_(背锅)解析漏洞复现
    目录Nginx解析漏洞复现1.1、漏洞描述1.2、漏洞等级1.3、影响版本1.4、漏洞复现1、基础环境2、漏洞扫描3、漏洞验证1.5、深度利用GetShellNginx解析漏洞复现说明内容漏洞编号漏洞名称漏洞评级影响范围漏洞描述Nginx解析漏洞该解析漏洞是PHPCGI的......