docker nginx部署web应用_Docker实战:docker部署nginx项目详解

593eff1aa3ddf021285b08a517dc3816.gif

什么是Nginx

Nginx是一款灵活、稳定、高效、低消耗的轻量级Web服务器,支持HTTP、反向代理及电子邮件(IMAP/POP3/SMTP)等服务。Nginx也是一个跨平台的服务器,可以运行在Linux、Windows、Mac OS等操作系统上。而且Nginx具有稳定的高性能、丰富的模块库、灵活的配置、占用内存少、并发能力强、响应速度快等优势,而且还开源免费深受业界追捧和公司青睐也因此得到很多企业的广泛应用。

cc07d35c39a88e1d57396e6553604801.png

查询nginx镜像

安装之前我们先从Docker Hub 上查找下是否存在nginx镜像,通过docker提供的search命令来查询Docker Hub官方仓库中的镜像。命令格式为:docker search [options] keyword,输出内容包括镜像名称、镜像描述、收藏数、是否官方创建、是否自动创建等信息,默认输出的结果按收藏数进行排序。这里我们可以看到docker仓库提供了很多nginx镜像,最受欢迎的还是官方的nginx。

9ebcf3bd88f986b98c652b6706f74407.png

下载nginx镜像

既然有nginx镜像我们就可以直接拉取下来,docker提供了拉取命令:docker pull [options] /:,该命令表示从origin远程仓库(默认Docker Hub)中的repository仓库拉取标签为tag的镜像(如果省略标签则拉取标签为latest的镜像)。这里我直接使用命令:docker pull nginx,可以从Docker Hub下载最新版本的nginx。

7b724d35a1f176f469aed9c299d392df.png

查看docker镜像

通过命令:docker images或者docker image ls可以列出本机已有的镜像,REPOSITORY资源仓库名,TAG指镜像的标签信息,IMAGE ID:是镜像的 ID(唯一的),CREATED:指镜像最后的更新时间,SIZE:指镜像的大小。这里我们可以查看到nginx已经存在,该镜像大小为133MB(还不小哦,上次下载Windows版的nginx才1.68MB)。

0aea46b2f56d71ffa99dc3f0203d6c32.png

运行nginx容器

启动容器可以通过命令:docker run [OPTIONS] IMAGE [COMMAND] [ARG...]来启动容器,可以通过配置参数来指定nginx的容器名称和运行模式等。这里我们运行一个展示vue项目的nginx服务并指定访问ip为8001,其指令为:docker run --name nginx-vue -p 8001:80 -d nginx。-p表示端口映射将本地的 8001 端口映射到容器内部的 80 端口,-d则是指定该容器一直在后台运行。

5746e1dc70aa4a246d68c395783ae221.png

验证nginx启动成功

在浏览器中输入地址:http://127.0.0.1:8001/,回车就看到熟悉的“Welcome to nginx!”则说明我们的nginx就已经启动成功了。

7a8d4622a0de4dc98949583d5e98bc68.png

创建nginx目录

这里我们需要在主机上创建用于映射nginx文件的目录,用于存放nginx的默认配置文件和静态文件。这里我们一般接触的是nginx的配置文件、日志文件和部署文件,这里我在opt中创建创建nginx目录来存放这些文件。创建目录的命令为:mkdir -p /opt/nginx/html /opt/nginx/logs /opt/nginx/conf /opt/nginx/conf.d,其中-p指递归创建目录(如果上级目录不存在,会按目录层级自动创建目录)。html目录作为nginx容器配置的项目部署目录,logs目录作为nginx容器的日志存储目录,conf目录作为nginx容器的配置文件。创建好之后将nginx默认的配置文件拷贝过来方便直接使用,执行命令:docker cp 5f07c5049a26:/etc/nginx/nginx.conf /opt/nginx/conf(其他文件自己看需求是否拷贝)。

7d98bf8e85747c3caf4075883cd1a427.png

映射并启动nginx

docker运行容器时提供了参数-v可以用来与宿主机绑定挂载目录,参数格式为:-v 宿主机目录>:容器目录>。-v /opt/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:将宿主机中的nginx.conf挂载到容器的/etc/nginx/nginx.conf 。-v /opt/nginx/conf/conf.d:/etc/nginx/conf.d: 将宿主机的conf.d目录挂载到容器的/etc/nginx/conf/conf.d 。-v /opt/nginx/html:/usr/share/nginx/html:将宿主机的html目录挂载到容器的 /usr/share/nginx/html。-v /opt/nginx/logs:/var/log/nginx:将宿主机的logs挂载到容器的/var/log/nginx。这样docker中的nginx就会加载宿主机中对应的文件目录了,这样我们就可以很方便的在宿主机中对docker中的nginx进行配置了。

170473afbf1bf8a56883a561ebe9b9fb.png

上传打包的项目文件

将vue打包好的文件上传到html目录中,再次打开浏览器访问地址 http://127.0.0.1:8001/就可以看到我们自己的项目了。这里我用的是FinalShell工具(xshell也不错,配带xftp同样可以方便的上传文件),可以直接将文件拖拽到服务器。

66b748416766c2bc2159a7d9068df020.gif

总结:

Docker部署nginx等应用还是很方便的,直接拉取下来就可以运行。简单的配置下可以使用了,剩下的操作和在centos都是一样的。以上内容是小编给大家分享的【Docker实战:docker部署nginx项目详解】,希望对大家有所帮助。为了方便学习,下面附上本文用到的源码:

# docker search nginx
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
nginx Official build of Nginx. 13870 [OK]
jwilder/nginx-proxy Automated Nginx reverse proxy for docker con… 1897 [OK]
richarvey/nginx-php-fpm Container running Nginx + PHP-FPM capable of… 791 [OK]
linuxserver/nginx An Nginx container, brought to you by LinuxS… 127
*********省略**********
# docker pull nginx
# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest f35646e83998 4 days ago 133MB
# docker run --name nginx-vue -p 8001:80 -d nginx
4a0670b2f1dfd661af193f14f1dac7abf4d0a9603c967ef5e9787f4a9fbb08b3
# docker run -d -p 8001:80 --name nginx-vue
-v /opt/nginx/html:/usr/share/nginx/html/
-v /opt/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
-v /opt/nginx/logs:/var/log/nginx
-v /opt/nginx/conf/conf.d:/etc/nginx/conf.d nginx

来源:

https://www.toutiao.com/i6884813534249943564/

“IT大咖说”欢迎广大技术人员投稿,投稿邮箱:aliang@itdks.com

6a3181230eb054c35dc7208322c20ff2.gif 来都来了,走啥走,留个言呗~

 IT大咖说  |  关于版权 

由“IT大咖说(ID:itdakashuo)”原创的文章,转载时请注明作者、出处及微信公众号。投稿、约稿、转载请加微信:ITDKS10(备注:投稿),茉莉小姐姐会及时与您联系!

感谢您对IT大咖说的热心支持!

相关推荐

推荐文章

  • 软件架构设计分层模型和构图思考

  • 通过API网关实现微服务管控-限流,熔断和降级

  • 程序员必备!这是即将写入MySQL源码的官方bug解决方案

  • Flutter跨平台、H5、小程序源码大集合,快学习起来

  • 超详细的四类数据库去重实现方案汇总,值得收藏Restful API设计规范

  • 一文看懂企业数字化转型的五大趋势

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值