DockerCompose部署示例
目录
前言
1. 初识DockerCompose
2. 安装DockerCompose
3. 部署微服务项目
1)找一个目录,创建一个新的cloud-demo文件夹。
2)在cloud-demo文件夹创建一个docker-compose.yml文件,然后编写下面内容:
3)在cloud-demo下创建以mysql、user-service、gate-way、order-service命名的文件夹,用于存放部署时要用到的东西:
4) 因为要给mysql挂载一个配置文件和一个本地数据,所以在mysql文件夹里创建conf和data目录:
5)在mysql的conf文件夹里,创建hmy.cnf文件
6)将本地的mysql的data数据复制到cloud-demo/mysql/data下面:
7)将之前没编写完的docker-compose文件,把mysql的数据卷的挂载信息写上:
8) 在gateway目录下新建Dockerfile文件,内容如下:
9)使用maven打包工具,将项目中的每个微服务都打包为app.jar,我的就是gateway、order-service和user-service:
10)将docker-compose.yml文件补全:
11)将整个cloud-demo上传到虚拟机的任意目录下面,我这里的是上传到/tmp目录下面:
4. 如果mysql密码不一致如何解决
前言
Docker Compose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器。
1. 初识DockerCompose
Compose文件是一个YAML文本文件,通过指令定义集群中的每个容器如何运行。示例如下:
version: "3.8"services:mysql:image: mysql:5.7.25environment:MYSQL_ROOT_PASSWORD: 123456volumes:- "/tmp/mysql/data:/var/lib/mysql"- "/tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf"web:build: .ports:- "8090:8090"
上面的Compose文件就描述一个项目,其中包含两个容器:
- mysql:一个基于mysql:5.7.25镜像构建的容器,并且挂在了两个目录
- web:一个基于docker build临时构建的镜像容器,映射端口是8090
DockerCompose的详细语法参考官网:https://docs.docker.com/compose/compose-file/。
其实DockerCompose文件可以看作是将多个docker run命令写到一个文件,只是语法稍有差异。
2. 安装DockerCompose
我的CentOS7安装Docker里面有详细操作。
3. 部署微服务项目
需求:将自己的cloud-demo微服务项目利用DockerCompose部署
步骤:
1)找一个目录,创建一个新的cloud-demo文件夹。
2)在cloud-demo文件夹创建一个docker-compose.yml文件,然后编写下面内容:
我这里用到的微服务只有user-service、order-service和gateway。因为feign-api是自己独立出来的一个模块,没有对外暴露的接口,供自己项目依赖引用的,后续打包userservice或orderservice的时候,会作为依赖打包进去,所以不需要在docker-compose文件中写出来,这里已经用到了nacos,所以eureka-service也不用了。
3)在cloud-demo下创建以mysql、user-service、gate-way、order-service命名的文件夹,用于存放部署时要用到的东西:
4) 因为要给mysql挂载一个配置文件和一个本地数据,所以在mysql文件夹里创建conf和data目录:
5)在mysql的conf文件夹里,创建hmy.cnf文件
内容如下:
[mysqld]
skip-name-resolve
character_set_server=utf8
datadir=/var/lib/mysql
server-id=1000
- skip-name-resolve:这个配置项告诉 MySQL 服务器在用户登录时不要进行域名解析,可以提高连接速度。
- character_set_server=utf8:表示服务器端使用的字符集为 utf8,这是为了确保数据的正确存储和检索
- datadir=/var/lib/mysql:这个配置项指定了 MySQL 数据库文件的存储路径,即数据库的数据文件将存储在 /var/lib/mysql 目录下
- server-id=1000:这个配置项指定了 MySQL 服务器的唯一标识号,用于在主从复制等场景中识别不同的服务器
6)将本地的mysql的data数据复制到cloud-demo/mysql/data下面:
这里面包括了我这次要部署的项目需要用到的cloud-order和cloud-user库,也包括了安装本地数据库时设置的root的用户信息,以及全部权限信息,所以找到本地数据库的数据存储目录,最好一起拷贝过来,另外,docker-compose文件里面写的mysql的root密码一定要跟本地的root密码一致,不然docker部署之后,会出现很多意想不到的问题(问就是我踩过这个坑)。
7)将之前没编写完的docker-compose文件,把mysql的数据卷的挂载信息写上:
后续我们启动docker-compose的时候,是在docker-compose.yml文件的目录下启动的,后续不管把这里的cloud-demo上传到虚拟机的哪个目录,都能通过$PWD这个命令找到当前目录,保证我们写的配置文件以及本地环境的数据环境能够在mysql镜像中能使用。
8) 在gateway目录下新建Dockerfile文件,内容如下:
FROM java:8-alpine
COPY ./app.jar /tmp/app.jar
ENTRYPOINT java -jar /tmp/app.jar
这就是一个自定义的镜像文件。然后把这个文件在user-service和order-service文件夹中各拷贝一份。
9)使用maven打包工具,将项目中的每个微服务都打包为app.jar,我的就是gateway、order-service和user-service:
在上面上个微服务的pom文件中加上下面的内容就可以,这里的filename指的就是将微服务打包成app.jar。
<build><finalName>app</finalName><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins>
</build>
打包好之后将这里的app.jar包复制到各自对应的文件夹下面。
10)将docker-compose.yml文件补全:
docker-compose.yml文件到这里就全部写完了,全部内容如下:
version: "3.2" # docker-compose 文件格式版本
services:nacos:image: nacos/nacos-server # 指定的使用镜像,如果本地或虚拟机里没有会自动从远程仓库拉取,我这里没有指定nacos-server的版本号,所以会去拉取最新版本environment:MODE: standaloneports:- "8848:8848"mysql:image: mysql:5.7.25 # 指定使用的mysql镜像,我这里指定了版本,是因为跟我本地保持一致,后续数据卷映射的时候,需要使用到本地的mysql数据文件environment:MYSQL_ROOT_PASSWORD: 123456 # 设置镜像mysql的root密码,跟本地保持一致,后续用到本地数据的时候,不会报错volumes:- "$PWD/mysql/data:/var/lib/mysql" # 数据卷映射,把本地的mysql/data目录挂载到镜像的/var/lib/mysql目录下,这样,我们本地的数据文件,在镜像里也是存在的,其中$PWD表示当前目录- "$PWD/mysql/conf:/etc/mysql/conf.d/" # 同上,把本地的mysql/conf目录挂载到镜像的/etc/mysql/conf.d/目录下,这样,我们本地的配置文件,在镜像里也是存在的userservice:build: ./user-service # 指定构建镜像的目录,会自动去该目录下寻找Dockerfile文件,然后构建镜像,这里的./user-service表示去当前目录下的user-service目录找Dockerfile文件orderservice:build: ./order-servicegateway:build: ./gatewayports:- "10010:10010"
11)将整个cloud-demo上传到虚拟机的任意目录下面,我这里的是上传到/tmp目录下面:
然后进入docker-compose.yml文件目录下(/tmp/cloud-demo),运行命令:
docker-compose up -d
t通过命令docker ps可以看到启动的服务有哪些:
服务都启动之后,访问cloud-demo的对外接口,http://虚拟机IP:10010/user/1?authorization=admin,可以得到结果:
访问cloud-demo的对外接口,http://虚拟机IP:10010/order/101?authorization=admin,可以得到结果:
另外,在服务部署的时候要善于使用docker-compose --help命令,这里介绍了很多,包括查看服务启动的日志等。
如果在部署过程中出现微服务注册到nacos里报错的话,在确保nacos服务启动成功之后,重启其他微服务就可以了。
4. 如果mysql密码不一致如何解决
如果mysql配置的密码和你的项目不一致,先用下面命令进入mysql容器:
docker exec -it 你的mysql容器名字
再通过下面命令进入mysql:
mysql -u root -p
然后修改你的登录MySQL的登录密码,下面的host='%',代表的是不止本地登录,你可以先查查你的mysql的user表看看root的host是不是%还是localhost:
update mysql.user set authentication_string=password('你的新密码') where user ='root and host = '%';flush privileges;
然后更新授予用户权限,这里的root@%指的就是user的host为%(任意地方登录):
grant all privileges on *.* to root@'%' identified by 'root' with grant option;flush privileges;
这样不管你是虚拟机登录还是外部浏览器访问微服务接口,就都能调用数据库了。
相关文章:

