阿里云docker安装nginx

本文详细介绍了如何使用Docker拉取Nginx镜像,创建并运行Nginx容器,以及如何通过两种方式修改容器内的Nginx配置文件。第一种方法是直接进入容器内部修改,第二种方法是通过挂载主机目录实现配置文件的外部编辑。此外,还强调了在挂载目录操作时需要注意的路径问题。

一.获取nginx镜像,创建nginx容器并运行

1.使用docker pull nginx命令拉取nginx镜像到本地

86e310404cd74b2e97f4a565daae63c4.png

2.使用docker images nginx命令,查看我们拉取到本地的nginx镜像IMAGE ID

74222e089dc24d458b5f014441a88c7a.png

3. 首先测试下nginx镜像是否可用,使用docker run -d --name mynginx -p 9001:80 nginx创建并启动nginx容器

docker run -d --name mynginx -p 9001:80 nginx
  • -d 指定容器以守护进程方式在后台运行
  • --name 指定容器名称,此处我指定的是mynginx,也可设置其他名字
  • -p 指定主机与容器内部的端口号映射关系,格式 -p
  • [宿主机端口号]:[容器内部端口],此处我使用了主机9001端口,映射容器80端口

4. 此时使用docker ps可以看到正在运行的nginx容器

02a5548a6d30474ba6353c0b1f9db27c.png

 5.浏览器输入阿里云公共ip:9001就可以看到下列网页了

95d18ef1c4854b279fbfccec914678be.png

   如果看不到,检查一下阿里云控制台的安全组是否开启http端口

f12cb285e03a492ba5988ec2cbd31c04.png

 

到这里我们已经完成了nginx容器的搭建,但是此时还有个问题,我们如何修改nginx的配置文件?

二.修改nginx的配置文件

这里有两种方式解决这个问题:

方式一:每次都进入到nginx容器内部修改

该方法需要每次都进入到nginx容器内部修改。比较适合改动少,简单使用的情况!

1.执行·docker exec -it ef /bin/bash·进入到nginx容器内部

  • exec 命令代表附着到运行着的容器内部
  • -it 是 -i 与 -t两个参数合并写法,-i -t 标志着为我们指定的容器创建了TTY并捕捉了STDIN
  • exec -i:  --interactive(相互作用的)   即使没有连接,也要保持STDIN打开
    exec -t:   --tty                                   Allocate a pseudo-TTY(分配一个 冒充的终端设备)
  • ef 是我们要进入的容器,可以写容器id,也可以写容器别名
  • /bin/bash 指定了执行命令的shell

aa9cca12d0454285af64b6ddc027bb37.png

2.进入到nginx容器内部后,我们可以cd /etc/nginx,可以看到相关的nginx配置文件都在/etc/nginx目录下

8844fc33796340a6a897c4ca6e4248fe.png

而nginx容器内的默认首页html文件目录为/usr/share/nginx/html

4a8035a9cbc446beaae793205e66cde1.png

日志文件默认位于/var/log/nginx

f71e99e27edb4967a314eca841cd39d3.png

3.执行exit命令从容器内部退出。 

方式二:将nginx容器内部配置文件挂载到主机

将nginx容器内部配置文件挂载到主机,之后就可以在主机对应目录修改即可。适合频繁修改,复杂使用的情况!(常用)

1.在主机下创建挂载目录,你也可以创建其他目录

mkdir -p /home/nginx{conf,log,html}

2.将容器内的文件分别拷贝到主机下,分别执行

# 将容器nginx.conf文件复制到宿主机
docker cp nginx:/etc/nginx/nginx.conf /home/nginx/conf/nginx.conf

# 将容器conf.d文件夹下内容复制到宿主机
docker cp nginx:/etc/nginx/conf.d /home/nginx/conf/conf.d

# 将容器中的html文件夹复制到宿主机
docker cp nginx:/usr/share/nginx/html /home/nginx/

3.执行 docker stop mysql 命令停止刚刚创建的nginx容器,然后执行docker rm 移除容器

