Docker部署Nginx服务器并实现HTTPS自动重定向

在部署之前,请确保大家已经安装了Docker,并且有一个可用的Nginx镜像。同时,大家需要准备SSL证书(.crt文件)和私钥(.key文件),这些文件将用于HTTPS加密通信。

1. 创建必要的目录和文件

首先,在你的宿主机上创建用于存储Nginx配置文件和SSL证书的目录。假设我们使用以下路径:

  • 配置文件目录:/usr/local/docker/nginx/config/conf.d
  • SSL证书目录:/usr/local/docker/nginx/https

将你的SSL证书(如ssl.crtssl.key)复制到/usr/local/docker/nginx/https目录下。

2. 编写Nginx配置文件

接下来,我们需要编写Nginx的配置文件。在/usr/local/docker/nginx/config/conf.d目录下,创建两个文件:http.confhttps.conf

http.conf

这个文件用于处理HTTP请求,并将它们重定向到HTTPS。

server {

listen 80;

listen :::80;

server_name 域名/IP地址;

重定向地址

return 301 https://server_namerequest_uri;

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root /usr/share/nginx/html;

}

}

https.conf

这个文件配置了HTTPS服务器,包括SSL证书的路径和代理设置(如果你需要将请求转发到后端服务)。

server {

listen 443 ssl;

listen :::443;

server_name 域名地址/IP地址;

注意文件位置

ssl_certificate /ssh/ssh.crt;

ssl_certificate_key /ssh/ssh.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;

location / {

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

proxy_set_header X-Forwarded-Proto $scheme;

proxy_pass http://IP或者域名:端口号;

}

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root /usr/share/nginx/html;

}

}

注意:在https.conf中,请确保ssl_certificatessl_certificate_key的路径与你的证书文件在Docker容器中的挂载路径相匹配。由于我们稍后会将/usr/local/docker/nginx/https目录挂载到容器的/etc/nginx/https,因此这里使用了/etc/nginx/https/ssl.crt/etc/nginx/https/ssl.key

3. 启动Docker容器

现在,我们可以使用Docker命令来启动Nginx容器,并挂载配置文件和SSL证书目录。

#!/bin/bash

docker run -d --name nginx \

-p 80:80 -p 443:443 \

-v /usr/local/docker/nginx/config/conf.d:/etc/nginx/conf.d \

-v /usr/local/docker/nginx/https:/https \

--privileged=true \

--restart=always \

nginx

这个命令做了以下几件事:

使用nginx镜像启动一个名为nginx的容器。

将宿主机的80和443端口映射到容器的80和443端口。

将宿主机的配置文件目录和SSL证书目录挂载到容器内相应的位置。

设置容器为特权模式(通常不需要,除非你有特殊需求)。

设置容器在退出时自动重启。

4. 验证配置

启动容器后,大家可以通过访问大家的域名或IP地址来验证Nginx是否正在运行,并且HTTP请求是否被正确地重定向到HTTPS。

相关推荐
lichenyang4535 小时前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4535 小时前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4535 小时前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4535 小时前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
Patrick_Wilson5 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
Suroy5 天前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭5 天前
运行你的第一个Docker容器
后端·docker·容器
宋均浩6 天前
# Docker 镜像瘦身实战:从 1.2G 到 80MB 的五个优化步骤
ci/cd·docker
Avan_菜菜7 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https