一、写在前面

今天自己原本的mysql服务配置出了问题,刚好自己接触了容器技术,就想着自己使用docker重新部署一个mysql服务。

二、下载步骤

首先要获取mysql镜像(可以通过官网下载或者从公司的仓库获取),下面演示从官网下载步骤

2.1 docker search mysql,可以看到搜索的结果,这个结果是按照一定的星级评价规则排序的。

image.png

2.2 docker pull mysql 拉取一个合适版本的mysql到本地服务器

三、启动镜像

-p 3307:3306:将容器的3307端口映射到主机的3306端口;

-v $PWD/mysql:/var/lib/mysql:将主机当前目录下的/mysql挂载到容器的/var/lib/mysql;

-e MYSQL_ROOT_PASSWORD=123456:初始化root用户的密码;

–name 给容器命名,test_mysql
-d 表示刚下载的镜像id

命令行如下:

docker run \
-p 3307:3306 \
--name mysql_3307 \
--privileged=true \
-v /wanghao/mysql_3307/conf.d:/etc/mysql/conf.d \
-v /wanghao/mysql_3307/logs:/logs \
-v /wanghao/mysql_3307/data:/var/lib/mysql \
-v /etc/localtime:/etc/localtime \
-v /wanghao/mysql_3307/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql

四、局域网无法访问数据库的方法

create user 'wanghao'@'%' identified with mysql_native_password by 'Wh*123456';
grant all privileges on *.* to 'wanghao'@'%';

注意:这里platform可以任意命名,表示赋予这个账户的权限,这里是赋予所有的权限

update user set host='%' where user='root';
alter user 'root'@'%' identified with mysql_native_password by 'root';

刷新权限:

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

五、表名大小写问题

image.png

MySQL 上了 8 后,在 Linux 端,对于 lower_case_table_names 参数,只能在初始化的时候设置了,若初始化的时候没设置,那后面就傻愣愣了

示例:

当前本地已有环境设置为 lower_case_table_names = 1 了,将 lower_case_table_names 修改为 0 会发生什么。

测试版本

root [(none)]> select version();
+-----------+
| version() |
+-----------+
| 8.0.18    |
+-----------+
1 row in set (0.00 sec)

lower_case_table_names不是动态参数,将my.cnf 中 lower_case_table_names 改为 0

重启 mysql

查看错误日志

2020-09-22T17:16:49.781973+08:00 1 [ERROR] [MY-011087] [Server] Different lower_case_table_names settings for server ('0') and data dictionary ('1').
2020-09-22T17:16:49.782401+08:00 0 [ERROR] [MY-010020] [Server] Data Dictionary initialization failed.
2020-09-22T17:16:49.782620+08:00 0 [ERROR] [MY-010119] [Server] Aborting

官方是这么说的

地址:https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html
image.png

所以,除非你是安装在 windows上或者可以确保开发人员实行规范建表等操作,不然就在初始化配置my.cnf时候就将 lower_case_table_names = 1 配置上去吧

docker 部署要大小写忽略只能 运行容器命令的时候加上了

docker run \
-p 3307:3306 \
--name mysql_3307 \
--privileged=true \
-v /wanghao/mysql_3307/conf.d:/etc/mysql/conf.d \
-v /wanghao/mysql_3307/logs:/logs \
-v /wanghao/mysql_3307/data:/var/lib/mysql \
-v /etc/localtime:/etc/localtime \
-v /wanghao/mysql_3307/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql --lower-case-table-names=1