Docker笔记:docker compose部署项目, 常用命令与负载均衡

docker compose的作用

  • docker-compose是docker官方的一个开源项目
  • 可以实现对docker容器集群的快速编排
  • docker-compose 通过一个配置文件来管理多个Docker容器
  • 在配置文件中,所有的容器通过 services来定义
  • 然后使用docker-compose脚本来启动,停止和重启容器
  • 使用docker-compose可以对我们项目进行快速部署

docker命令部署项目

  • 比如,项目中有:nginx, web, mysql 三项服务

1 )mysql 的部署

  • 拉取镜像 $ docker pull mysql
  • 创建mysql, 并将mysql数据库导入到容器里
    • $ docker run --name mysql_c -p 3306:3306 -v /root/mysql/conf.d:/etc/mysql/conf.d -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql
    • 在物理机 $ mkdir /root/mysql/conf.d /root/mysql/data 来创建两个目录
  • 客户端 尝试连接 物理机上的mysql容器,成功
  • 连接成功后,创建数据库或导入数据库,这里导入之前的数据库

2 )web的部署

  • 测试本地的web项目是否可以链接容器数据库,检查连接配置,正常
    • 这里如果mysql连接配置写的是ip最好改成 host对应的域名
  • 打包或不打包的不同部署方式,参考前文
  • 需要注意连接数据库的问题,这里简单举例: 这里用centos镜像来运行的,不是golang或已经打包好的镜像
  • $ docker run -itd --name goweb1 --link mysql_c:mysql -p 8080:8080 -v /root/wwwroot/:/root centos
    • --link 之后,会在 /etc/host 生成mysql对应的别名配置,就可以连接到mysql了
  • $ docker exec -it goweb1 /bin/bash 这里goweb1是容器,可以用自己的
  • $ chmode -R goweb1 这里找到对应的目录修改执行权限, 这里goweb1是目录
  • $ nohup ./goweb & 这里 goweb是可执行程序
  • 客户端访问测试正常

3 )nginx的部署

  • 如果想要不通过ip访问,通过域名访问,就要配置ng的转发
  • 转发配置, 默认配置文件 default.conf,新建任意 xxx.conf 存放在物理机上 /root/nginx/conf.d

goweb.conf

upstream backend {ip_hash;server goweb1:8080; # 这里是 goweb1 容器服务的host别名
}server {listen       80;server_name  goweb.xxxx.com; # 你的域名地址location / {# 设置主机头和客户端真实地址,以便服务器获取客户端真实IP         # 禁用缓存proxy_buffering off; # 反向代理的地址proxy_pass http://backend;     }# error_page  404              /404.html;# redirect server error pages to the static page /50x.html#error_page   500 502 503 504  /50x.html;location = /50x.html {root  html;}
}
  • 启动nginx映射端口,配置映射目录,连接web服务

    • $ docker run -itd --name nginxweb -p 80:80 --link goweb1:centos -v /root/nginx/conf.d/:/etc/nginx/conf.d nginx
  • 检查 host配置

    • $ cat /etc/hosts
    • 如果是客户端访问 goweb.xxxx.com 域名,客户端需要配置相关的host, 才能访问
    • 确认配置文件无误
  • ping 域名 成功

  • 以上是纯docker命令部署,也可通过 Dockerfile来配置部署goweb应用程序

  • 不管是原生docker命令部署,还是 Dockerfile部署,其实都比较麻烦

docker compose 部署项目

