我是靠谱客的博主 跳跃小松鼠,最近开发中收集的这篇文章主要介绍Docker三剑客——docker-compose,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

一、Docker-Compose简介

Compose是用于定义和运行容器docker应用程序的工具。通过Compose,可以使用YAML文件来配合应用程序需要的所有的服务。然后,使用一个命令,就可以从YAML文件配合中创建并启动所有服务。那么就需要了解YAML文件的基本语法。

YAML文件基本语法:

  • 大小写敏感;
  • 使用缩进表示层级关系;
  • 缩进不允许使用tab,只允许空格;
  • 缩进的空格数不重要,只要相同等级的元素左对齐即可;
  • “#”表示注释;

Docker-Compose是一个容器编排工具。通过一个.yml或.yaml文件,将所有的容器的部署方法、文件映射、容器端口映射等情况写在一个配置文件里,执行docker-compose up命令就像执行脚本一样,一个一个的安装并部署容器。

Dockerfile 可以让用户管理一个单独的应用容器;而 Compose 则允许用户在一个模板(YAML 格式)中定义一组相关联的应用容器;

Docker Compose将所管理的容器分为三层:

  • 工程(project);
  • 服务(service);
  • 容器(container);

docker compose运行目录下的所有yml文件组成一个工程,一个工程包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖。一个服务可包括多个容器实例。

docker-compose就是docker容器的编排工具,主要就是解决相互有依赖关系的多个容器的管理。

二、docker-compose工具的安装使用

若想使用docker-comppose这个容器编排工具,那么宿主机必须是基于docker的环境,可以参考docker详细安装教程。docker的环境解决了之后,就是下载docker-compose这个命令,可以上GitHub官网进行下载,如图:
docker三剑客——docker-compose
docker三剑客——docker-compose
docker三剑客——docker-compose
docker三剑客——docker-compose
下载compose工具时,需先查看本机的docker版本!

[root@docker ~]# docker -v
//查看docker的版本信息
Docker version 18.09.0, build 4d60db4
//本次采用18.9.0版本

如果docker版本过低,可以自行查找其他版本的docker-compose工具。选择合适的版本之后,执行在github网站上找到的命令。

[root@docker ~]# curl -L https://github.com/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
[root@docker ~]# chmod +x /usr/local/bin/docker-compose

如果网速不佳可以使用以下命令:

[root@docker ~]# curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
[root@docker ~]# chmod +x /usr/local/bin/docker-compose
//使用道云的加速器进行下载
[root@docker ~]# docker-compose -v
//查看工具的版本信息
docker-compose version 1.25.0, build 0a186604

三、编写.yml文件

(1)构建简单的Nginx服务.yml文件

[root@docker ~]# vim /root/.vimrc
set tabstop=2
[root@docker ~]# source /root/.vimrc
//由于tab键使用的较多,所以事先设置了一个tab键代表的空格数
[root@docker ~]# mkdir compose_test
[root@docker ~]# cd compose_test/
//创建一个测试目录,用于存放docker-compose.yml文件
//建议一个目录下只有一个docker-compose.yml文件
[root@docker compose_test]# vim docker-compose.yml
//编写一个docker-compose.yml文件
version: "3"
//指定语法的版本
services:
//定义服务
nginx:
container_name: web_nginx
//运行的容器名
image: nginx
//使用的镜像
restart: always
//随docker服务的启动而启动
ports:
- 90:80
//映射的端口
volumes:
- /root/compose_test/webserver:/usr/share/nginx/html
//本地与容器挂载的目录
//编写文件注意缩进
[root@docker compose_test]# docker-compose up -d
//使用当前目录下的docker-compose.yml文件生成相应的容器
//“-d”选项,表示后台运行,如果不指定,默认则在前台运行,会占用终端
[root@docker compose_test]# docker ps
//查看运行的容器
CONTAINER ID
IMAGE
COMMAND
CREATED
STATUS
PORTS
NAMES
c674041cc65b
nginx
"nginx -g 'daemon of…"
8 minutes ago
Up 8 minutes
0.0.0.0:90->80/tcp
web_nginx
[root@docker compose_test]# echo "hello world" > webserver/index.html
//创建测试网页
[root@docker compose_test]# curl 127.0.0.1:90
hello world
//访问测试
[root@docker compose_test]# docker-compose stop
//通过.yml文件停止文件中指定的容器
[root@docker compose_test]# docker ps
CONTAINER ID
IMAGE
COMMAND
CREATED
STATUS
PORTS
NAMES
//查看效果
[root@docker ~]# docker-compose -f /root/compose_test/docker-compose.yml up -d
//可以使用“-f”选项来指定yml文件启动文件中定义的容器

(2)compose+dockerfile构建镜像

[root@localhost ~]# mkdir compose && cd compose
//创建一个测试目录并进入
[root@localhost compose]# vim Dockerfile
//创建dockerfile
FROM nginx:latest
ADD html /usr/share/nginx/html
[root@localhost compose]# vim docker-compose.yml
//编写yml文件
version: "3"
services:
nginx:
build: .
//这里指定dockerfile的路径,可以写相对路径或绝对路径
container_name: mynginx
//生成的容器名称
image: mynginx
//使用dockerfile生成的镜像名称
restart: always
ports:
- 70:80
[root@localhost compose]# mkdir html
[root@localhost compose]# echo "hello world" > html/index.html
//创建网页目录
[root@localhost compose]# docker-compose build
//就是将dockerfile文件生成镜像
[root@localhost compose]# docker-compose up -d
//直接生成容器,上一条命令可以忽略
[root@localhost compose]# curl 127.0.0.1:70
hello world
//测试效果