b54e60d0eb664b5cb9898200d5840599.png

 4.执行下列命令,重新创建nginx容器


docker run -d --name nginx -p 9001:80 -v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /home/nginx/conf/conf.d:/etc/nginx/conf.d -v /home/nginx/log:/var/log/nginx -v /home/nginx/html:/usr/share/nginx/html --privileged=true nginx

5.此时可以试试在我们在容器的挂载 /home/nginx/html目录下修改index.html,再次访问看看效果。到这里就大功告成了,下次需要修改网页和其他配置只需要直接进入你在主机创建的目录下修改即可!
最后需要注意的:我们在挂载目录的操作,都实际会映射到容器内部,写配置文件的时候一定要注意路径问题!!

 

阿里云上使用 Docker 部署 Nginx 并配置 SSL 证书以实现 HTTPS 访问,可以通过以下步骤完成。整个过程包括申请证书、准备目录结构、配置 Nginx 文件、启动容器等。 ### 1. 申请 SSL 证书 首先,前往阿里云控制台申请免费的 SSL 证书。阿里云提供的证书文件通常为 `.pem` 和 `.key` 格式[^2]。申请成功后,下载证书文件,并将其保存到本地目录,例如 `/usr/local/nginx/conf/ssl` 或其他你计划挂载到容器的目录。 ### 2. 准备宿主机目录结构 为了便于管理和维护,建议将 Nginx 的配置文件、HTML 文件、日志文件以及 SSL 证书文件分别挂载到宿主机的指定目录。可以使用以下命令创建所需目录结构: ```bash mkdir -p /usr/local/nginx/{conf,html,logs,ssl} ``` 将下载的 `.pem` 和 `.key` 文件复制到 `/usr/local/nginx/ssl` 目录中。 ### 3. 编写 Nginx 配置文件 #### 3.1 主配置文件 `nginx.conf` 在 `/usr/local/nginx/conf` 目录下创建 `nginx.conf` 文件,并确保其内容包含基本的 HTTP 配置。可以使用默认的 Nginx 配置作为基础,确保 `http` 块中包含 `include /etc/nginx/conf.d/*.conf;`,以便加载站点配置文件。 #### 3.2 站点配置文件 `conf.d/default.conf` 在 `/usr/local/nginx/conf/conf.d` 目录下创建 `default.conf` 文件,用于配置 HTTPS 站点。以下是基本的 SSL 配置示例: ```nginx server { listen 443 ssl; server_name yourdomain.com; ssl_certificate /etc/nginx/ssl/your_certificate.pem; ssl_certificate_key /etc/nginx/ssl/your_private_key.key; ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers HIGH:!aNULL:!MD5; location / { root /usr/share/nginx/html; index index.html; try_files $uri $uri/ =404; } } ``` 请将 `yourdomain.com` 替换为你的域名,并确保 `ssl_certificate` 和 `ssl_certificate_key` 的路径与挂载到容器内的路径一致。 ### 4. 启动 Nginx 容器 使用以下命令启动 Nginx 容器,并将宿主机的配置目录、SSL 证书目录、HTML 文件目录等挂载到容器中: ```bash docker run -d \ --name nginx \ -p 80:80 \ -p 443:443 \ -v /usr/local/nginx/conf:/etc/nginx \ -v /usr/local/nginx/conf.d:/etc/nginx/conf.d \ -v /usr/local/nginx/ssl:/etc/nginx/ssl \ -v /usr/local/nginx/html:/usr/share/nginx/html \ -v /usr/local/nginx/logs:/var/log/nginx \ nginx ``` ### 5. 验证 HTTPS 访问 启动容器后,通过浏览器访问 `https://yourdomain.com`,确认是否能够正常加载页面并显示安全锁标志,表示 HTTPS 配置已成功生效。 ### 6. 其他注意事项 - 确保阿里云安全组规则允许 443 端口的入站流量。 - 定期更新 SSL 证书,避免证书过期导致访问失败。 - 可以使用 `docker exec` 命令进入容器内部检查配置文件是否正确加载。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值