DockerCompose部署示例
目录 前言 1. 初识DockerCompose 2. 安装DockerCompose 3. 部署微服务项目 1)找一个目录,创建一个新的cloud-demo文件夹。 2)在cloud-demo文件夹创建一个docker-compose.yml文件,然后编写下面内容: 3)…...

【云原生】Helm来管理Kubernetes集群的详细使用方法与综合应用实战
✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…...
电源插头应该统一方向
大家在使用插排的时候就会发现,有的横向,有的竖向。 国家强制规定,统一方向,插排能方便使用。...
大学新生编程入门最佳攻略
引言 编程的重要性:简述编程在当今社会的地位,为何它是大学生的必备技能。目标设定:明确文章旨在帮助新生从零基础开始,逐步成长为编程高手。 方向一:编程语言选择 1. 编程语言概览 介绍几种流行语言:如…...

MySQL 的binlog 、undolog 、redolog
Binlog (二进制日志) bin Log 作用 用于记录所有修改数据库数据的 SQL 语句或行级别的变化,主要用于主从复制和数据恢复。 binlog格式 STATEMENT模式:binlog里面记录的就是SQL语句的原文。优点是并不需要记录每一行的数据变化,减少了binlo…...

【计算机网络】三次握手、四次挥手
问:三次握手 四次挥手 TCP 连接过程是 3 次握手,终止过程是 4 次挥手 3次握手 第一步:客户端向服务器发送一个带有 SYN(同步)标志的包,指示客户端要建立连接。 第二步:服务器收到客户端的请求…...
Spring Boot中的全局异常处理:@RestControllerAdvice的应用
在现代Web开发中,异常处理是一个不可或缺的部分。良好的异常处理不仅能提高系统的健壮性,还能提升用户体验。在Spring Boot中,全局异常处理的实现可以通过使用RestControllerAdvice注解来完成。本文将详细介绍如何使用RestControllerAdvice和…...
指令数据的构建
文章目录 基于现有的 NLP 任务数据集构建基于日常对话数据构建基于合成数据构建指令微调(Instruction Tuning)是指使用自然语言形式的数据对预训练后的大语言模型进行参数微调,这一术语由谷歌研究员在 2022 年的一篇 ICLR 论文中正式提出。在另外一些参考文献中,指令微调也…...

