docker-compose 集群_dockercompose作用

docker-compose 集群_dockercompose作用前言实际工作中我们部署一个应用,一般不仅仅只有一个容器,可能会涉及到多个,比如用到数据库,中间件MQ,web前端和后端服务,等多个容器。我们如果一个个去启动应用,当项目非常多时,就很难记住了,所有

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

前言

实际工作中我们部署一个应用,一般不仅仅只有一个容器,可能会涉及到多个,比如用到数据库,中间件MQ,web前端和后端服务,等多个容器。
我们如果一个个去启动应用,当项目非常多时,就很难记住了,所有需要一个配置文件,负责实现对Docker容器集群的快速编排。
 

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参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。

安装

pip3 install docker-compose

安装成功后,输入docker-compose version查看版本
如果出现-bash: docker-compose: command not found,可以按照以下步骤执行
 

解决docker-compose 命令不存在、未找到命令错误

 

1.安装扩展源

sudo yum -y install epel-release

 

2.安装python-pip模块

sudo yum install python-pip

 

3.通过以下命令进行安装

wget https://github.com/docker/compose/releases/download/1.14.0-rc2/docker-compose-Linux-x86_64
rename docker-compose-Linux-x86_64 docker-compose docker-compose-Linux-x86_64
chmod +x /usr/local/bin/docker-compose

 

4. docker-compose version命令进行查看

[root@jkc ~]# docker-compose version
docker-compose version 1.14.0-rc2, build 24dae73
docker-py version: 2.3.0
CPython version: 2.7.13
OpenSSL version: OpenSSL 1.0.1t  3 May 2016

 

案例演示

docker-compose已经安装成功,接下来去https://hub.docker.com上找个项目部署练练手,项目地址:https://hub.docker.com/r/easymock/easymock
docker-compose 集群_dockercompose作用
 

docker-compose 文件内容

version: '3'

services:
  mongodb:
    image: mongo:3.4.1
    volumes:
      # ./data/db 数据库文件存放地址,根据需要修改为本地地址
      - './data/db:/data/db'
    networks:
      - easy-mock
    restart: always

  redis:
    image: redis:4.0.6
    command: redis-server --appendonly yes
    volumes:
      # ./data/redis redis 数据文件存放地址,根据需要修改为本地地址
      - './data/redis:/data'
    networks:
      - easy-mock
    restart: always

  web:
    image: easymock/easymock:1.6.0
    command: /bin/bash -c "npm start"
    ports:
      - 7300:7300
    volumes:
      # 日志地址,根据需要修改为本地地址
      - './logs:/home/easy-mock/easy-mock/logs'
      # 配置地址,请使用本地配置地址替换
      # - './production.json:/home/easy-mock/easy-mock/config/production.json'
    networks:
      - easy-mock
    restart: always

networks:
  easy-mock:

在本地新建一个文件夹/root/easymock,接着新建文件docker-compose.yml,把上面的内容写入到这个文件里,如下步骤

[root@jkc ~]# mkdir /root/easymock
[root@jkc ~]# cd /root/easymock/
[root@jkc easymock]# touch docker-compose.yml
[root@jkc easymock]# vi docker-compose.yml 
[root@jkc easymock]# cat docker-compose.yml 
version: '3'

services:
  mongodb:
    image: mongo:3.4.1
    volumes:
      # ./data/db 数据库文件存放地址,根据需要修改为本地地址
      - './data/db:/data/db'
    networks:
      - easy-mock
    restart: always

  redis:
    image: redis:4.0.6
    command: redis-server --appendonly yes
    volumes:
      # ./data/redis redis 数据文件存放地址,根据需要修改为本地地址
      - './data/redis:/data'
    networks:
      - easy-mock
    restart: always

  web:
    image: easymock/easymock:1.6.0
    command: /bin/bash -c "npm start"
    ports:
      - 7300:7300
    volumes:
      # 日志地址,根据需要修改为本地地址
      - './logs:/home/easy-mock/easy-mock/logs'
      # 配置地址,请使用本地配置地址替换
      # - './production.json:/home/easy-mock/easy-mock/config/production.json'
    networks:
      - easy-mock
    restart: always

networks:
  easy-mock:
[root@jkc easymock]# 

 

docker-compose up启动

使用docker-compose up 指令启动服务,可以看到依次启动三个容器

  • Creating easymock_redis_1 … done
  • Creating easymock_mongodb_1 … done
  • Creating easymock_web_1 … done
    如果看到以下报错,permission denied, open ‘logs/2019-08-18-info.log’,给log文件夹加个权限即可
chmod 777 /root/easymock/logs/

接着浏览器输入http://ip:7300/即可访问了
docker-compose 集群_dockercompose作用
 

docker-compose挂后台运行

挂后台运行需加-d参数

docker-compose up -d

查看正在启动的docker容器使用docker ps