1 )安装 docker compose

  • 如果你是安装的桌面版 Docker,不需要额外安装,已经包含了
  • 如果是没图形界面的服务器版 Docker,你需要单独安装
    • 如果是 centos8 默认源是有问题的,我们可以配置到阿里源
      • 参考:http://bbs.itying.com/topic/6256730b212f3a0c78d4ac16
        • $ rm -rf /etc/yum.repos.d/*
        • $ touch /etc/yum.repos.d/CentOS-Base.repo
          • 复制链接提供的内容
        • $ yum clean all
        • $ yum makecache
        • 在安装 docker compose 前还要配置 docker的源,这里是时候的 阿里源
          • $ yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    • $ sudo yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin
      • 如果在安装的时候,后面有 docker-compose-plugin 参数,也会被安装
    • $ yum install docker-compose-plugin
      • 这是单独安装
  • 运行 docker compose 检查是否安装成功

2 )配置 docker-compose.yml

version: "3"services: # 定义容器服务mysql_c: # 当前容器配置image: mysqlcontainer_name: mysql_c # 可以不写,和配置名保持一致environment: MYSQL_ROOT_PASSWORD: 123456restart: alwaysports:- 3306:3306volumes:- /root/mysql/conf.d:/etc/mysql/conf.d- /root/mysql/data:/var/lib/mysqlgoweb1:image: gowebimg # 这个golangweb的镜像需要提前准备好build:context: ./dockerfile: Dockerfile# container_name: goweb1restart: alwaysports:- 8080:8080depends_on: # 表示 mysql_c 容器创建完成后,再去创建 goweb1 容器- mysql_cnginx:image: nginxcontainer_name: nginxrestart: alwaysports:- 80:80depends_on:- goweb1volumes:- /root/nginx/conf.d/:/etc/nginx/conf.d
  • 验证配置文件: $ docker compose convert
    • 如果有错,不会启动,输出错误,如: yaml: line3: did not find expected key
  • 编译运行容器: $ docker compose up
  • 后台运行: $ docker compose up -d
  • $ docker ps / docker compose ps
    • 这样,一次就起来了3个容器服务
  • 之后,验证服务是否正常
    • 如果不正常,进行检查,如 检查web服务
    • $ docker compose exec 服务名 /bin/bash
      • 例如: $ docker compose exec goweb1 /bin/bash
    • 查看里面的配置文件
      • 注意一般而言,我们这样查看都是基于未打包的
      • 因为打包后的可执行文件,不是docker打包可能结果和配置不匹配
    • 上述配置,有可能会遇到一些问题,比如 mysql容器先启动起来,goweb应用接着启动起来,但是mysql可能还没启动起来
      • 可重启应用解决 $ docker compose restart goweb1
      • 可使用脚本解决
  • 重启某个服务
    • $ docker compose restart goweb1
  • docker compose 极大方便了我们结合不同的容器
    • 通过一个配置文件,一个命令即可部署

3 )解决启动顺序问题导致的数据库访问不通

  • 使用 wait-for-it.sh 脚本
  • https://github.com/vishnubob/wait-for-it
  • 改写 compose 文件

    goweb1:image: gowebimg # 这个golangweb的镜像需要提前准备好build:context: ./dockerfile: Dockerfile# container_name: goweb1restart: alwaysports:- 8080:8080depends_on: # 表示 mysql_c 容器创建完成后,再去创建 goweb1 容器- mysql_ccommand: ["./wait-for-it.sh", "mysql_c:3306", '--', './goweb'] # goweb是编译后的可执行文件
    

docker compose 常见命令

  • $ docker compose build 可编译/重新编译服务
    • 如果有 Dockerfile会编译我们的镜像
    • –force-rm:总是删除构建过程中的临时容器。
    • –no-cache:镜像构建过程中不使用 cache。
    • –pull:始终先尝试通过 pull 来获取最新版本的镜像
  • $ docker compose logs 可查看操作日志
  • $ docker compose ps 可查看当前主机容器信息,类似 docker ps
  • $ docker compose start 启动容器
  • $ docker compose restart 重启容器
  • $ docker compose stop 停止容器 后面不加容器,则全部停止
  • $ docker compose rm 删除容器 不加容器,删除停止状态的容器
    • -f 强制删除
  • $ docker compose exec 进入容器
  • $ docker compose version 查看版本

docker compose 实现容器扩容

1 )方案1:基于命令

  • $ docker compose up --scale='goweb1=3' -d
    • goweb1 是服务名, 3 是部署扩展3台用于负载均衡
    • 注意,如果web服务启动多态,配置相同的端口会有问题,这时只需要注释掉 上面的 ports 配置
        # ports:#     - 8080:8080
      
  • $ docker compose ps 可看见3台 goweb1 服务
  • 结束掉一台,会自动重新负载均衡
    • 可以进入 nginx 服务 ping goweb1 服务,ip地址会动态变化

2 )方案2: 基于docker-compose.yml文件

goweb1:build:context: ./dockerfile: Dockerfilerestart: alwaysdeploy:replicas: 3 #副本数量resources: #资源limits: #配置cpucpus: "0.5" # 设置该容器最多只能使用 50% 的 CPUmemory: 500M # 设置该容器最多只能使用 500M内存restart_policy: #定义容器重启策略, 用于代替 restart 参数condition: on-failure #只有当容器内部应用程序出现问题才会重启depends_on:- mysql_ccommand: ["./wait-for-it.sh","mysql_c:3306","--","./goweb"]
  • 注意,启动多个副本不能指定 container_name

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/219706.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle 查看统计信息

统计信息在oracle中是非常重要的模块,就好似打仗时的侦察兵,提前了解敌情,来帮助CBO更好地生成执行计划。下面是一些常用地查看统计信息的语句,希望能帮助到大家。 表统计信息查看 select t.owner, t.table_name, t.num_rows, t…

考研真题c语言

【2016年山西大学考研真题】输入10个学生三门课的成绩,用函数实现:找出最高的分数所对应的学号和成绩。 1. 定义一个结构体 Student 来表示每个学生,包括学号和三门课的成绩。 c typedef struct { int studentID; int score1; i…

链路追踪详解(四):分布式链路追踪的事实标准 OpenTelemetry 概述

目录 OpenTelemetry 是什么? OpenTelemetry 的起源和目标 OpenTelemetry 主要特点和功能 OpenTelemetry 的核心组件 OpenTelemetry 的工作原理 OpenTelemetry 的特点 OpenTelemetry 的应用场景 小结 OpenTelemetry 是什么? OpenTelemetry 是一个…

DevEco Studio 鸿蒙(HarmonyOS)项目结构

DevEco Studio 鸿蒙(HarmonyOS)项目结构 一、操作环境 操作系统: Windows 10 专业版 IDE:DevEco Studio 3.1 SDK:HarmonyOS 3.1 二、项目结构 创建简单的Hello World移动应用项目结构如下图 由上到下说明各个文件夹的作用 .hvigor:存…

阅读笔记——《UTOPIA: Automatic Generation of Fuzz Driverusing Unit Tests》

【参考文献】Jeong B, Jang J, Yi H, et al. UTOPIA: automatic generation of fuzz driver using unit tests[C]//2023 IEEE Symposium on Security and Privacy (SP). IEEE, 2023: 2676-2692.【注】本文仅为作者个人学习笔记,如有冒犯,请联系作者删除。…

智慧储能数字孪生:能源未来的智慧引擎

随着社会对清洁能源的需求不断增加,智能储能技术成为能源转型的关键驱动力。在这一领域中,数字孪生技术的应用为智慧储能带来了全新的可能性。数字孪生是指数字化、实时、可视化的模拟系统,通过复制现实世界中的对象或过程,为智能…

SpeechGPT领航:创新的130亿参数跨模态AI模型

引言 在人工智能的最新进展中,SpeechGPT以其130亿参数的规模和跨模态会话能力引起了业界的广泛关注。这一由复旦大学邱锡鹏教授团队开发的模型,不仅在技术层面上取得了重大突破,也为多模态人工智能(AI)的未来发展指明…

力扣120. 三角形最小路径和

动态规划 思路: 假设 dp[i][j] 为最小路径到第 i 层的第 j 个元素的值;则 dp[i][j] min(dp[i - 1][j - 1], dp[i - 1][j]) tr[i][j];当 j 0 时,dp[i][j] dp[i - 1][0] tr[i][0];(可以认为 j - 1 不能…

目标检测YOLO实战应用案例100讲-基于深度学习的跌倒检测(续)

目录 3.3 基于YOLOv7算法的损失函数优化 3.3.1 IoU损失策略 3.3.2 GIoU回归策略 3.3.3

Selenium库自动化测试入门

前言 为什么要学selenium??前面已经学了requests库我们会发现 对于绝大多数动态渲染的网页来说,用requests进行爬虫比较繁琐。 所以我们还是要学习一下selenium库,以帮助我们更高效的爬取网页。 环境: pychar 202…

Linux--绝对路径和相对路径

1. 绝对路径 从根目录算起的路径叫做绝对路径 例如: /home/python/Desktop/usr/bin 2. 相对路径 从当前目录算起的路径叫做相对路径 例如: ./test/hello../static/images 3. 绝对路径和相对路径的使用 使用绝对路径切换到桌面 cd /home/python/Desktop 在下载目录以相…

机器学习算法新手入门指南

AI算法的种类在人工智能领域中非常丰富,而且多样化,AI算法利用数学、统计学和计算机科学等领域的原理和方法,通过模拟人类智能和学习能力来解决各种复杂的问题。 在监督学习领域,我们有经典的线性回归和逻辑回归算法,…

光栅化渲染:可见性问题和深度缓冲区算法

在前面第二章中,我们了解到,在投影点(屏幕空间中的点)的第三个坐标中,我们存储原始顶点 z 坐标(相机空间中点的 z 坐标): 当一个像素与多个三角形重叠时,查找三角形表面上…

Java 多线程之线程安全集合

文章目录 一、概述二、List 接口线程安全实现类2.1 普通 List 变线程安全 List2.2 Vector2.3 CopyOnWriteArrayList 三、Map 接口线程安全实现类3.1 普通 Map 变线程安全 Map3.2 Hashtable3.3 ConcurrentHashMap3.4 ConcurrentSkipListMap 有序/跳表 四、Set 接口线程安全实现类…

J2EE(架构师考试复习资料)

J2EE 是针对 Web Service、业务对象、数据访问和消息报传送的一组规范。这组应用编程接口确定了 Web 应用与驻留它们的服务器之间的通信方式。J2EE 注重两件事,一是建立标准,使 Web 应用的部署与服务器无关;二是使服务器能控制构件的生命周期…

前端传的true后端变false?

前端传来true,后端变成false? 背景:原因分析:解决: 背景: 最近在搞项目的时候遇到了神奇的东西,后端定了了boolean类型的变量,前端在传值的时候传的是true,但是到了后端…

自定义Mybatis LanguageDriver性能优化

场景:高并发情况下mybatis 动态sql 解析 锁问题优化 优化前 并发测试 XMLLanguageDriver 类 的 createSqlSource 方法有锁 而且 每次执行时都会走该方法 优化前 : 线程有Block 优化后的 LanguageDriver public class CustomXMLLanguageDriver im…

uniapp 使用wgt包实现热更新具体实现代码

uniapp 使用wgt包实现热更新具体实现代码 参考文档:https://ask.dcloud.net.cn/article/35667 app.vue 在onLaunch生命周期里面调用 import { GetRefres } from /utils/hot-refresh; onLaunch(() > {// #ifdef APP-PLUSGetRefres();// #endif });utils/hot-r…

CENTOS 安装zookeeper

1,下载 release地址:Apache ZooKeeper 地址:https://dlcdn.apache.org/zookeeper/zookeeper-3.8.3/apache-zookeeper-3.8.3-bin.tar.gz 2,安装 # 解压并进入解压目录 tar zxvf apache-zookeeper-3.8.3-bin.tar.gz -C /usr/local…

Vue3 实现图片的帧动画方案分享

一、纯 JS &#xff08;有性能问题会卡顿&#xff09; <div class"robot-box"><img ref"robotImgRef" src"/Greet/Greet_00000.png" alt"" /></div>const delay 30; const imgCount 109; let i 0; const robotIm…