1.引言
运行一个镜像,需要添加大量的参数
可以通过docker-compose编写这些参数
Docker-compose可以帮助我们批量管理容器
只需要通过一个docker-compose.yml文件去维护即可
2.下载Docker-Compose
#1.去GitHub官网搜docker-compose 下载1.24.1版本的docker
https://github.com/docker/compose/releases/download/1.24.1/docker-compose-Linux-x86_64
#2. 将下载好的文件,拖拽到Linux系统下放到root目录下
将docker-compose放到 /usr/local
mv docker-compose-Linux-x86_64 /usr/local
#3.需要将docker-compose的文件名称修改一下,方便使用, 基于文件一个可执行文件
mv docker-compose-Linux-x86_64 docker-compose
chmod 777 docker-compose
#4.为了方便使用配置环境变量(将docker-compose拖放到bin目录)
mv docker-compose bin
vi /etc/profile -- 配置路径
export PATH=/usr/local/bin:$PATH
source /etc/profile
#5.测试
#在任意目录下输入
docker-compose
#出现一下则表示成功
[root@izjlyo1d8nuj1gz ~]# docker-compose
Define and run multi-container applications with Docker.
Usage:
docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]
docker-compose -h|--help
Options:
-f, --file FILE Specify an alternate compose file
(default: docker-compose.yml)
-p, --project-name NAME Specify an alternate project name
(default: directory name)
--verbose Show more output
--log-level LEVEL Set log level (DEBUG, INFO, WARNING, ERROR, CRITICAL)
--no-ansi Do not print ANSI control characters
-v, --version Print version and exit
-H, --host HOST Daemon socket to connect to
--tls Use TLS; implied by --tlsverify
--tlscacert CA_PATH Trust certs signed only by this CA
--tlscert CLIENT_CERT_PATH Path to TLS certificate file
--tlskey TLS_KEY_PATH Path to TLS key file
--tlsverify Use TLS and verify the remote
--skip-hostname-check Don't check the daemon's hostname against the
name specified in the client certificate
--project-directory PATH Specify an alternate working directory
(default: the path of the Compose file)
--compatibility If set, Compose will attempt to convert keys
in v3 files to their non-Swarm equivalent
3.Docker-Compose管理MySQL和Tomcat容器
yml文件以key: value 方式来指定配置信息
多个配置信息以换行+缩进的方式来区分
在docker-compose.yml 文件中,不要使用制表符
version: '3.1'
services:
mysql: #服务的名称
restart: always #代表只要docker 启动,那么这个容器就跟着一起启动
image: daocloud.io/library/mysql:5.5.55 #指定镜像的路径
container_name: mysql #指定容器名称
ports:
- 3306:3306 # 端口号映射 多个
#-3302::3306
environment:
MYSQL_ROOT_PASSWORD: root #指定MySQL的ROOT用户登录密码
TZ: Asia/Shanghai #指定时区
volumes: #数据卷
- /opt/docker_mysql_tomcat/mysql_data:/var/lib/mysql #映射数据卷
tomcat:
restart: always
image: daocloud.io/library/tomcat:8.5.15-jre8
container_name: tomcat
ports:
- 8080:8080
environment:
TZ: Asia/Shanghai
volumes:
- /opt/docker_mysql_tomcat/tomcat_webapps:/usr/local/tomcat/webapps
- /opt/docker_mysql_tomcat/tomcat_logs:/usr/local/tomcat/logs
4.使用Docker-Compose命令管理器
使用docker-compose命令是,默认会在当前目录下找docker-compose.yml
如果没有是不生效的
#1.基于docker-compose.yml启动管理的容器
docker-compose up -d
#2. 关闭并删除容器
docker-compose down
#3.开启或关闭|重启已经存在的有docker-compose维护的容器
docker-compose start|stop|restart
#4.查看由docker-compose管理的容器
docker-compose ps
#5.查看日志
docker-compose logs -f
5.docker-compose配置Dockerfile使用
使用docker-compose.yml文件以及Dockerfile文件在生成自定义镜像的同时启动当前镜像,并且docker-compose去管理容器
#yml文件
version: '3.1'
services:
ssm:
restart:always
bulid: #构建自定义镜像
context: ../ #指定dockerfile文件的所在路径
dockerfile: Dockerfile #指定Dockerfile文件名称
image: ssm: 1.0.1
container_name: ssm
ports:
- 8082:8080
enviroment:
TZ: Asia/Shanghai
#Dockerfile文件
from daocloud.io/library/tomcat:8.5.15-jre8
copy itbbs.war /usr/local/tomcat/webapps
#可以直接启动基于docker-compose.yml以及Dockerfile文件构建的自定义镜像docker-compose up -d
#如果自定义镜像不存在,会帮助我们构建出自定义镜像,如果自定义镜像存在,会直接运行镜像
#重新构建的话
docker-compose bulid
#运行前,重新构建
docker-compose up -d --bulid