[root@jkc easymock]# docker-compose up -d
Creating network "easymock_easy-mock" with the default driver
Creating easymock_mongodb_1 ... 
Creating easymock_web_1 ... 
Creating easymock_redis_1 ... 
Creating easymock_redis_1
Creating easymock_web_1
Creating easymock_web_1 ... done
[root@jkc easymock]# docker ps
CONTAINER ID        IMAGE                     COMMAND                  CREATED             STATUS              PORTS                    NAMES
f88971162a08        redis:4.0.6               "docker-entrypoint.s…"   30 minutes ago      Up 30 minutes       6379/tcp                 easymock_redis_1
73cba1bc4a1a        easymock/easymock:1.6.0   "/bin/bash -c 'npm s…"   30 minutes ago      Up 12 minutes       0.0.0.0:7300->7300/tcp   easymock_web_1
7d317fdf9247        mongo:3.4.1               "/entrypoint.sh mong…"   30 minutes ago      Up 30 minutes       27017/tcp                easymock_mongodb_1
[root@jkc easymock]# 

 

docker-compose停止运行

停掉服务使用docker-compose down

[root@jkc easymock]# docker-compose down
Stopping easymock_redis_1 ... done
Stopping easymock_web_1 ... done
Stopping easymock_mongodb_1 ... done
Removing easymock_redis_1 ... done
Removing easymock_web_1 ... done
Removing easymock_mongodb_1 ... done
Removing network easymock_easy-mock
[root@jkc easymock]# 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/165888.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月30日 下午8:46
下一篇 2022年7月30日 下午8:46


相关推荐

  • docker的端口映射_外网远程桌面端口映射

    docker的端口映射_外网远程桌面端口映射Docker端口映射实现网络访问首先,大家如果看到有什么不懂的地方,欢迎吐槽!!!我会在当天或者第二天及时回复,并且改进~~Docker运行容器之后却发现没IP,没端口,那要如何访问容器呢?下面我来介绍下Docker通过端口映射来实现网络访问一、从外部访问容器应用在启动容器的时候,如果不指定对应参数,在容器外部是无法通过网络来访问容器内的网络应用和服务的。当容器中运行一些网络应用,要让外部访问这些应用时,可以通过-P或-p参数指定端口映射。先来说说p和P吧-p可以指定要映射的端口,并

    2022年10月9日
    6
  • docker复制文件到宿主机_下面哪几个属于docker网络模式

    docker复制文件到宿主机_下面哪几个属于docker网络模式自从Docker容器出现以来,容器的网络通信就一直是被关注的焦点,也是生产环境的迫切需求。容器的网络通信又可以分为两大方面:单主机容器上的相互通信,和跨主机的容器相互通信。 一、端口映射(局域网,外网此方式均可)。此种方式是将容器的某个端口映射到宿主机的某个端口,其它主机访问容器提供的服务需要通过宿主机的IP进行访问:dockerrun-p9000:8000–namec…

    2022年8月21日
    11
  • Docker部署OpenLDAP

    Docker部署OpenLDAPLDAP 说明什么是 LDAP 轻型目录访问协议 LightweightD LDAP 是一个开放的 中立的 业标准的应用协议 通过 IP 协议提供访问控制和维护分布式信息的目录信息 它是由目录数据库和一套访问协议组成的系统 详情请查看维基百科 LDAP 为什么用 LDAP LDAP 是开放的 Internet 标准 市场上或者开源社区的绝大多数软件都支持 LDAP 协议 简单来说 LDAP 协议最大的好处就是能统一管理用户密码 新人报道创建一个用户就能登录公司的所有平台

    2026年3月18日
    2
  • 卸载Docker CE

    卸载Docker CEnbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp 卸载 DockerCE 前言针对上一篇博客中的 DockerCE 的安装 有可能在实际的生产环境中使用 Docker 不是最新的 Latest 而需要特定 TAG 这儿就需要以前的 DockerCE 所有的安装包卸载干净 才能再次进行安装 nbsp 卸载 Do

    2026年3月26日
    2
  • docker端口映射成功 不可用_docker启动后访问拒绝连接

    docker端口映射成功 不可用_docker启动后访问拒绝连接情境描述创建一个docker容器,并进行端口映射。容器启动后,在部署容器的主机上可以访问映射端口,但是其他主机无法访问。问题排查出现上述情况,应是请求被拦截。出现该问题的可能是由于firewall配置异常、ip转发关闭、iptables服务拦截了请求排查firewall(1)使用firewall-cmd–state查看防火墙运行情况如果防火墙处于notrunning,则可以排除…

    2022年10月17日
    5
  • 从零开始的Docker Desktop使用,Docker快速上手 ( ̄︶ ̄) Docker介绍和基础使用

    从零开始的Docker Desktop使用,Docker快速上手 ( ̄︶ ̄) Docker介绍和基础使用Docker 简介和安装本博客主要解决在 Windows 环境下 快速上手使用 Docker 的问题 主要会介绍在 Windows 系统下 DockerDeskto 的安装 Docker 基础命令 比如说下载镜像 启动镜像 使用镜像 关闭镜像 删除镜像 使用仓库 创建镜像等模块的使用 其他系统应该除了安装外其他操作都可以通用

    2026年3月26日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号