论文解读(14)-GeoCLIP
加油,加油! 原文: GeoCLIP: Clip-Inspired Alignment between Locations and Images for Effective Worldwide Geo-localization (2309.16020 (arxiv.org)) 这一篇的重点在于范围放宽到全球了 摘要 首先指出了目前…...

MySQL基础练习题16-电影评分
题目 准备数据 分析数据 总结 题目 查找评论电影数量最多的用户名。如果出现平局,返回字典序较小的用户名。 查找在 February 2020 平均评分最高 的电影名称。如果出现平局,返回字典序较小的电影名称。 准备数据 ## 创建库 create database db; u…...

CRMEB-众邦科技 使用笔记
1.启动项目报错 Unable to load authentication plugin ‘caching_sha2_password’. 参考:http://t.csdnimg.cn/5EqaE 解决办法:升级mysql驱动 <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</ar…...

npm与webpack的学习笔记
npm 定义:npm是Node.js标准的软件包管理器。它起初是作为下载和管理Node.js包依赖的方式,但其现在也已成为前端JavaScript中使用的工具。 包 包:将模块、代码、其他资料聚合成一个文件夹 包的分类: 项目包:主要用…...
Vue 生命周期选项:2.x 与 3.x 的全面解析及案例分享二
目录 Vue3.X生命周期 介绍 流程图 案例 this.$nextTick Vue 生命周期选项:2.x 与 3.x 的全面解析及案例分享一-CSDN博客 Vue3.X生命周期 介绍 beforeCreate:在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。此时无法访…...
Linux centos7 安装sftp
这里写自定义目录标题 指定 SSH 默认端口 (通常是22)添加自定义端口确保 SFTP 子系统配置存在匹配自定义端口的配置 在 CentOS 7 上安装 SFTP 并使用自定义端口 22345 启动,同时不影响现有的 SSH 登录,可以按照以下步骤进行配置: 步骤 1: 安…...

