1.11.1 下载最新版mysql
docker pull mysql
1.11.2 查看镜像(软件包)
docker images
1.11.3 创建mysql容器,其中3306为本地mysql端口,8036为容器端口,也是外网访问端口
docker run -itd --name xizhao-mysql -p 8036:3306 --net xizhao -e MYSQL_ROOT_PASSWORD=root mysql
1.11.4 查看所有容器
docker ps -a
1.11.5 进入mysql容器
docker exec -it 4c04d93e5b18 /bin/bash
1.11.6登录mysql
mysql -h localhost -u root -p
回车,输入密码:root
1.11.7配置mysql表名忽略大小写
先登录mysql后,输入命令:
show variables like '%case_table%';
运行结果:
lower_case_table_names=1(说明是不区分大小写的)
lower_case_table_names=0(如上图为0说明区分大小写的)
安装vim
因为docker镜像内部没有带vim命令,所以需要手动安装,也可以利用docker cp命令从宿主机中复制过去
apt-get update
apt-get install vim
安装完后,切换到目录 /etc/mysql目录
vi my.cnf
保存后,重启mysql容器
docker restart 容器id
如果mysql容器重启失败,需要先把修改的配置文件拷贝到指定目录
docker cp xizhao-mysql:/etc/mysql/my.cnf /home
修改完配置后拷贝到docker容器中
docker cp /home/my.cnf xizhao-mysql:/etc/mysql/my.cnf
重启mysql容器
docker restart 4fafdf74e14c
最后发现mysql8.0版本只支持初始化的时候配置忽略表名大小写
lower_case_table_names can only be configured when initializing the server. Changing the lower_case_table_names setting after the server is initialized is prohibited.
LOWER_CASE_TABLE_NAMES只能在初始化服务器时配置。禁止在服务器初始化后更改LOWER_CASE_TABLE_NAMES设置