1、拉取镜像
bash
x86架构
docker pull registry.cn-hangzhou.aliyuncs.com/qiluo-images/mariadb:latest
arm架构
docker pull registry.cn-hangzhou.aliyuncs.com/qiluo-images/linux_arm64_mariadb:latest
mariadb 版本是12.1.2版本
运行容器
bash
docker run -d -p 3306:3306 \
--name mariadb --privileged=true \
-e MYSQL_ROOT_PASSWORD="68WcxQhIcN206LrO" \
-e MYSQL_USER="root" \
-e MYSQL_PASSWORD="68WcxQhIcN206LrO" \
-e MYSQL_DATABASE="mariadb" \
-v /data/mariadb/my.cnf:/etc/mysql/my.cnf \
-v /data/mariadb/data:/var/lib/mysql \
-v /data/mariadb/logs:/var/log/mysql \
-v /etc/localtime:/etc/localtime:ro \
registry.cn-hangzhou.aliyuncs.com/qiluo-images/mariadb:latest
完整的 MariaDB 安装脚本
bash
#!/bin/bash
# 设置变量
DB_NAME="mariadb"
DB_USER="root"
DB_PASSWORD="68WcxQhIcN206LrO"
DATA_DIR="/data/mariadb"
PORT="3306"
# 创建数据目录
sudo mkdir -p ${DATA_DIR}/{data,logs,conf}
sudo chmod -R 777 ${DATA_DIR}
# 创建配置文件
cat > ${DATA_DIR}/conf/my.cnf << EOF
[mysqld]
server-id = 100
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
max_connections = 1000
max_allowed_packet = 256M
log-bin = mysql-bin
binlog_format = row
expire_logs_days = 7
slow_query_log = 1
slow_query_log_file = /var/log/mysql/slow.log
long_query_time = 2
[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
EOF
# 停止并移除现有容器
docker stop mariadb 2>/dev/null
docker rm mariadb 2>/dev/null
# 运行 MariaDB 容器
docker run -d \
--name mariadb \
--restart=unless-stopped \
--privileged=true \
-p ${PORT}:3306 \
-e MYSQL_ROOT_PASSWORD=${DB_PASSWORD} \
-e MYSQL_DATABASE=${DB_NAME} \
-e MYSQL_USER=${DB_USER} \
-e MYSQL_PASSWORD=${DB_PASSWORD} \
-v ${DATA_DIR}/data:/var/lib/mysql \
-v ${DATA_DIR}/logs:/var/log/mysql \
-v ${DATA_DIR}/conf/my.cnf:/etc/mysql/conf.d/my.cnf \
-v /etc/localtime:/etc/localtime:ro \
registry.cn-hangzhou.aliyuncs.com/qiluo-images/mariadb:latest \
--character-set-server=utf8mb4 \
--collation-server=utf8mb4_unicode_ci
echo "MariaDB 安装完成!"
echo "连接信息:"
echo "主机: localhost:${PORT}"
echo "用户名: ${DB_USER}"
echo "密码: ${DB_PASSWORD}"
echo "数据库: ${DB_NAME}"
