本文共 2675 字,大约阅读时间需要 8 分钟。
用户和组设置
为mysql
用户和组创建组账号,并设置权限。groupadd -r mysql && useradd -r -g mysql mysql
软件包安装
安装必要的软件包并清理缓存。apt-get update && apt-get install -y --no-install-recommends gnupg dirmngr && rm -rf /var/lib/apt/lists/*
gosu安装
安装gosu工具以便于用户切换。export GOSU_VERSION=1.7set -x && apt-get update && apt-get install -y --no-install-recommends ca-certificates wgetwget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)"wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc"
验证GPG密钥并设置权限。
GNUPGHOME="$(mktemp -d)" && gpg --batch --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosugpgconf --kill allrm -rf "$GNUPGHOME" /usr/local/bin/gosu.ascchmod +x /usr/local/bin/gosu
启动gosu并清理缓存。
gosu nobody true && apt-get purge -y --auto-remove ca-certificates wget
目录创建
创建MySQL数据目录并设置权限。mkdir -p /var/lib/mysql /var/run/mysqldchown -R mysql:mysql /var/lib/mysql /var/run/mysqldchmod 777 /var/run/mysqld
MySQL配置
设置MySQL配置文件并禁用不必要的选项。echo '[mysqld]' >> /etc/mysql/conf.d/docker.cnfecho 'skip-host-cache' >> /etc/mysql/conf.d/docker.cnfecho 'skip-name-resolve' >> /etc/mysql/conf.d/docker.cnf
体积挂载
挂载数据库目录。VOLUME /var/lib/mysql
脚本执行
执行初始化脚本并设置入口点。COPY docker-entrypoint.sh /usr/local/bin/ln -s /usr/local/bin/docker-entrypoint.sh /entrypoint.shENTRYPOINT ["docker-entrypoint.sh"]
创建数据库目录并设置权限
创建数据库目录并确保mysql
用户拥有权限。mkdir -p /var/lib/mysqlchown -R mysql:mysql /var/lib/mysql
安装MySQL依赖
设置必要的DEBCONF选项并安装MySQL。debconf-set-selections << EOFmysql-community-server mysql-community-server/data-dir selectmysql-community-server mysql-community-server/root-pass passwordmysql-community-server mysql-community-server/re-root-pass passwordmysql-community-server mysql-community-server/remove-test-db select falseEOFapt-get update && apt-get install -y mysql-server=5.7.29-1debian9
移除旧文件
清理旧文件和目录。rm -rf /var/lib/mysql /var/run/mysqldmkdir -p /var/lib/mysql /var/run/mysqld
配置文件处理
处理MySQL配置文件中的绑定地址和日志设置。sed -Ei 's/^(bind-address|log)/#&/' /etc/mysql/conf.d/docker.cnf
数据库初始化
初始化数据库目录并设置初始密码。mkdir -p /var/lib/mysql /var/run/mysqldchown -R mysql:mysql /var/lib/mysql /var/run/mysqldchmod 777 /var/run/mysqld
用户管理
创建默认用户和设置root用户的密码。useradd -r -g mysql mysqlgroupadd -r mysql
设置root用户的密码并验证。
mysqladmin -u root -p shutdown
数据库检查
检查数据库配置并启动MySQL服务。mysqld --skip-networking --socket=/var/run/mysqld
最终验证
确保数据库已初始化并设置完成。mysql -u root -p
通过以上步骤,可以在Docker环境中完成MySQL服务器的配置和数据库初始化,确保数据库运行稳定且安全。
转载地址:http://jxjxz.baihongyu.com/