|
|
---
|
|
|
icon: edit
|
|
|
date: 2021-09-15
|
|
|
category:
|
|
|
- Docker
|
|
|
tag:
|
|
|
- Docker
|
|
|
- mysql
|
|
|
headerDepth: 5
|
|
|
---
|
|
|
|
|
|
|
|
|
# Docker 安装mysql8.0
|
|
|
### 一、写在前面
|
|
|
今天自己原本的mysql服务配置出了问题,刚好自己接触了容器技术,就想着自己使用docker重新部署一个mysql服务。
|
|
|
|
|
|
### 二、下载步骤
|
|
|
首先要获取mysql镜像(可以通过官网下载或者从公司的仓库获取),下面演示从官网下载步骤
|
|
|
|
|
|
#### 2.1 docker search mysql,可以看到搜索的结果,这个结果是按照一定的星级评价规则排序的。
|
|
|
![image.png](/upload/2021/09/image-6acf16e6457a48e49d80b7b1e6561073.png)
|
|
|
#### 2.2 docker pull mysql 拉取一个合适版本的mysql到本地服务器
|
|
|
|
|
|
### 三、启动镜像
|
|
|
```txt
|
|
|
-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
|
|
|
```
|
|
|
命令行如下:
|
|
|
```shell
|
|
|
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
|
|
|
```
|
|
|
|
|
|
### 四、局域网无法访问数据库的方法
|
|
|
```sql
|
|
|
create user 'wanghao'@'%' identified with mysql_native_password by 'Wh*123456';
|
|
|
grant all privileges on *.* to 'wanghao'@'%';
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
注意:这里platform可以任意命名,表示赋予这个账户的权限,这里是赋予所有的权限
|
|
|
```sql
|
|
|
update user set host='%' where user='root';
|
|
|
alter user 'root'@'%' identified with mysql_native_password by 'root';
|
|
|
```
|
|
|
刷新权限:
|
|
|
```sql
|
|
|
mysql> flush privileges;
|
|
|
Query OK, 0 rows affected (0.00 sec)
|
|
|
```
|
|
|
|
|
|
### 五、表名大小写问题
|
|
|
![image.png](/upload/2021/10/image-c13812355983466f952a08f36c406b63.png)
|
|
|
|
|
|
MySQL 上了 8 后,在 Linux 端,对于 lower_case_table_names 参数,只能在初始化的时候设置了,若初始化的时候没设置,那后面就傻愣愣了
|
|
|
|
|
|
示例:
|
|
|
|
|
|
当前本地已有环境设置为 lower_case_table_names = 1 了,将 lower_case_table_names 修改为 0 会发生什么。
|
|
|
|
|
|
测试版本
|
|
|
```shell
|
|
|
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
|
|
|
|
|
|
查看错误日志
|
|
|
```log
|
|
|
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](https://pic4.zhimg.com/v2-7f96160724c66388120bafc3ff3f6d1b_r.jpg)
|
|
|
|
|
|
所以,除非你是安装在 windows上或者可以确保开发人员实行规范建表等操作,不然就在初始化配置my.cnf时候就将 lower_case_table_names = 1 配置上去吧
|
|
|
|
|
|
#### docker 部署要大小写忽略只能 运行容器命令的时候加上了
|
|
|
```shell
|
|
|
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
|
|
|
``` |