• 售前

  • 售后

热门帖子
入门百科

docker官方mysql镜像自定义配置详解

[复制链接]
手机哈哈 显示全部楼层 发表于 2021-10-25 19:09:25 |阅读模式 打印 上一主题 下一主题
之前为了节省安装时间,所以用官方mysql docker镜像启动mysql。

通过
复制代码 代码如下:$ docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d daocloud.io/mysql:tag
some-mysql 指定了该容器的名字,my-secret-pw 指定了 root 用户的暗码,tag 参数指定了你想要的 MySQL 版本
如许数据是没有持久化的 所以在启动参数中必要挂载当地目录
于是如许数据库不停跑着,但是由于近来步伐必要支持emoji心情,不得不将mysql的字符集更改。
复制代码 代码如下:$ docker run --name some-mysql -v /my/own/datadir:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d daocloud.io/mysql:tag
这时候就可以挂载自定义配置文件,官方文档阐明
当 MySQL 服务启动时会以 /etc/mysql/my.cnf 为配置文件,本文件会导入 /etc/mysql/conf.d 目录中全部以 .cnf 为后缀的文件。这些文件会拓展或覆盖 /etc/mysql/my.cnf 文件中的配置。因此你可以创建你自己必要的配置文件并挂载至 MySQL 容器中的 /etc/mysql/conf.d 目录。

所以最简单改变数据库配置的方式就是在宿主机上新建配置文件,改成utf8mb4
  1. [client]
  2. default-character-set=utf8mb4
  3. [mysqld]
  4. character-set-client-handshake = FALSE
  5. character-set-server = utf8mb4
  6. collation-server = utf8mb4_unicode_ci
  7. [mysql]
  8. default-character-set=utf8mb4
复制代码
随后将文件复制到相应docker容器文件夹下
  1. docker cp /home/my.cnf(宿主机文件路径) [容器id]:/etc/mysql/mysql.conf.d
复制代码
末了使用docker stop和start下令重启容器就实现了加载自定义配置。

由Docker的MySQL官方镜像配置的容器无法启动题目

我使用的是MySQL的Docker镜像。先创建并启动镜像:
  1. # docker run --name mysql-b \
  2. > -p 33002:3306 -v /zc/mysql/datadir-b:/var/lib/mysql \
  3. > -e MYSQL_ROOT_PASSWORD='123456' -d mysql:latest
复制代码
正常启动,没有题目。通常我们使用MySQL的时候,必要设置参数。要设置参数,我们先得进入容器的bash,举行操作:
  1. docker exec -it mysql-b bash
复制代码
MySQL的默认配置文件是 /etc/mysql/my.cnf 文件。如果想要自定义配置,发起向 /etc/mysql/conf.d 目录中创建 .cnf 文件。新建的文件可以恣意起名,只要包管后缀名是 cnf 即可。新建的文件中的配置项可以覆盖 /etc/mysql/my.cnf 中的配置项。由于 MySQL 的 Docker 官方镜像没有提供 vim 编辑器,所以我用cat下令生成文件并添加内容:
  1. # cat >test.cnf <<EOF
  2. [mysqldump]
  3. user=root
  4. password='123456'
  5. [mysqld]
  6. max_allowed_packet=8M
  7. lower_case_table_names=1
  8. character_set_server=utf8
  9. max_connections=900
  10. max_connect_errors=600
  11. default-character-set=utf8
  12. EOF
复制代码
退出后,制止容器,再重新启动容器,发现容器无法启动。
办理方法

删除原来谁人不能启动的容器。重新创建一个新的容器。题目的关键在于原来的 test.cnf 文件有错误。找到原来配置文件的末了一行:
  1. default-character-set=utf8
复制代码
把这一行删除。添加配置文件的时候包管没有这一行就可以了。
题目缘故起因

MySQL 的官方 Docker 镜像里面,在标签 latest 下,[mysqld] 这一配置段上并没有 default-character-set 这一配置项。
如果你要检察全部的配置项,可以使用如下下令,使用管道将输出的资助都放到 help.txt 文件里面:
  1. docker run -it --rm mysql:tag --verbose --help > help.txt
复制代码
此中 tag 表现镜像的标签,好比 latest 和 5.6。

以上就是本文的全部内容,盼望对各人的学习有所资助,也盼望各人多多支持脚本之家。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作