当前位置: 首页 > article >正文

把openEuler当微服务跑:Docker Compose编排实战,管理Nginx+MySQL多容器集群

基于openEuler的微服务集群实战Docker Compose编排NginxMySQL全流程在云原生技术席卷企业IT基础设施的今天将操作系统容器化已成为提升资源利用率、加速应用交付的标准实践。openEuler作为面向数字基础设施的开源操作系统凭借其卓越的多架构支持能力和云原生友好特性正成为容器化部署的理想选择。本文将带您深入探索如何利用Docker Compose这一编排利器在openEuler基础上构建完整的NginxMySQL微服务集群实现从单机部署到生产级集群管理的技术跃迁。1. 环境准备与架构设计1.1 系统需求与组件选型构建基于openEuler的容器化微服务集群需要确保基础环境满足以下要求Docker引擎版本20.10.0及以上支持Compose V2格式openEuler镜像推荐LTS版本如24.03-lts-sp2保证长期支持硬件资源至少2核CPU、4GB内存、20GB磁盘空间网络配置主机需开启IP转发net.ipv4.ip_forward1关键组件版本矩阵组件推荐版本替代方案备注openEuler24.03-lts-sp222.03-lts-sp4生产环境首选LTSNginx1.25.3OpenResty支持HTTP/3MySQL8.0.36MariaDB 10.11事务型业务首选1.2 多容器网络拓扑设计合理的网络架构是微服务稳定运行的基础。我们采用桥接网络模式设计如下通信方案[Host Machine] ├── [openeuler-bridge-network] │ ├── nginx-container (172.20.0.10) │ ├── mysql-container (172.20.0.20) │ └── [自定义网络策略] └── [Host Volume Mounts] ├── /data/nginx └── /data/mysql这种设计实现了容器间通过服务名直接通信关键数据持久化到宿主机端口暴露最小化原则2. Docker Compose编排实战2.1 编写docker-compose.yml创建项目目录并编写核心配置文件mkdir -p ~/openeuler-cluster/{nginx,mysql} cd ~/openeuler-clusterversion: 3.8 services: nginx: image: nginx:1.25.3-alpine container_name: openeuler-nginx platform: linux/amd64 ports: - 8080:80 - 8443:443 volumes: - ./nginx/conf.d:/etc/nginx/conf.d - ./nginx/logs:/var/log/nginx networks: - openeuler-net depends_on: - mysql healthcheck: test: [CMD, curl, -f, http://localhost] interval: 30s timeout: 10s retries: 3 mysql: image: mysql:8.0 container_name: openeuler-mysql platform: linux/amd64 environment: MYSQL_ROOT_PASSWORD: ${DB_ROOT_PASSWORD} MYSQL_DATABASE: ${DB_NAME} MYSQL_USER: ${DB_USER} MYSQL_PASSWORD: ${DB_PASSWORD} volumes: - ./mysql/data:/var/lib/mysql - ./mysql/init:/docker-entrypoint-initdb.d networks: - openeuler-net healthcheck: test: [CMD, mysqladmin, ping, -h, localhost] timeout: 20s retries: 10 networks: openeuler-net: driver: bridge ipam: config: - subnet: 172.20.0.0/242.2 环境变量配置创建.env文件管理敏感配置# Database Configuration DB_ROOT_PASSWORDOpenEuler1234 DB_NAMEapp_db DB_USERapp_user DB_PASSWORDUser5678 # Network Settings SUBNET172.20.0.0/24 NGINX_IP172.20.0.10 MYSQL_IP172.20.0.202.3 初始化脚本准备MySQL容器首次启动时会执行/docker-entrypoint-initdb.d目录下的脚本# 创建初始化SQL文件 cat ~/openeuler-cluster/mysql/init/01-create-tables.sql EOF CREATE TABLE IF NOT EXISTS users ( id INT AUTO_INCREMENT PRIMARY KEY, username VARCHAR(50) NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ) ENGINEInnoDB DEFAULT CHARSETutf8mb4; EOF3. 集群部署与优化3.1 启动与验证集群执行以下命令启动整个集群docker compose up -d验证服务状态# 检查容器运行状态 docker compose ps # 测试Nginx连接MySQL docker exec openeuler-nginx sh -c apk add mysql-client mysql -h mysql -u ${DB_USER} -p${DB_PASSWORD} ${DB_NAME} -e SHOW TABLES; # 查看实时日志 docker compose logs -f3.2 性能调优配置针对openEuler环境优化Nginx配置# ~/openeuler-cluster/nginx/conf.d/app.conf upstream backend { server mysql:3306; keepalive 32; } server { listen 80; server_name localhost; location /db { proxy_pass http://backend; proxy_http_version 1.1; proxy_set_header Connection ; } }MySQL性能优化建议# 在my.cnf中添加 [mysqld] innodb_buffer_pool_size 1G innodb_log_file_size 256M skip_name_resolve ON default_authentication_plugin mysql_native_password4. 生产环境进阶管理4.1 高可用方案设计实现零停机部署的滚动更新策略# 在docker-compose.yml中添加 deploy: update_config: parallelism: 1 delay: 10s order: start-first备份与恢复方案# MySQL每日备份 docker exec openeuler-mysql sh -c mysqldump -u root -p${MYSQL_ROOT_PASSWORD} --all-databases | gzip /var/lib/mysql/backup/$(date %Y%m%d).sql.gz # Nginx配置版本控制 cd ~/openeuler-cluster/nginx git init git add . git commit -m Initial config4.2 监控与日志收集配置Prometheus监控指标# docker-compose.yml追加 monitoring: image: prom/prometheus ports: - 9090:9090 volumes: - ./prometheus.yml:/etc/prometheus/prometheus.yml networks: - openeuler-net日志收集的ELK方案# 修改Nginx日志格式 log_format json_combined escapejson { time:$time_iso8601, remote_addr:$remote_addr, request:$request, status: $status, body_bytes_sent:$body_bytes_sent, request_time:$request_time };5. 故障排查与日常维护5.1 常见问题解决方案容器网络连通性测试# 检查容器间通信 docker exec -it openeuler-nginx ping mysql # 查看网络详情 docker network inspect openeuler-cluster_openeuler-net资源限制配置示例# 在docker-compose.yml中限制资源 nginx: deploy: resources: limits: cpus: 1.5 memory: 1G reservations: memory: 512M5.2 安全加固措施实施最小权限原则# 为MySQL创建专用用户 docker exec openeuler-mysql mysql -u root -p${DB_ROOT_PASSWORD} -e CREATE USER app_ro% IDENTIFIED BY Readonly123; GRANT SELECT ON ${DB_NAME}.* TO app_ro%; # 定期轮换密码 openssl rand -base64 16 | docker secret create db_password_v2 -在openEuler宿主机上实施的安全配置# 配置防火墙规则 firewall-cmd --permanent --add-rich-rulerule familyipv4 source address172.20.0.0/24 port port3306 protocoltcp accept firewall-cmd --reload # 启用SELinux容器策略 semanage port -a -t http_port_t -p tcp 8080

相关文章:

把openEuler当微服务跑:Docker Compose编排实战,管理Nginx+MySQL多容器集群

基于openEuler的微服务集群实战:Docker Compose编排NginxMySQL全流程 在云原生技术席卷企业IT基础设施的今天,将操作系统容器化已成为提升资源利用率、加速应用交付的标准实践。openEuler作为面向数字基础设施的开源操作系统,凭借其卓越的多架…...

微信支付运营户 vs 基本户彻底搞懂:商家转账到零钱的资金流与账户权限实操指南

微信支付商户账户体系全解析:从资金流到权限设置的实战指南 第一次登录微信支付商户后台时,那些专业术语和复杂的资金流向是否让你感到手足无措?作为刚接手这项工作的财务或技术人员,理解运营户和基本户的区别就像学习一门新语言…...

手把手教你用XML为RimWorld Mod添加第一个新物品:从Defs文件到游戏内生效全流程

从零开始为RimWorld Mod添加自定义武器:XML实战指南 第一次打开RimWorld的Mod文件夹时,那些密密麻麻的XML文件可能让人望而生畏。但别担心——每个资深Mod作者都经历过这个阶段。今天我们就用最直观的方式,带你完成第一个可运行的物品Mod&…...

别再死记M法T法公式了!用Arduino和常见编码器手把手教你电机测速(附代码)

用Arduino实战编码器测速:告别公式背诵,从接线到可视化分析 当你第一次拿到那个小巧的增量式编码器时,可能会被那些专业术语吓到——M法、T法、分辨率、倍频...但我要告诉你一个秘密:这些概念远没有看起来那么可怕。本文将带你用最…...

MRIcron的dcm2niix命令行参数详解:从-f到-z,每个选项在医学影像转换中到底有什么用?

MRIcron的dcm2niix命令行参数深度解析:精准控制医学影像转换的20个关键技巧 在神经影像研究领域,DICOM到NIfTI的格式转换是数据处理流程中的关键第一步。作为业内广泛使用的转换工具,MRIcron套件中的dcm2niix以其高效稳定的表现赢得了研究人员…...

如何在极域电子教室控制下找回学习自主权

如何在极域电子教室控制下找回学习自主权 【免费下载链接】JiYuTrainer 极域电子教室防控制软件, StudenMain.exe 破解 项目地址: https://gitcode.com/gh_mirrors/ji/JiYuTrainer 你是否经历过这样的场景?老师在全班电脑上开启了极域电子教室的屏幕广播&…...

茶叶病害目标检测数据集 茶叶病害识别管理系统 数据集+界面+模型 识别功能包括登录、导入模型、图片、视频、实时检测

01 — 茶叶病害目标检测(数据集/界面 基于YOLO全系列,界面非常美观,非常详细)模块/类别 详细说明 一、技术栈编程语言:PythonGUI框架:PyQt5(界面美观、操作友好)目标检测模型框架&am…...

艾尔登法环终极优化指南:解锁帧率与游戏增强的完整教程

艾尔登法环终极优化指南:解锁帧率与游戏增强的完整教程 【免费下载链接】EldenRingFpsUnlockAndMore A small utility to remove frame rate limit, change FOV, add widescreen support and more for Elden Ring 项目地址: https://gitcode.com/gh_mirrors/el/El…...

PDF-Extract-Kit-1.0与STM32CubeMX的嵌入式集成方案

PDF-Extract-Kit-1.0与STM32CubeMX的嵌入式集成方案 1. 工业现场的真实需求场景 在工厂自动化产线里,设备运行日志、维修手册、质检报告这些资料大多以PDF格式存在。操作员需要快速从几十页的技术文档中提取某个传感器的参数范围,或者从维修记录里找出…...

Qwen2.5-VL-7B-Instruct部署教程:离线环境无网络安装依赖包完整方案

Qwen2.5-VL-7B-Instruct部署教程:离线环境无网络安装依赖包完整方案 1. 学习目标与前置准备 Qwen2.5-VL-7B-Instruct是一款强大的多模态视觉-语言模型,能够同时处理图像和文本输入,生成高质量的响应。本教程将带你完成在离线环境下的完整部…...

本地Cookie导出工具:解决Web开发中的认证数据管理难题

本地Cookie导出工具:解决Web开发中的认证数据管理难题 【免费下载链接】Get-cookies.txt-LOCALLY Get cookies.txt, NEVER send information outside. 项目地址: https://gitcode.com/gh_mirrors/ge/Get-cookies.txt-LOCALLY 在Web开发和数据采集领域&#x…...

玄机靶场实战:从应急响应到vulntarget-j-02的攻防解析

1. 玄机靶场与应急响应实战入门 第一次接触玄机靶场时,我被它高度仿真的企业内网环境震撼到了。这个基于Docker构建的靶场平台完美复现了企业常见的Windows服务器、Web应用和数据库服务,甚至连日志记录和行为特征都和真实环境一模一样。对于想学习网络安…...

1篇2章10节:介绍 CO-STAR 提示词工程框架

CO-STAR 框架的核心理念是将系统化目标管理的思路应用于提示词设计。框架由六大要素组成,通过系统化拆解,CO-STAR 帮助用户将复杂或多维任务转化为结构化、可控的提示词,提升 AI 理解和执行的准确性。CO-STAR 提示词工程框架在现代社会&#…...

终极指南:如何在OBS中一键实现AI背景移除与低光增强

终极指南:如何在OBS中一键实现AI背景移除与低光增强 【免费下载链接】obs-backgroundremoval An OBS plugin for removing background in portrait images (video), making it easy to replace the background when recording or streaming. 项目地址: https://gi…...

Graphormer部署案例:科研云平台中Graphormer作为标准化AI分子服务模块

Graphormer部署案例:科研云平台中Graphormer作为标准化AI分子服务模块 1. 项目概述 Graphormer是一种基于纯Transformer架构的图神经网络模型,专门为分子图(原子-键结构)的全局结构建模与属性预测而设计。该模型在OGB、PCQM4M等…...

文墨共鸣效果展示:当传统水墨美学遇上现代AI技术

文墨共鸣效果展示:当传统水墨美学遇上现代AI技术 1. 视觉与技术的完美融合 1.1 水墨美学的数字重生 在数字化浪潮中,"文墨共鸣"项目创造性地将中国传统水墨美学与现代AI技术相结合。这个独特的语义相似度分析工具摒弃了传统技术工具的冰冷界…...

Happy Island Designer终极指南:从零开始打造梦想岛屿的完整教程

Happy Island Designer终极指南:从零开始打造梦想岛屿的完整教程 【免费下载链接】HappyIslandDesigner "Happy Island Designer (Alpha)",是一个在线工具,它允许用户设计和定制自己的岛屿。这个工具是受游戏《动物森友会》(Animal…...

终极指南:为什么Tree of Thoughts思维树算法能提升AI推理能力70%?

终极指南:为什么Tree of Thoughts思维树算法能提升AI推理能力70%? 【免费下载链接】tree-of-thoughts Plug in and Play Implementation of Tree of Thoughts: Deliberate Problem Solving with Large Language Models that Elevates Model Reasoning by…...

Jetson设备文件系统损坏?别急着重刷!试试这个fsck.ext4急救指南

Jetson设备文件系统损坏?别急着重刷!试试这个fsck.ext4急救指南 当你的Jetson设备突然无法启动,屏幕上跳出EXT4-fs error loading journal或cant read superblock这类错误时,大多数人的第一反应可能是翻出刷机工具包,准…...

精通Venera漫画源:从零构建个性化漫画生态系统的完整指南

精通Venera漫画源:从零构建个性化漫画生态系统的完整指南 【免费下载链接】venera A comic app 项目地址: https://gitcode.com/gh_mirrors/ve/venera 你是否曾想过将分散在不同平台的漫画资源整合到一个统一的阅读环境中?Venera作为一款开源漫画…...

如何快速掌握Google Cloud服务的Go实现:golang-samples完整指南

如何快速掌握Google Cloud服务的Go实现:golang-samples完整指南 【免费下载链接】golang-samples Sample apps and code written for Google Cloud in the Go programming language. 项目地址: https://gitcode.com/gh_mirrors/go/golang-samples GitHub 加速…...

如何快速解决Windows热键冲突问题:Hotkey Detective完整使用指南

如何快速解决Windows热键冲突问题:Hotkey Detective完整使用指南 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective …...

CC工具箱实战:SHP转TXT通用版,从数据到自定义描述的完整流程

1. 为什么需要SHP转TXT工具? 在日常的GIS数据处理工作中,我们经常会遇到需要将SHP格式的地块数据转换为特定格式的TXT文件的需求。比如在土地调查项目中,上级部门可能要求提交包含地块坐标和属性的文本文件;在数据上报时&#xff…...

Solana验证节点同步太慢?保姆级快照下载与加速同步配置指南

Solana验证节点同步太慢?保姆级快照下载与加速同步配置指南 运行Solana验证节点时,最令人头疼的莫过于漫长的区块同步过程。我曾亲眼见过一个节点花了整整三天才完成同步,期间消耗的服务器资源和运维精力让人抓狂。不过别担心,通…...

Qwen3.5-4B-Claude-Opus开源大模型教程:Web镜像安全配置最佳实践

Qwen3.5-4B-Claude-Opus开源大模型教程:Web镜像安全配置最佳实践 1. 模型与镜像概述 Qwen3.5-4B-Claude-4.6-Opus-Reasoning-Distilled-GGUF是基于Qwen3.5-4B的推理蒸馏模型,特别强化了结构化分析、分步骤回答以及代码与逻辑类问题的处理能力。该版本以…...

从地图文件到实际导航:手把手教你用Cartographer的PGM/YAML配置Amcl定位

从地图文件到实际导航:手把手教你用Cartographer的PGM/YAML配置Amcl定位 在机器人自主导航的实践中,Cartographer作为SLAM领域的标杆工具,其生成的地图文件(.pgm和.yaml)常常成为下游导航模块的起点。但许多开发者发现…...

运动控制系统(五)-闭环的PI控制系统

上一节我们讲到控制系统的三大规律,第一条就是“比例控制系统无法消除“静差”。这一节我们解决这个问题。闭环积分控制在介绍静差的时候我们提到了:静差的存在主要是因为比例控制器仅依赖于当前误差ΔUn来进行调节,而没有考虑过去&#xff0…...

Pixel Dream Workshop 大模型一键部署教程:3步搭建创意生成环境

Pixel Dream Workshop 大模型一键部署教程:3步搭建创意生成环境 1. 开篇:为什么选择Pixel Dream Workshop? 如果你正在寻找一个能快速生成高质量创意内容的工具,Pixel Dream Workshop绝对值得一试。这个基于大模型的开源项目&am…...

SleeperX:Mac智能睡眠控制终极方案,告别合盖中断烦恼

SleeperX:Mac智能睡眠控制终极方案,告别合盖中断烦恼 【免费下载链接】SleeperX MacBook prevent idle/lid sleep! Hackintosh sleep on low battery capacity. 项目地址: https://gitcode.com/gh_mirrors/sl/SleeperX 在Mac使用中,你…...

芯片中层的三道坎:贪权、嗔人、痴技术

做芯片研发的中层,处境其实很尴尬。上面有总监压着,下面有工程师看着,左边是项目deadline,右边是跨部门扯皮。每天活得像个三明治。但在这种压力下,很多中层会不知不觉走偏——心态出了问题。先说”贪”。中层最常见的…...