Docker Compose的入门与使用

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 

Docker Compose的入门与使用_第1张图片
授权

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

验证

docker-compose -v

在这里插入图片描述

Compose入门案例

运行一个Tomcat
流程:

  1. 需要定义一个docker-compose.yml 文件----可以在idea里面创建
  2. 需要在docker-compose文件配置依赖服务
  3. docker-compose up 执行该文件

Docker Compose的入门与使用_第2张图片

  • 上传yml文件到linux之后直接执行 docker-compose up
    Docker Compose的入门与使用_第3张图片
    在这里插入图片描述
    容器名称
    在这里插入图片描述

docker-compose构建同一个局域网

因为每一个容器都相当于一个独立的linux,那么我们要如何才做到将这些容器联通起来?
那就是配置局域网,将你想联通的容器都放在同一个局域网中就行了。
如何做?
使用networks,参考以下配置

进阶配置
Docker Compose的入门与使用_第4张图片
这样就可以联通起来了

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文件

Docker Compose的入门与使用_第5张图片

spring boot 配置文件

Docker Compose的入门与使用_第6张图片

直接执行 docker-compose up

你可能感兴趣的:(docker,docker,eureka,容器)