【云原生 | 从零开始学Docker】三、Docker实战之安装Nginx和Tomcat

简介: 通过前面两章的学习,相信各位朋友们都在自己的服务器上安装了docker了,也熟悉了一些常用的指令,这里我带着大家去做一些简单的实战来让各位更熟悉这些指令!接下来的内容最好跟着敲一遍,记一下步骤,能让你更深刻理解!

Nginx


1.1 搜索镜像


在这里我们有两个选择。


1.在shell里,使用指令docker search nginx来搜索nginx的镜像,然后选择下载。


2.去docker hub搜索nginx,里面有详细的内容以及安装(对于nginx不熟悉的可以这么做)


这里我们就选择用shell安装,官网的地址放在这里:docker hub的nginx


15.png


1.2 下载


找到镜像之后,我们选择直接用docker pull nginx下载最新版的Nginx。


16.png


pull会自动下载最新的版本,我们看到分层下载之后这个界面就是安装成功了。


1.3 启动,绑定端口


还记得我们之前说的docker run的-p选项嘛,可以通过绑定端口让外部通过这个端口访问内部,今天我们就要来实战试一试。因为nginx常用的就是80端口,所以我们通过外部一个没有用过的端口来和80端口绑定!


docker run -d --name nginx01 -p 3456:80 nginx #这里我们用3456端口


上面这段指令的意思是,以后台启动nginx,把该镜像名字改为nginx01,并且把宿主机的3456端口和nginx的80端口绑定。


17.png


启动成功!


1.4 查看端口


我们设置完端口之后,先通过curl指令检查一下端口。


curl localhost:3456 welcome to nginx


18.png


没问题,然后我们尝试一下通过服务器ip:3456进入nginx,如果可以进入那就是没问题。


19.png


嗯? 咱们不是没问题吗,为什么访问不了?其实这个问题是因为防火墙的原因,这里我们解释一下


镜像通过run启动起来容器,容器就相当于独立的小的linux,在里面也有一个防火墙,我们启动了nginx 开启了80端口,但是他和外面隔离,外部访问不了,我们的linux也有防火墙,然后外网如果访问服务器,比如你开启3456端口,外网就能通过这个端口访问了,但是此时还是不能访问docker,我们要让宿主机和容器打通 ,就是-p。


但是腾讯或者阿里云都是有一个安全组的,外网要访问,先通过安全组再进入宿主机再进入docker,所以我们需要在安全组里面打开对应端口才可以访问。


0.png


选择防火墙,添加规则


111.png


之后点击确定,我们就可以访问了。


222.png


到这里,nginx没有问题了!我们再进入这个容器里面看看。


1.5 进入nginx


我们用whereis nginx查看nginx的路径


4.png


然后通过exec -it交互模式进入nginx


40.png


我们发现成功进入,到了这一步就算完成了。


恭喜你,成功的用docker安装了nginx,接下来我们去尝试一下tomcat!tomcat和nginx差不多,相信你现在肯定没问题。


Tomcat


2.1 搜索镜像


和nginx步骤一样,如果你不熟悉,就去docker hub看吧!tomcat


这里给大家介绍一个测试常用的操作


docker run -it --rm tomcat:9.0

如果加上–rm的话,当你停止当前容器它就会自动删除,也没有历史记录,不加的话停止了还可以查到容器,这个功能最好是在测试的时候使用!


2.2 下载


这里就不去搜索了,直接用pull下载最新版的tomcat,记得退出刚才进入的nginx!


docker pull tomcat


41.png


2.3 启动tomcat


这里我们依旧使用-p来绑定端口连通,然后在服务器防火墙开放端口,起名为tomcat01并且后台运行!


docker run -d -p 3357:8080 --name tomcat01 tomcat


42.png


2.4 测试


我们启动之后,端口也开放了,我们就可以通过浏览器去访问,和nginx一样,我们通过服务器ip:3357来访问我们的tomcat。


43.png


此时我们发现一个问题,可以访问tomcat,但是显示404是什么鬼!


其实这是一个坑,在第一章的时候我们提过,docker为什么便捷,小,是因为他是阉割版本,因为官方阉割镜像的原因,默认是最小的镜像,会把不必要的都剔除,我们进入tomcat看一下具体问题。


44.png


进去之后我们ls一下查看文件。


45.png


出问题的在于webapps这个文件,我们进去查看一下


46.png


好家伙,文件夹里空无一物,怪不得访问404,那我们怎么解决这个问题呢。


这个时候有两个解决办法,我们发现有一个webapps.dist这个文件,我们可以把这个文件里面的东西复制导webapps来解决这个问题,或者是直接把这个文件改成webapps,把原来的删掉!


cp -r webapps.dist/* webapps


我们通过cp复制过去!


47.png


可以看到,现在webapps里面有东西了,我们这个时候刷新下网页看看!


48.png


可以看到,问题解决了!


好了,现在你学会了如何通过docker去安装nginx和tomcat,还学会了端口链接等操作,那么我们在最后放一个问题,我们现在每次修改配置文件都要进去很麻烦,要是能在外部提供一个映射路径,达到在容器修改文件名容器内部就自动修改是不是很方便,这个功能其实就是我们的数据卷!我们将在第五章讲到,各位可以期待一下~

目录
相关文章
|
5月前
|
应用服务中间件 网络安全 nginx
手把手教你使用 Docker 部署 Nginx 教程
本文详解Nginx核心功能与Docker部署优势,涵盖镜像拉取、容器化部署(快速、挂载、Compose)、HTTPS配置及常见问题处理,助力高效搭建稳定Web服务。
2227 4
|
8月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
5月前
|
应用服务中间件 Linux nginx
在虚拟机Docker环境下部署Nginx的步骤。
以上就是在Docker环境下部署Nginx的步骤。需要注意,Docker和Nginix都有很多高级用法和细节需要掌握,以上只是一个基础入门级别的教程。如果你想要更深入地学习和使用它们,请参考官方文档或者其他专业书籍。
263 5
|
6月前
|
关系型数据库 数据库 PostgreSQL
docker 安装 Postgres 17.6
本文介绍如何通过Docker安装和配置PostgreSQL 17.6。内容包括拉取镜像、导出配置文件、运行容器并挂载数据与配置文件目录,以及进入容器使用psql操作数据库的完整步骤,便于持久化管理和自定义配置。
851 3
docker 安装 Postgres 17.6
|
5月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
692 6
|
5月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
518 2
|
存储 Cloud Native 数据处理
从嵌入式状态管理到云原生架构:Apache Flink 的演进与下一代增量计算范式
本文整理自阿里云资深技术专家、Apache Flink PMC 成员梅源在 Flink Forward Asia 新加坡 2025上的分享,深入解析 Flink 状态管理系统的发展历程,从核心设计到 Flink 2.0 存算分离架构,并展望未来基于流批一体的通用增量计算方向。
474 0
从嵌入式状态管理到云原生架构:Apache Flink 的演进与下一代增量计算范式
|
7月前
|
运维 监控 Cloud Native
从本土到全球,云原生架构护航灵犀互娱游戏出海
本文内容整理自「 2025 中企出海大会·游戏与互娱出海分论坛」,灵犀互娱基础架构负责人朱晓靖的演讲内容,从技术层面分享云原生架构护航灵犀互娱游戏出海经验。
644 16
|
7月前
|
运维 监控 Cloud Native
从本土到全球,云原生架构护航灵犀互娱游戏出海
内容整理自「 2025 中企出海大会·游戏与互娱出海分论坛」,灵犀互娱基础架构负责人朱晓靖的演讲内容,从技术层面分享云原生架构护航灵犀互娱游戏出海经验。