国产化 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 数据库并确保数据库服务始终保持运行。通过映射的端口,可以从宿主机访问数据库。
相关推荐
鸠摩智首席音效师1 小时前
Docker 中如何限制CPU和内存的使用 ?
docker·容器
Michaelwubo1 小时前
Docker dockerfile镜像编码 centos7
运维·docker·容器
jingyu飞鸟1 小时前
centos-stream9系统安装docker
linux·docker·centos
好像是个likun1 小时前
使用docker拉取镜像很慢或者总是超时的问题
运维·docker·容器
White_Mountain2 小时前
在Ubuntu中配置mysql,并允许外部访问数据库
数据库·mysql·ubuntu
老王笔记3 小时前
GTID下复制问题和解决
mysql
玖疯子4 小时前
介绍 Docker 的基本概念和优势,以及在应用程序开发中的实际应用。
docker
暴富的Tdy4 小时前
【快速上手Docker 简单配置方法】
docker·容器·eureka
Lojarro4 小时前
【Spring】Spring框架之-AOP
java·mysql·spring
TianyaOAO4 小时前
mysql的事务控制和数据库的备份和恢复
数据库·mysql