我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Docker Compose

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Docker Compose

为什么需要使用Docker Compose

Docker Compose 容器编排技术

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

如果使用docker原生部署的话,则需要安装Redis、mysql、nginx容器,才可以启动我们springboot项目,这样的话部署项目的流程非常复杂,所以需要引入我们的

Docker compose实现容器编排技术。

基本的概念

Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。

Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。

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

Docker-Compose的工程配置文件默认为docker-compose.yml,可通过环境变量COMPOSE_FILE或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。

Compose 中有两个重要的概念:

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

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

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

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

Docker-Compose 的配置文件

Docker-Compose 的工程配置文件默认为 docker-compose.yml,可通过环境变量COMPOSE_FILE 或 -f 参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器

Docker-Compose 配置常用字段

文档地址:https://docs.docker.com/compose/compose-file/compose-file-v3/

  • build 指定 Dockerfile 文件名,要指定Dockerfile文件需要在build标签的子级标签中使用dockerfile标签指定

  • dockerfile 构建镜像上下文路径

  • context 可以是 dockerfile 的路径,或者是指向 git 仓库的 url 地址

  • image 指定镜像

  • command 执行命令,覆盖默认命令

  • container name 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法 scale

  • deploy 指定部署和运行服务相关配置,只能在 Swarm 模式使用

  • environment 添加环境变量

  • networks 加入网络

  • ports 暴露容器端口,与 -p 相同,但端口不能低于 60

  • volumes 挂载宿主机路径或命令卷

  • hostname 容器主机名

  • restart 重启策略,默认 no,always,no-failure,unless-stoped

1.no,默认策略,在容器退出时不重启容器

2.on-failure,在容器非正常退出时(退出状态非0),才会重启容器

3.on-failure:3,在容器非正常退出时重启容器,最多重启3次

4.always,在容器退出时总是重启容器

5.unless-stopped,在容器退出时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了的容器

安装docker-compose

从GitHub上下载

官网文档:https://docs.docker.com/compose/install/https://github.com/docker/compose/releases下载版本:docker-compose-linux-x86_64放到目录:/usr/local/bin/ 修改文件名:docker-compose

这里已经上传到CSDN一份了

https://download.csdn.net/download/zhou9898/87490141

添加可执行权限

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

docker-compose常用命令

docker-compose -h                           # 查看帮助 docker-compose up                           # 创建并运行所有容器docker-compose up -d                        # 创建并后台运行所有容器docker-compose -f docker-compose.yml up -d  # 指定模板docker-compose down                         # 停止并删除容器、网络、卷、镜像。 docker-compose logs       # 查看容器输出日志docker-compose pull       # 拉取依赖镜像dokcer-compose config     # 检查配置dokcer-compose config -q  # 检查配置,有问题才有输出 docker-compose restart   # 重启服务docker-compose start     # 启动服务docker-compose stop      # 停止服务 docker-compose ps  列出项目中所有的容器docker-compose logs  查看容器中日志信息

1. 需要定义一个docker-compose.yml文件----工程

2. 需要在docker-compose文件配置依赖服务

3. docker-compose up 执行该文件

1. 创建一个docker-compose.yml;

2. 定制docker-compose 内容;

3. 运行 docker-compose up ;

docker-compose 部署项目

创建docker-compose.yml

version: '3.3'services:  mp:    build: .    image: mp # Dockerfile构建的镜像    ports:      - "8080:8080"

启动

docker-compose up -d # 创建并后台运行所有容器

docker-compose配合Dockerfile使用

Dockerfile文件

FROM openjdk:11MAINTAINER zqd   # 作者ADD boot02-1.0-SNAPSHOT.jar /boot02.jarENTRYPOINT ["nohup","java","-jar","/boot02.jar","&"]EXPOSE 8080
version: '3.3'services:  boot02:    build:         context: /home/        dockerfile: Dockerfile    container_name: boot02    ports:      - "8080:8080"

docker-compose 安装redis

一、 docker 拉去最新版本的redis

docker pull redis:6.0.6 #后面可以带上tag号, 默认拉取最新版本

二、 docker安装redis

执行命令:

mkdir -p /data/redis/confcd /data/redis/conf

新增配置文件

vim /data/redis/conf/redis.conf

内容只有如下这些:

#开启保护protected-mode yes#开启远程连接 #bind 127.0.0.1 #自定义密码requirepass 12345678 port 6379timeout 0# 900s内至少一次写操作则执行bgsave进行RDB持久化save 900 1 save 300 10save 60 10000rdbcompression yesdbfilename dump.rdbdir /dataappendonly yesappendfsync everysec

