docker swarm搭建mysql数据库服务

因为工作需要搭建演示环境,使用docker swarm部署了一次mysql,特此整理,以备参考。

首先我们需要编写docker swarm启动使用的yml文件,指明所用镜像,版本以及一些配置。

其中因为使用了hostnet网络模式,容器将不会虚拟出IP/端口,而是使用宿主机的IP和端口。 比如你配置了使用3306端口,就是直接使用服务器的3306端口。

容器启动后,便可以使用配置文件中的初始密码连接访问。

示例

yaml 复制代码
version: '3.4'
services:
  mysql:
    volumes:
      - /app/mysql/conf:/etc/mysql
      - /app/mysql/data:/var/lib/mysql
      - /app/mysql/logs:/var/log/mysql
      - /app/mysql/mysql-files:/var/lib/mysql-files
    image: mysql:8.0.25
    networks:
       - hostnet
    environment:
      - TZ=Asia/Shanghai
      - MYSQL_ROOT_PASSWORD=password
      - SQL_MODE=STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
    deploy:
      mode: replicated
      replicas: 1
      placement:
        constraints:
        # 指定启动节点
#          - node.labels.node==manager
           - node.role==manager
    # 赋予容器所有内核权限       
    cap_add:
      - ALL
    logging: 
      driver: "json-file"
      options: 
        max-size: "1m"

#networks:
#  overlay:

networks:
  hostnet:
    external:
      name: host

其中需要根据配置,建立对应目录与配置文件,docker会将你服务器的目录与镜像内的目录相映射。

javascript 复制代码
    volumes:
      - /app/mysql/conf:/etc/mysql
      - /app/mysql/data:/var/lib/mysql
      - /app/mysql/logs:/var/log/mysql
      - /app/mysql/mysql-files:/var/lib/mysql-files

前半边为你服务器上的目录,后半部分为对应镜像内的目录, 前半边的目录需要你先手动创建mkdir出来,否则容器无法启动

目录用处 /etc/mysql 配置 /var/lib/mysql 数据文件 /var/log/mysql 日志 /var/lib/mysql-files 导入导出

其中可以在配置目录/etc/mysql下,新加my.cnf进行相关配置的调整 数据文件目录/var/lib/mysql保证数据不会随容器关闭而丢失,也便于迁移,其他目录不再具体说明,

my.cnf 示例如下

ini 复制代码
[mysqld]
port=6446
#skip-grant-tables
skip-name-resolve

#此参数可以控制服务端口监听在哪个网卡上
#bind_address=192.168.22.22
#bind_address=127.0.0.1
#bind-address = 0.0.0.0

default-time-zone='+08:00'

collation_server=utf8mb4_general_ci
character_set_server=utf8mb4
init-connect=SET NAMES utf8mb4
default-time-zone='+08:00'
max_connections=3000

#binlog保留多长时间
binlog_expire_logs_seconds=2592000

#函数验证规则
log_bin_trust_function_creators=1

[client]
default-character-set=utf8mb4 

[mysqld_safe]
log-error=/var/log/mysql/mysqld.log

sql_mode="ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"

容器启动 docker stack deploy -c /app/mysql/mysql-docker.yml mysql

容器删除 docker stack rm mysql

容器日志 docker service logs -f mysql_mysql

启动节点查看 docker service ps mysql_mysql

相关推荐
鳄鱼杆1 小时前
服务器 | Docker应用开发与部署的实践以及阿里云镜像加速配置
服务器·阿里云·docker
逍遥浪子~2 小时前
docker实践(一)
运维·docker·容器
AI云原生3 小时前
如何使用Docker快速运行Firefox并实现远程访问本地火狐浏览器的教程
运维·docker·云原生·容器·serverless·firefox·kubeless
❀͜͡傀儡师4 小时前
Docker部署搜索引擎SearXNG
运维·docker·容器·searxng
虎头金猫5 小时前
如何在Linux上使用Docker在本地部署开源PDF工具Stirling PDF:StirlingPDF+cpolar让专业操作像在线文档一样简单
linux·运维·ubuntu·docker·pdf·开源·centos
janthinasnail8 小时前
使用Docker搭建MaxKB智能体平台
docker·maxkb
计算机小手8 小时前
高效 P2P 文件传输工具:FileSync 利用 WebRTC 技术实现极速安全传输
经验分享·docker·webrtc·开源软件
笨鸟贤妃9 小时前
Ubuntu 22.04 安装 Docker & Compose 最新最简单完整指南
ubuntu·docker·compose
感哥10 小时前
Docker存储
docker
灞波儿奔波儿灞10 小时前
Lucky STUN穿透结合群晖NAS实现docker下transmission监听端口动态更新
docker·群晖·stun·lucky