使用docker部署nginx+tomcat架构(3):使用docker-compose简化部署操作
经历了之前的两篇,我们已经大体上了解了docker部署容器的过程。
不过,整个部署过程中需要手动输入很多的docker命令,稍显繁琐并且容易出错。那么有没有一种相对简洁优雅的方式来完成这些部署工作呢?答案是有的,docker-compose(一下简称“compose”)正是为此而生。
关于docker-compose(了解更多:https://docs.docker.com/compose/):
Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Compose 是一个用户定义和运行多个容器的 Docker 应用程序。在 Compose 中你可以使用 YAML 文件来配置你的应用服务。然后,只需要一个简单的命令,就可以创建并启动你配置的所有服务。
“compose”的安装过程这里就不详述了,不过个人推荐通过pip进行安装,具体安装过程可百度得知。
下面就让我们来使用“compose”完成之前的部署工作,看看“compose”是怎么简化操作的。
先看一个配置文件docker-compose.yml:
version: "3"
services:
mysql:
image: mysql:5.7
restart: always
container_name: mysql
ports:
- "3306:3306"
volumes:
- ~/mysql/conf:/etc/mysql/conf.d
- ~/mysql/data:/var/lib/mysql
- ~/mysql/logs:/var/log/mysql
environment:
- MYSQL_ROOT_PASSWORD=admin tomcat1:
image: tomcat
container_name: tomcat1
volumes:
- ~/tomcat/conf:/usr/local/tomcat/conf
- ~/tomcat/webapps:/usr/local/tomcat/webapps
depends_on:
- mysql
links:
- mysql tomcat2:
image: tomcat
container_name: tomcat2
volumes:
- ~/tomcat/conf:/usr/local/tomcat/conf
- ~/tomcat/webapps:/usr/local/tomcat/webapps
depends_on:
- mysql
links:
- mysql nginx:
image: nginx
container_name: nginx
ports:
- "80:80"
volumes:
- ~/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
- ~/nginx/www:/usr/share/nginx/html
- ~/nginx/logs:/var/log/nginx
links:
- tomcat1
- tomcat2
关于compose配置文件的详细解释请参看:https://docs.docker.com/compose/compose-file/
这里简单说下,docker-compose.yml是“compose”的默认配置文件,“compose”就是通过这个文件对docker容器进行快速编排、部署管理的。配置文件遵循YAML语法,并且由三个核心部分组成:version、services和networks(本篇没有用到)。
version指明当前版本,目前主要有1,2,3三个大版本,每个版本都跟docker-engine有着对应关系。大体的对应关系如下:
services定义了用于部署的服务(容器),以配置文件中的mysql为例进行说明:
image 指定容器镜像及其版本
container_name 设置容器名称
ports 配置容器的端口映射
volumes 绑定宿主机的本地路径到容器
environment 预设容器的环境变量
tomcat1中还有depends_on和links,这是两个很有使用的配置项。
depends_on 通过依赖关系按顺序启动docker服务
links 将依赖的服务以hosts形式注册到容器
我们知道在部署软件的时候,时常要考虑个组件之间的依赖关系。比如tomcat如果想访问数据库,必须要先启动mysql(当然也可以是其他数据库)。在传统的做法中,一般依赖于软件实施人员手动进行控制和确认,但是“compose”提供了depends_on配置项就解决了这个问题,只需配置好依赖的docker服务,“compose”就会在部署时优先启动被依赖的服务。使用过spring的同学应该能够理解,这就是容器间的“依赖注入”啊。
至于links这个配置项,就更是利器了。在之前的篇章中,我们都是在mysql部署后通过“docker inspect mysql|grep IPAddress”查看mysql的IP,然后再修改tomcat中关于mysql的配置,这样的方式非常的不智能并且麻烦。但是通过links配置项,docker在启动过程中会将容器所需连接的服务以hostname的形式注册到网络中,那么容器启动后可通过hostname访问对应的docker服务,免去了手动配置的痛苦。
使用docker部署nginx+tomcat架构(3):使用docker-compose简化部署操作的更多相关文章
- 使用docker部署nginx+tomcat架构(2):访问mysql数据库
上一篇完成了通过docker部署nginx+tomcat的基础软件架构,但是距离一个真正可用的软件架构还差得很远.其中最重要的一点是缺少数据库这个角色的存在,那么本篇就来完善这一点. 废话少说,直接进 ...
- 使用docker部署nginx+tomcat架构
架构说明: 使用nginx+tomcat实现动态/静态(资源请求)分离和负载均衡. 参考文档: https://www.runoob.com/docker/docker-tutorial.html 配 ...
- kubernetes部署nginx/tomcat
kubernetes集群已经部署好了,需要的话可以参考之前的文章https://www.cnblogs.com/winter1519/p/10015420.html [root@master tomc ...
- docker-compose入门示例:一键部署 Nginx+Tomcat+Mysql
整体环境配置 整体环境的配置,如果一个一个 Dockerfile 去写,那么是相当麻烦的,好在 Docker 有一个名为 Docker-Compose 的工具提供,我们可以使用它一次性完成整体环境的配 ...
- Docker中nginx+tomcat实现负载均衡
拉取tomcat镜像 docker pull tomcat 运行两个tomcat容器 docker run -d -p 8088:8080 --name tomcat8088 tomcat docke ...
- centos7 部署 nginx+tomcat+MariaDB 环境并安装安全狗,使用natapp隧道
jdk安装: -openjdk 参考:https://blog.csdn.net/dhr201499/article/details/81626466 tomcat安装: 使用版本:8.5.37 参考 ...
- shell一键部署nginx+tomcat
1.首先拉取环境 tomcat需要用到jdk环境 提前准备好nginx源码包,放于指定目录下 vim test.sh #!/bin/bash yum -y install gcc gcc-c++ z ...
- nginx+tomcat 架构 HttpServletRequest.getScheme()获取正确的协议
http://blog.csdn.net/ofofw/article/details/46791447
- Docker部署Mysql, Tomcat, Nginx, Redis
1. Mysql部署 问题及解决方案 容器内的网络和外部机器不能直接通信 外部机器和宿主机可以直接通信 宿主机和容器可以直接通信 当容器中的网络服务需要被外部机器访问时,可以将容器中提供服务的端口映射 ...
随机推荐
- log4j打印抛出异常时堆栈内容
JAVA 中为快速定位,抛出异常的位置.往往需要在日志中描述. log.err("异常出错点", e); 会将出错时的堆栈信息显示出来. package com.jqyc.jase ...
- 获取豆瓣电影数据(R与API获取网页数据)
一般成熟的网站都会有反爬虫策略,例如限制访问次数,限制访问 IP,动态显示数据等.爬虫和反爬虫就是一直相爱相杀地互相钳制.如果要通过爬虫来获取某些大型网站的数据,那是一件很费时费力的活.小白总遭遇过在 ...
- FGPA异步信号问题
FPGA在处理异步信号时,尽量打1~2拍寄存器,否则在线调试会发现各种奇怪问题. 下面是verilog代码 在线调试发现,计数器在跳变 原因是cmd_start由ARM输出,与FPGA时钟异步,需要打 ...
- Java学习:网络编程总结
Java网络编程总结 一.概述 计算机网络是通过传输介质.通信设施和网络通信协议,把分散在不同地点的计算机设备互连起来,实现资源共享和数据传输的系统.网络编程就就是编写程序使联网的两个(或多个)设备( ...
- 【05】Saltstack:配置详解
写在前面的话 上一节迷迷糊糊的说了一下配置管理,这一节主要谈谈我们常见的一些操作如何将他转换成配置文件的形式来实现.这样的好处在于,我们可以一次编写到处使用,不用每次再去编写复杂的命令. 配置回顾 在 ...
- java报错 pom.xml第一行报"org.apache.maven.archiver.MavenArchiver.getManifest(org.apache.maven.project...
https://www.cnblogs.com/appium/p/11168441.html 新建Maven项目时,每个pom文件第一行都报错. 一.问题分析 原因就是你的maven的配置文件不是最新 ...
- web api对接小程序基本签名认证
using BMOA.Application.System; using BMOA.Common; using BMOA.Web.Models; using Newtonsoft.Json; usin ...
- sedlauncher.exe 磁盘爆满
打开应用和功能,搜KB4023057,然后卸载. 快捷键WIN+R打开运行,输入services.msc回车打开系统服务,找到Windows Remediation Service (sedsvc)和 ...
- ES6 Set和Map集合(六)
一.Set集合创建Set实例:let set = new Set();1.特性:a.Set本身是一个构造函数,用来生成Set数据结构[类比数组结构]b.Set函数可以接受具有Iterable接口的数据 ...
- Spring Cache Redis结合遇到的坑
业务上需要把一些数据放到redis里面,但是系统逻辑代码差不多编写完成了,怎么整?用Spring Cache啊,对既有业务逻辑侵袭极小. 于是尝试调查了一下,遇到一些问题分享一下(本文使用Spring ...