保存退出

参数说明

1.修改保护模式protected-mode yes 默认为yes 可以跳过这一步

Redis protected-mode属性解读

设置外部网络连接redis服务,设置说明如下:

a.关闭protected-mode模式,此时外部网络可以直接访问

b.开启protected-mode保护模式,需配置bind ip 和设置访问密码 redis3.2版本后新增protected-mode配置,默认是yes,即开启。

2.把bind 127.0.0.1 注释掉 #bind 127.0.0.1, 这样所有的ip都可以访问了

3.设置密码(根据自己的需要)

4.appendonly yes #开启AOF模式

三、编写 docker-compose.yaml文件

cd /data/redisvim docker-compose.yml

写入下面的内容

version: '3.8'services:  myredis:    container_name: myredis    image: redis:6.0.6    restart: always    ports:      - 6379:6379    privileged: true    command: redis-server /etc/redis/redis.conf --appendonly yes    volumes:      - /data/redis/data:/data      - /data/redis/conf/redis.conf:/etc/redis/redis.conf    networks:      - mywebnetworks:  myweb:    driver: bridge

说明:

/etc/redis/redis.conf为容器里的目录

启动前的目录结构

yum -y install tree
[root@localhost redis]# pwd/usr/local/docker/redis[root@localhost redis]# tree.├── conf│   └── redis.conf├── data│   └── appendonly.aof└── docker-compose.yml2 directories, 3 files

四、启动容器

docker-compose up -d

到这里就ok了,

启动后的目录结构

[root@localhost redis]# tree.├── conf│   └── redis.conf├── data│   └── appendonly.aof└── docker-compose.yml2 directories, 3 files

docker-compose 安装mysql

mkdir -p /data/mysqlcd /data/mysql

新建一个文件

vim docker-compose.yml
version: '3'services:  mysql:    image: mysql    restart: always    container_name: mysql    environment:      MYSQL_ROOT_PASSWORD: 123456    command:      --default-authentication-plugin=mysql_native_password      --character-set-server=utf8mb4      --collation-server=utf8mb4_general_ci      --explicit_defaults_for_timestamp=true      --lower_case_table_names=1      --max_allowed_packet=128M;    ports:      - 3306:3306    volumes:      - /data/mysql/data:/var/lib/mysql      - /etc/localtime:/etc/localtime:ro

默认数据库是账号是root

密码自己修改 MYSQL_ROOT_PASSWORD

保存

启动运行

docker-compose up -d

docker-compose 安装nginx

创建目录

根据自己的需要存放位置

mkdir -p /data/nginxmkdir -p /data/nginx/conf.dmkdir -p /data/nginx/logmkdir -p /data/nginx/conf

docker-compose.yml

vim /data/nginx/docker-compose.yml

version: '3'services:  nginx:    restart: always    image: nginx    ports:      - 80:80      - 443:443    volumes:      - /data/nginx/conf.d:/etc/nginx/conf.d      - /data/nginx/log:/var/log/nginx      - /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf      - /data/nginx/html:/usr/share/nginx/html      - /etc/letsencrypt:/etc/letsencrypt

为应用存放位置(该目录下要有 index.html)

mkdir -p /data/nginx/htmlvim /data/nginx/html/index.html

nginx相关配置

vim /data/nginx/conf.d/my.conf

server {     listen 80;   server_name localhost;    location / {        root   /usr/share/nginx/html;        index index.html index.htm;     }}

vim /data/nginx/conf/nginx.conf

