国产化 ARM 环境mysql-mariadb 部署

复制代码
version: '3.1'
services:
  db:
    image: mariadb:mysql-5.7
    container_name: mariadb
    command: ["mysqld", "--character-set-server=utf8mb4", "--collation-server=utf8mb4_unicode_ci","--default-authentication-plugin=mysql_native_password"] 
    restart: always
    volumes:
      - ./data:/var/lib/mysql
      - /etc/localtime:/etc/localtime:ro
    environment:
      MYSQL_ROOT_PASSWORD: 111111
      MYSQL_USER: malone
      MYSQL_PASSWORD : 111111
      TZ: Asia/Shanghai
    ports:
      - 3306:3306    

这段 docker-compose.yaml 文件定义了一个 mariadb 服务,使用 MariaDB 镜像并进行了一些配置。以下是逐行解释:

yaml 复制代码
version: '3.1'
  • 定义 Docker Compose 文件的版本为 3.1。这个版本支持定义多个服务,并允许使用一些高级特性。
yaml 复制代码
services:
  • services 是 Compose 文件中的关键字,表示所有的服务都定义在这里。在该文件中只定义了一个服务:db
yaml 复制代码
  db:
  • 这里定义了一个服务,名为 db,代表 MariaDB 数据库服务。
yaml 复制代码
    image: mariadb:mysql-5.7
  • image 指定了 Docker 容器的镜像。这里使用的是 mariadb:mysql-5.7,表示使用 MariaDB 5.7 版本的镜像。如果没有本地镜像,Docker 会从 Docker Hub 拉取。
yaml 复制代码
    container_name: mariadb
  • container_name 设置了容器的名称为 mariadb,这意味着在 Docker 中查看容器时,容器将以此名称出现。
yaml 复制代码
    command: ["mysqld", "--character-set-server=utf8mb4", "--collation-server=utf8mb4_unicode_ci","--default-authentication-plugin=mysql_native_password"]
  • command 用于覆盖容器启动时默认执行的命令。这里指定了 mysqld 命令及一些参数:
    • --character-set-server=utf8mb4 设置服务器的字符集为 utf8mb4,以支持更多字符(包括表情符号等)。
    • --collation-server=utf8mb4_unicode_ci 设置字符集的排序规则。
    • --default-authentication-plugin=mysql_native_password 使用 mysql_native_password 插件进行身份验证,以兼容一些较老的客户端。
yaml 复制代码
    restart: always
  • restart: always 表示容器如果停止或崩溃,会自动重启,确保服务持续运行。
yaml 复制代码
    volumes:
      - ./data:/var/lib/mysql
      - /etc/localtime:/etc/localtime:ro
  • volumes 用于将主机的目录或文件挂载到容器内:
    • ./data:/var/lib/mysql 将主机当前目录下的 data 文件夹挂载到容器中的 /var/lib/mysql,这是 MariaDB 存储数据库数据的位置。这样数据库数据就保存在宿主机上,即使容器删除也不会丢失。
    • /etc/localtime:/etc/localtime:ro 将宿主机的本地时间设置文件挂载到容器中,确保容器与宿主机的时间一致。
yaml 复制代码
    environment:
      MYSQL_ROOT_PASSWORD: 111111
      MYSQL_USER: malone
      MYSQL_PASSWORD : 111111
      TZ: Asia/Shanghai
  • environment 用于设置环境变量:
    • MYSQL_ROOT_PASSWORD: 111111 设置 MariaDB 的 root 用户密码为 111111
    • MYSQL_USER: malone 创建一个名为 malone 的普通用户。
    • MYSQL_PASSWORD: 111111 设置用户 malone 的密码为 111111
    • TZ: Asia/Shanghai 设置容器的时区为 Asia/Shanghai
yaml 复制代码
    ports:
      - 3306:3306
  • ports 映射容器的端口到宿主机的端口。这里将容器的 3306 端口映射到宿主机的 3306 端口,这样宿主机就可以通过 localhost:3306 访问 MariaDB 数据库。

总结:

  • 该配置文件使用 Docker Compose 来启动一个 MariaDB 5.7 的容器,配置了时区、字符集、数据卷挂载等内容。容器将运行 MariaDB 数据库并确保数据库服务始终保持运行。通过映射的端口,可以从宿主机访问数据库。
相关推荐
YL200404265 小时前
MySQL-基础篇-函数
mysql
薪火铺子6 小时前
MySQL 分库分表实战:ShardingSphere 深度解析
数据库·mysql
极客先躯6 小时前
高级java每日一道面试题-2025年12月07日-实战篇[Dockerj]-Docker daemon 的配置文件在哪里?常用的配置项有哪些?
java·docker·配置文件的实际位置·配置文件的格式规则·常用配置项全景与分类·配置如何生效·daemon 配置折射架构思维
yuanyuan2o26 小时前
从最小项目开始的 CMake 教程
c语言·开发语言·arm开发·c++·makefile·make·cmake
川石课堂软件测试7 小时前
软件测试|常见面试题整理
数据库·python·jmeter·mysql·appium·postman·prometheus
薪火铺子8 小时前
MySQL 锁机制与死锁分析深度解析
数据库·mysql
千百元8 小时前
mysql5.7 定时删除表数据
mysql
颯沓如流星9 小时前
【 Docker Desktop】基于Windows + WSL2 的环境配置, 快速部署一套Kubernetes Cluster
windows·docker·kubernetes
消失的旧时光-194310 小时前
SQL 第四篇:JOIN 实战(数据库到底是怎么“拼表”的)
数据库·sql·mysql
showyoui10 小时前
一次 GKE Sidecar 场景下的连通性排查实录
docker·微服务·容器·kubernetes·service_mesh