(3)使用.yml文件搭建博客平台

[root@localhost ~]# mkdir wordpress && cd wordpress
//创建测试目录
[root@localhost wordpress]# vim docker-compose.yml
//编写yml文件
version: "3.1"
services:
wordprss:
image: wordpress
//指定使用的镜像
restart: always
ports:
- 8080:80
//指定映射的端口
environment:
//修改容器内部的环境变量
WORDPRESS_DB_HOST: db
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: 123.com
WORDPRESS_DB_NAME: wordpress
db:
image: mysql:5.7
restart: always
environment:
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: 123.com
MYSQL_ROOT_PASSWORD: 123.com
[root@localhost wordpress]# docker-compose up -d
//生成相应的容器,并在后台运行
[root@localhost wordpress]# netstat -anpt | grep 8080
//确定端口在监听
tcp6
0
0 :::8080
:::*
LISTEN
5546/docker-proxy
[root@localhost wordpress]# docker ps | grep word
//确定容器在运行
81dd5fe032a6
wordpress
"docker-entrypoint.s…"
7 minutes ago
Up 7 minutes
0.0.0.0:8080->80/tcp
wordpress_wordprss_1
702b530d7679
mysql:5.7
"docker-entrypoint.s…"
7 minutes ago
Up 7 minutes
3306/tcp, 33060/tcp
wordpress_db_1
[root@localhost wordpress]# echo "net.ipv4.ip_forward = 1" >> /etc/sysctl.conf
[root@localhost wordpress]# sysctl -p
net.ipv4.ip_forward = 1

现在就可以访问测试页面了。如图:
docker三剑客——docker-compose
docker三剑客——docker-compose
docker三剑客——docker-compose
docker三剑客——docker-compose
docker三剑客——docker-compose
访问自己搭建的博客成功!

三、Docker的监控

(1)docker自带的监控命令

[root@localhost ~]# docker top wordpress_wordprss_1
//查看容器的使用状态
UID
PID
PPID
C
STIME
TTY
TIME
CMD
root
5601
5569
0
20:53
?
00:00:00
apache2 -DFOREGROUND
33
6073
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6074
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6075
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6076
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6077
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6096
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6098
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6099
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6100
5601
0
20:54
?
00:00:00
apache2 -DFOREGROUND
33
6155
5601
0
20:57
?
00:00:00
apache2 -DFOREGROUND
[root@localhost ~]# docker stats wordpress_wordprss_1
[root@localhost ~]# docker logs wordpress_wordprss_1
//这三条都是容器本身自带的监控命令

(2)sysdig

[root@localhost ~]# docker run -it --rm --name sysdig --privileged=true --volume=/var/run/docker.sock:/host/var/run/docker.sock --volume=/dev:/host/dev --volume=/proc:/host/proc:ro --volume=/boot:/host/boot:ro --volume=/lib/modules:/host/lib/modules:ro --volume=/usr:/host/usr:ro sysdig/sysdig
//创建一个容器并自动进入容器中
//--rm:随着退出容器而被删除;
//--privileged=true:赋予特殊权限;
root@711dbeb59fdd:/# csysdig
//执行这条命令

如图:
docker三剑客——docker-compose
图中可以使用键盘和鼠标进行操作!

(3)scope

[root@localhost ~]#
curl -L git.io/scope -o /usr/local/bin/scope
[root@localhost ~]#
chmod +x /usr/local/bin/scope
//下载安装脚本
[root@localhost ~]#
scope launch
//以容器方式启动
……………………
Weave Scope is listening at the following URL(s):
* http://172.21.0.1:4040/
* http://192.168.122.1:4040/
* http://172.22.0.1:4040/
* http://172.20.0.1:4040/
* http://172.18.0.1:4040/
* http://172.19.0.1:4040/
* http://192.168.1.1:4040/
//根据末尾的提示信息进行访问

如图:
docker三剑客——docker-compose
根据图中的提示,自行可以点击进行测试!

如果要监控两台的话:主机名必须进行区分方法如下:

[root@dockerA ~]#
curl -L git.io/scope -o /usr/local/bin/scope
[root@dockerA ~]#
chmod +x /usr/local/bin/scope
[root@dockerA ~]# scope launch 192.168.1.1 192.168.1.2
//首选指定本地的IP,再指定对方的IP
[root@dockerA ~]# docker run -itd --name http httpd
//运行一个容器进行测试
[root@dockerB ~]#
curl -L git.io/scope -o /usr/local/bin/scope
[root@dockerB ~]#
chmod +x /usr/local/bin/scope
[root@dockerB ~]# scope launch 192.168.1.2 192.168.1.1
[root@dockerB ~]# docker run -itd --name nginx nginx

访问(dockerA、dockerB任意一台即可)测试:
docker三剑客——docker-compose

——————————本文到此结束,感谢观看——————————

最后

以上就是跳跃小松鼠为你收集整理的Docker三剑客——docker-compose的全部内容,希望文章能够帮你解决Docker三剑客——docker-compose所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(38)

评论列表共有 0 条评论

立即
投稿
返回
顶部