Docker Compose的概念在上一篇Docker的介绍中有讲解,现在说一下怎么使用
安装Docker Compose
从官网上下载,速度会比较慢
执行
sudo curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
授权
sudo chmod +x /usr/local/bin/docker-compose
验证
docker-compose -v
Compose入门案例
运行一个Tomcat
流程:
- 需要定义一个docker-compose.yml 文件----可以在idea里面创建
- 需要在docker-compose文件配置依赖服务
- docker-compose up 执行该文件
- 上传yml文件到linux之后直接执行 docker-compose up
容器名称
docker-compose构建同一个局域网
因为每一个容器都相当于一个独立的linux,那么我们要如何才做到将这些容器联通起来?
那就是配置局域网,将你想联通的容器都放在同一个局域网中就行了。
如何做?
使用networks,参考以下配置
进阶配置
这样就可以联通起来了
Compose常用命令
docker-compose ps
列出项目中所有的容器
docker-compose stop
停止docker-compose
docker-compose logs
查看容器中日志信息
docker-compose pull
拉取服务依赖的镜像
Compose常用配置
Image 镜像名称;
Build 根据docker file 打包 成镜像;
Context 指定docker file文件位置;
Commond 使用command可以覆盖容器启动后默认执行的命令;
Container_name 容器名称;
depends_on 指定依赖那个服务;
Ports 映射的端口号;
extra_hosts 会在/etc/hosts文件中添加一些记录;
Volumes 持久化目录;
volumes_from 从另外一个容器挂在数据卷;
Dns 设置dns
Compose部署springboot项目
dockerfile文件
#基础镜像使用java
FROM java:8
#作者
MAINTAINER tujr
# VOLUME 指定了临时文件目录为/tmp。
# 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
VOLUME /tmp
#将jar包添加到容器中并更名为tujr.jar
ADD tujr-thymeleaf-1.0-SNAPSHOT.jar tujr.jar
#运行jar包
RUN bash -c 'touch /tujr.jar'
ENTRYPOINT ["java","-Djava,security.egd=file:/dev/./urandom","-jar","/tujr.jar"]
#暴露8080端口
EXPOSE 8080
docker-compose.yml文件
spring boot 配置文件
直接执行 docker-compose up