如果执行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
是制定容器内部用户,没必要,默认已经指定mysql2.我建议不要随意挂在到其他位置,在挂载其他位置的时候一定记得root方式chown

官方的entrypoint

3.可以参考
注意,请使用空文件夹存储data数据,不然可能你之前的版本问题不兼容自动生成的文件