docker - 使用centos/mysql-56-centos7,启动数据库报权限问题
本文介绍了docker - 使用centos/mysql-56-centos7,启动数据库报权限问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
如果执行docker run -u 0 ***
报错是
2017-08-10 20:00:51 66 [ERROR] Fatal error: Please read "Security" section of the manual to find out how to run mysqld as root!
如果执行
docker run -d --name mysql_test -e TZ="Asia/Shanghai" -v /etc/localtime:/etc/localtime:ro -v /etc/mysql:/etc/opt/rh/rh-mysql56/my.cnf.d -e MYSQL_ROOT_PASSWORD=abc123 -p 3306 centos/mysql-56-centos7
报错是
/usr/bin/run-mysqld: line 14: /etc/my.cnf.d/base.cnf: Permission denied
其中
/etc/mysql
被尝试加过: chown -R mysql:mysql
权限
网上的一些方法也试过,没生效,求救
试了下官方5.6.34的镜像,不使用自定义cnf文件的话是ok的;
使用-v /etc/mysql:/etc/mysql/conf.d
,启动容器后是existed状态,没有报错了
docker logs显示:
Initializing database
2017-08-11 03:09:18 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2017-08-11 03:09:18 0 [Note] Ignoring --secure-file-priv value as server is running with --bootstrap.
2017-08-11 03:09:18 0 [Note] /usr/sbin/mysqld (mysqld 5.6.37-log) starting as process 36 ...
2017-08-11 03:11:04 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2017-08-11 03:11:04 0 [Note] mysqld (mysqld 5.6.37-log) starting as process 1 ...
解决方案
-u
是制定容器内部用户,没必要,默认已经指定mysql
2.我建议不要随意挂在到其他位置,在挂载其他位置的时候一定记得root方式chown
官方的entrypoint
3.可以参考
注意,请使用空文件夹存储data数据,不然可能你之前的版本问题不兼容自动生成的文件
mysql-db:
image: mysql:5.7
volumes:
- /etc/localtime:/etc/localtime:ro
- ./data/mysql:/var/lib/mysql:rw
- ./logs/mysql:/var/lib/mysql-logs:rw
- ./dockerfiles/mysql/conf.d:/etc/mysql/conf.d:ro
restart: always
ports:
- "3306:3306"
environment:
MYSQL_ROOT_PASSWORD: zhaojun
MYSQL_DATABASE: package_v1
MYSQL_USER: zhaojun
MYSQL_PASSWORD: zhaojun
这篇关于docker - 使用centos/mysql-56-centos7,启动数据库报权限问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文