user  root;worker_processes  1;error_log  /var/log/nginx/error.log warn;pid        /var/run/nginx.pid;events {    worker_connections  1024;}http {    include       /etc/nginx/mime.types;    default_type  application/octet-stream;    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '                      '$status $body_bytes_sent "$http_referer" '                      '"$http_user_agent" "$http_x_forwarded_for"';    access_log  /var/log/nginx/access.log  main;    sendfile        on;    #tcp_nopush     on;    keepalive_timeout  65;    #gzip  on;    include /etc/nginx/conf.d/*.conf;}

启动

cd /data/nginxdocker-compose up -d

访问

主页可能是centos欢迎页,需要替换,或者访问具体index.html

docker-compose批量部署

1、在docker-compose中构建Dockerfile

cd /data
build:     context: /home/df02 # 指定dockerfile目录    dockerfile: Dockerfile # 指定dockerfile文件名

vim docker-compose.yml

version: '3'services:  boot02:    build:         context: /home/df02        dockerfile: Dockerfile    container_name: boot02    ports:      - "8080:8080"  myredis:    container_name: myredis    image: redis:6.0.6    restart: always    ports:      - 6379:6379    privileged: true    command: redis-server /etc/redis/redis.conf --appendonly yes    volumes:      - /data/redis/data:/data      - /data/redis/conf/redis.conf:/etc/redis/redis.conf    networks:      - myweb  mysql:    image: mysql    restart: always    container_name: mysql    environment:      MYSQL_ROOT_PASSWORD: 123456    command:      --default-authentication-plugin=mysql_native_password      --character-set-server=utf8mb4      --collation-server=utf8mb4_general_ci      --explicit_defaults_for_timestamp=true      --lower_case_table_names=1      --max_allowed_packet=128M;    ports:      - 3306:3306    volumes:      - /data/mysql/data:/var/lib/mysql      - /etc/localtime:/etc/localtime:ro  nginx:    container_name: nginx    restart: always    image: nginx    ports:      - 80:80      - 443:443    volumes:      - /data/nginx/conf.d:/etc/nginx/conf.d      - /data/nginx/log:/var/log/nginx      - /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf      - /data/nginx/html:/usr/share/nginx/html      - /etc/letsencrypt:/etc/letsencryptnetworks:  myweb:    driver: bridge

来源地址:https://blog.csdn.net/zhou9898/article/details/129190341

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Docker Compose

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

2023-09-21

centos7安装docker-compose

Docker Compose是 docker 提供的一个命令行工具,用来定义和运行由多个容器组成的应用。使用 compose,我们可以通过 YAML 文件声明式的定义应用程序的各个服务,并由单个命令完成应用的创建和启动。确保本机已经安装了d
2023-01-31

MySql 8 with docker-compose

// Docker-compose.yml of MySql 8 version: "3" services:         mysql:              image: mysql              restart: always    
MySql 8 with docker-compose
2020-09-26

Docker系列:Docker-Compose用法详解

docker-compose是Docker官方提供的用于定义和管理运行多个Docker容器的开源容器编排工具。​
开源容器2024-12-01

Oracle 简介与 Docker Compose

Oracle 数据库是一款强大的关系型数据库管理系统,广泛用于企业级应用程序。通过使用 Docker Compose,您可以轻松地在容器化环境中部署和管理 Oracle 数据库。希望本文对您有所帮助,使您能够更好地了解 Oracle 数据库

Docker中的compose简介

Docker Compose 是 Docker 官方编排(Orchestration)项目之一,负责快速在集群中部署分布式应用,这篇文章主要介绍了Docker之compose介绍,需要的朋友可以参考下
2023-02-14

docker compose怎么使用

这篇文章主要介绍“docker compose怎么使用”,在日常操作中,相信很多人在docker compose怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”docker compose怎么使用”的疑
2023-06-30

使用docker、docker-compose部署微服务

使用docker、docker-compose部署微服务 一、使用docker部署1、准备2、上传jar包3、编写dockerfile文件3、构建镜像和容器 二、使用docker-compose部署1、准备服务的jar包和doc
2023-08-30

Docker Compose与Docker镜像仓库详解

Docker Compose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器,这篇文章主要介绍了Docker Compose与Docker镜像仓库,需要的朋友可以参考下
2023-03-21

docker-compose怎么部署Yapi

本篇内容主要讲解“docker-compose怎么部署Yapi”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“docker-compose怎么部署Yapi”吧!1 安装dockersudo yum
2023-06-29

Docker-compose怎么部署gitlab

这篇文章主要介绍“Docker-compose怎么部署gitlab”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Docker-compose怎么部署gitlab”文章能帮助大家解决问题。docker
2023-06-26

Docker compose部署minio服务

这篇文章主要介绍了Docker compose部署minio服务,minio的作用就是用来存储文件的,比如图片、视频、音频等各种类型的文件,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
2022-11-13

聊聊 Docker-Compose 进阶篇

configs 和 secrets 是 Docker Compose 和 Docker Swarm 中用于管理容器配置和敏感数据的两个不同的功能。

Docker Compose编排Springboot应用

我们还在myapp服务中设置了环境变量,以便应用程序能够连接到MySQL数据库。在这种情况下,我们将数据库URL设置为“jdbc:mysql://db:3306/mydb”,这意味着应用程序将连接到名为“db”的服务上的MySQL服务器,并

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录