docker-compose(容器编排技术)

基本的概念

Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。

Docker-Compose运行目录下的所有文件(docker-compose.yml, extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像,参数,依赖。一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡。

Compose中有两个重要的概念:

服务(service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。

项目(project):由一组关联的应用容器组成的一个完整业务单元,在docker-compose.ymb文件中定义。

一个项目可以由多个服务(容器)关联而成,Compose面向项目进行管理,通过子命令对项目中的一组容器进行便捷地生命周期管理。

Docker-Compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像,参数,依赖。一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡。

Compose项目由Python编写,实现上调用了Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose来进行编排管理。

Docker-Compose分成三层

1.项目层springboot项目依赖于我们的mysql redis.nginx等一个项目是由多个容器组成的。

2.服务层运行一个镜像的实例

为什么需要使用Docker Compose

Docker Compose容器编排技术

1.现在我们有一个springboot项目,需要依赖Redis、mysql5.7、nginx。

如果使用docker原生部署的话,则需要安装Redis、mysql5、nginx容器,在才可以们springboot项目,这样的话部署项目的流程非常复杂,所以需要引入我们的Docker compose实现容器编排技术。

docker-compose插件安装

1、访问docker-compose githup官网 

2. docker-compose-Linux-x86_64上传到服务器中,然后执行如下命令将其移动到

/usr/local/bin/目录中并且更名为docker-compose

mv docker-compose-Linux-x86_64/usr/local/bin/docker-compose

3.执行如下命令:添加可执行的权限

sudo chmod +x/usr/local/bin/docker-compose

4、验证docker-compose

docker-compose-v

第一个docker-compse.yml文件

运行docker-compose up指令运行本文件夹下的docker-compose.yml文件 

docker-compose容器构建同一局域网

docker-compose部署微服务项目

 springboot连接数据库此时不知道mysql容器ip

 

 此时会调用接口查询插入数据失败。

容器中提前创建数据库并无创建表。需要导入表结构

不同的环境只需要导入docker-compose.yml  dockerFile  和相应环境的jar即可进行相关的部署

Docker可视化工具使用

Portainer

Portainer是一款Docker可视化管理工具,允许我们在网页中方便的查看和管理Docker容器。要使用Portainer很简单,运行下面两条命令即可。这些命令会创建一个Portainer专用的卷,然后在8000和9000端口创建容器并运行。

运行下面命令安装Portainer

docker run -d -p 9000:9000

--name=portainer

--restart=always

-v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data

portainer/portainer

使用docker部署软件常见问题

我们在使用docker安装软件时,docker run成功了,但是无法访问比如es、springboot项目等。

docker run -p 8081:8080-dtomcat:8

1.改成前台启动-d去掉打印日志信息

2、查看容器启动的日志信息docker logs

查看最近30分钟的日志:docker logs --since 30m CONTAINER_ID(容器id)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值