1. 递归创建映射路径
mkdir -p D:docker\mysql8\data D:docker\mysql8\logs D:docker\mysql8\conf
2.在conf目录下创建my.cnf文件 内容如下:
[mysqld]
pid-file=/var/run/mysqld/mysqld.pid
socket=/var/run/mysqld/mysqld.sock
datadir=/var/lib/mysql
secure-file-priv= NULL
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。
max_connect_errors=10
# 服务端使用的字符集默认为utf8mb4
character-set-server=utf8mb4
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8mb4
#设置不区分大小写
# 必须在安装好MySQL后 修改mySQL配置文件设置为不敏感,一旦启动后,再设置是无效的,而且启动报错;
# 如果已经晚了,那必须把MySQL数据库文件全部 删除,修改配置文件再启动。
#lower_case_table_names=1
3.运行如下命令:
docker run -it -v /D/docker/mysql8/data:/var/lib/mysql -v /D/docker/mysql8/conf/:/etc/mysql/ -v /D/docker/mysql8/logs:/var/log/mysql --restart=always --name loc-mysql8.0 -e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306 -d mysql --lower_case_table_names=1
参数顺序一定要对,--lower_case_table_names=1要加在镜像名后面,镜像名前面是参数,后面是mysql配置,不然会报错
4.docker exec -it loc-mysql8.0 bash
5.登录并执行
mysql -u root -p
update use set host='%';
ALTER user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
FLUSH PRIVILEGES;
备注:host为 % 表示不限制ip localhost表示本机使用 plugin非mysql_native_password 则需要修改密码
问题:
1.mysql大小写不敏感的配置lower_case_table_names=1 开始放到my.cnf里面 在第五步操作时 报这个参数无效 后来把它放到了启动命令最后面 问题解决