1.引言
運(yùn)行一個(gè)鏡像,需要添加大量的參數(shù)
可以通過docker-compose編寫這些參數(shù)
Docker-compose可以幫助我們批量管理容器
只需要通過一個(gè)docker-compose.yml文件去維護(hù)即可
2.下載Docker-Compose
#1.去GitHub官網(wǎng)搜docker-compose 下載1.24.1版本的docker
https://github.com/docker/compose/releases/download/1.24.1/docker-compose-Linux-x86_64
#2. 將下載好的文件,拖拽到Linux系統(tǒng)下放到root目錄下
將docker-compose放到 /usr/local
mv docker-compose-Linux-x86_64 /usr/local
#3.需要將docker-compose的文件名稱修改一下,方便使用, 基于文件一個(gè)可執(zhí)行文件
mv docker-compose-Linux-x86_64 docker-compose
chmod 777 docker-compose
#4.為了方便使用配置環(huán)境變量(將docker-compose拖放到bin目錄)
mv docker-compose bin
vi /etc/profile -- 配置路徑
export PATH=/usr/local/bin:$PATH
source /etc/profile
#5.測試
#在任意目錄下輸入
docker-compose
#出現(xiàn)一下則表示成功
[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

image.png

image.png
3.Docker-Compose管理MySQL和Tomcat容器
yml文件以key: value 方式來指定配置信息
多個(gè)配置信息以換行+縮進(jìn)的方式來區(qū)分
在docker-compose.yml 文件中,不要使用制表符
version: '3.1'
services:
mysql: #服務(wù)的名稱
restart: always #代表只要docker 啟動(dòng),那么這個(gè)容器就跟著一起啟動(dòng)
image: daocloud.io/library/mysql:5.5.55 #指定鏡像的路徑
container_name: mysql #指定容器名稱
ports:
- 3306:3306 # 端口號(hào)映射 多個(gè)
#-3302::3306
environment:
MYSQL_ROOT_PASSWORD: root #指定MySQL的ROOT用戶登錄密碼
TZ: Asia/Shanghai #指定時(shí)區(qū)
volumes: #數(shù)據(jù)卷
- /opt/docker_mysql_tomcat/mysql_data:/var/lib/mysql #映射數(shù)據(jù)卷
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命令是,默認(rèn)會(huì)在當(dāng)前目錄下找docker-compose.yml
如果沒有是不生效的
#1.基于docker-compose.yml啟動(dòng)管理的容器
docker-compose up -d
#2. 關(guān)閉并刪除容器
docker-compose down
#3.開啟或關(guān)閉|重啟已經(jīng)存在的有docker-compose維護(hù)的容器
docker-compose start|stop|restart
#4.查看由docker-compose管理的容器
docker-compose ps
#5.查看日志
docker-compose logs -f
5.docker-compose配置Dockerfile使用
使用docker-compose.yml文件以及Dockerfile文件在生成自定義鏡像的同時(shí)啟動(dòng)當(dāng)前鏡像,并且docker-compose去管理容器
#yml文件
version: '3.1'
services:
ssm:
restart:always
bulid: #構(gòu)建自定義鏡像
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

image.png
#可以直接啟動(dòng)基于docker-compose.yml以及Dockerfile文件構(gòu)建的自定義鏡像docker-compose up -d
#如果自定義鏡像不存在,會(huì)幫助我們構(gòu)建出自定義鏡像,如果自定義鏡像存在,會(huì)直接運(yùn)行鏡像
#重新構(gòu)建的話
docker-compose bulid
#運(yùn)行前,重新構(gòu)建
docker-compose up -d --bulid