Java未来还是霸主吗?Java 在当今企业中的未来到底是什么?
Java 及其生态系统对于许多现代企业的成功至关重要。它是一种多功能语言,对许多用例提供强大支持,并具有强大的新功能来应对棘手的情况。但您可能会问自己:Java 的未来是什么? 尽管自 1999 年以来 Java 一直是软件开发领域的关键角…...

【C++】类和对象——Lesson2
Hi~!这里是奋斗的小羊,很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎 ~~ 💥💥个人主页:奋斗的小羊 💥💥所属专栏:C 🚀本系列文章为个人学习笔记…...

常用传感器讲解十五--触摸传感器(KY-036)
常用传感器讲解十五–触摸传感器(KY-036) 具体讲解 这个比较简单,就是触摸后给个信号 电路连接 在Arduino上将VCC引脚连接到5V。 将GND连接到Arduino的GND。 将OUT连接到Arduino上的D2 代码实现 void setup() {pinMode(2, INPUT);Seri…...

web后端--Spring事务管理
事务也要日志配置 !!!!debug前面记得加空格 logging:level:org.springframework.jdbc.support.JdbcTransactionManager: debugrollbackFor 默认情况下,只有出现RunTimeException才会回滚事务,rollbackfor属性用于控制出现何种异常类型,回滚…...

【Docker系列】Docker 中-d 和-it 的区别
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

PHP回收废品平台系统小程序源码
🌍绿色行动,从“回收废品平台系统”开始!🚚 🚪【家门口的环保站,废品不再无处安放】 你是否曾为家里的旧报纸、空瓶子、废旧电器等废品头疼不已,不知该如何处理?现在,“…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析
1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具,该工具基于TUN接口实现其功能,利用反向TCP/TLS连接建立一条隐蔽的通信信道,支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式,适应复杂网…...
synchronized 学习
学习源: https://www.bilibili.com/video/BV1aJ411V763?spm_id_from333.788.videopod.episodes&vd_source32e1c41a9370911ab06d12fbc36c4ebc 1.应用场景 不超卖,也要考虑性能问题(场景) 2.常见面试问题: sync出…...

Flask RESTful 示例
目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题: 下面创建一个简单的Flask RESTful API示例。首先,我们需要创建环境,安装必要的依赖,然后…...
在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能
下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能,包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...

基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容
基于 UniApp + WebSocket实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...
【论文笔记】若干矿井粉尘检测算法概述
总的来说,传统机器学习、传统机器学习与深度学习的结合、LSTM等算法所需要的数据集来源于矿井传感器测量的粉尘浓度,通过建立回归模型来预测未来矿井的粉尘浓度。传统机器学习算法性能易受数据中极端值的影响。YOLO等计算机视觉算法所需要的数据集来源于…...
【python异步多线程】异步多线程爬虫代码示例
claude生成的python多线程、异步代码示例,模拟20个网页的爬取,每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程:允许程序同时执行多个任务,提高IO密集型任务(如网络请求)的效率…...

让回归模型不再被异常值“带跑偏“,MSE和Cauchy损失函数在噪声数据环境下的实战对比
在机器学习的回归分析中,损失函数的选择对模型性能具有决定性影响。均方误差(MSE)作为经典的损失函数,在处理干净数据时表现优异,但在面对包含异常值的噪声数据时,其对大误差的二次惩罚机制往往导致模型参数…...

回溯算法学习
一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...

Python基于历史模拟方法实现投资组合风险管理的VaR与ES模型项目实战
说明:这是一个机器学习实战项目(附带数据代码文档),如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在金融市场日益复杂和波动加剧的背景下,风险管理成为金融机构和个人投资者关注的核心议题之一。VaR&…...