由Docker的MySQL官方镜像配置的容器无法启动问题的解决办法
来源:互联网 发布:ios4邪恶福利软件 编辑:程序博客网 时间:2024/04/30 03:45
这篇文章记录了我在使用 Docker 的 MySQL 官方镜像的时候碰到的一个问题。MySQL 的版本是 5.7。
问题描述
我使用的是MySQL的Docker镜像。先创建并启动镜像:
# docker run --name mysql-b \> -p 33002:3306 -v /zc/mysql/datadir-b:/var/lib/mysql \> -e MYSQL_ROOT_PASSWORD='123456' -d mysql:latest
正常启动,没有问题。通常我们使用MySQL的时候,需要设置参数。要设置参数,我们先得进入容器的bash,进行操作:
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命令生成文件并添加内容:
# cat >test.cnf <<EOF[mysqldump]user=rootpassword='123456'[mysqld]max_allowed_packet=8Mlower_case_table_names=1character_set_server=utf8max_connections=900max_connect_errors=600default-character-set=utf8EOF
退出后,停止容器,再重新启动容器,发现容器无法启动。
解决方法
删除原来那个不能启动的容器。重新创建一个新的容器。问题的关键在于原来的 test.cnf 文件有错误。找到原来配置文件的最后一行:
default-character-set=utf8
把这一行删除。添加配置文件的时候保证没有这一行就可以了。
问题原因
MySQL 的官方 Docker 镜像里面,在标签 latest 下,[mysqld] 这一配置段上并没有 default-character-set 这一配置项。
如果你要查看所有的配置项,可以使用如下命令,利用管道将输出的帮助都放到 help.txt 文件里面:
docker run -it --rm mysql:tag --verbose --help > help.txt
其中 tag 表示镜像的表情,比如 latest 和 5.6。
0 0
- 由Docker的MySQL官方镜像配置的容器无法启动问题的解决办法
- 【081】使用Nginx的官方Docker镜像,启动容器后无法显示自己网站页面,总显示Nginx官方默认页面的问题的解决方法
- MySQL 官方 Docker 镜像的使用
- 关于Docker官方CentOS镜像无法启动mysqld的总结
- 修改无法启动的docker容器的配置
- Docker 的 MySQL 官方镜像如何设置时区
- 如何使用DockerHub官方的mysql镜像生成容器
- 详解使用DockerHub官方的mysql镜像生成容器
- Docker配置本地镜像与容器的存储位置
- 解决无法docker镜像无法上传的问题
- Docker的安装/帮助/镜像/容器
- Docker镜像与容器的区别
- 解决docker镜像无法下载的问题
- 解决docker镜像无法下载的问题
- docker镜像的问题
- Docker笔记(1)--官方的tomcat镜像的使用(启动)
- Dockerfile、Docker镜像和Docker容器的关系
- 构建MySQL(5.6.22)Docker镜像遇到的问题
- SDUTACM 数据结构实验之栈四:括号匹配
- c++ find()
- 遍历转换
- poj1166--The Clocks(高斯消元)
- java interface 的几点默认规则
- 由Docker的MySQL官方镜像配置的容器无法启动问题的解决办法
- &运算(与运算)和|运算(或运算)
- 网页浏览小记
- 遍历转换
- Map_纪中1281_dfs
- 动态规划:从新手到专家
- 线程同步
- 八皇后问题
- hdu 5918(KMP)