博客
关于我
Docker for MySQL
阅读量:615 次
发布时间:2019-03-12

本文共 2675 字,大约阅读时间需要 8 分钟。

Docker MySQL配置与数据库初始化脚本

Dockerfile

基础配置

  • 用户和组设置

    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"]
  • 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/

    你可能感兴趣的文章
    RabbitMQ - 如保证消息的可靠性?(消息确认、消息持久化、失败重试机制)
    查看>>
    RabbitMQ - 基于 SpringAMQP 带你实现五种消息队列模型
    查看>>
    php数组函数分析--array_column
    查看>>
    php数组去重复数据的小例子
    查看>>
    php数组实现:哈希 +双向链表
    查看>>
    PHP数组排序函数array_multisort()函数详解(二)
    查看>>
    php数组的几个函数和超全局变量
    查看>>
    PHP文件上传详解
    查看>>
    PHP文件锁
    查看>>
    php文本框输入制定文本,php – 当用户没有向文本框输入任何内容时...
    查看>>
    PHP时间戳和日期相互转换操作总结
    查看>>
    php时间戳知识点,php 时间戳函数总结与示例
    查看>>
    php更新数据库失败,php – 无法更新MySQL数据库
    查看>>
    php机器人聊天对话框,基于AIML的PHP聊天机器人
    查看>>
    PHP查找数组中最大值与最小值
    查看>>
    php查最大值,在PHP数组中查找最大值
    查看>>
    php标签筛选,关于PHP CodeIgniter框架中通过<a>标签和url做多条件分类筛选
    查看>>
    php根据年月日计算年龄
    查看>>
    RabbitMQ - 单机部署(超详细)
    查看>>
    php检查注册,PHP检查注册的电子邮件地址是一个’school.edu’地址
    查看>>