代码改变世界

docker 安装mysql-5.12

2023-05-12 15:27  ly772186472  阅读(74)  评论(0编辑  收藏  举报

 

 

 

 

 

 

 

 

docker run --restart always -p 3306:3306 --name mysql -v /usr/local/dockerdata/mysql/conf/my.cnf:/etc/mysql/my.cnf -v /usr/local/dockerdata/mysql/logs:/logs -v /usr/local/dockerdata/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e TZ=Asia/Shanghai -d mysql:5.7

  

解释说明:
–restart always
重启docker时自动重启相关容器

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

–name mysql
启动后的容器名称为mysql

-v /usr/local/dockerdata/mysql/conf/my.cnf:/etc/mysql/my.cnf
将主机/usr/local/dockerdata/mysql/conf/my.cnf文件挂载到容器的/etc/mysql/my.cnf(配置文件)

-v /usr/local/dockerdata/mysql/logs:/logs
将主机/usr/local/dockerdata/mysql/logs目录挂载到容器的/logs(日志)

-v /usr/local/dockerdata/mysql/data:/var/lib/mysql
将主机/usr/local/dockerdata/mysql/data目录挂载到容器的/var/lib/mysql(数据文件)

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

-e TZ=Asia/Shanghai
指定时区为亚洲-上海

-d mysql:5.7
后台运行

参考:

https://blog.csdn.net/Zuo19960127/article/details/121344367

如何设置主从复制?

 

 

一、拉取镜像

# 拉取镜像
docker pull mysql
 
# 或者
docker pull mysql:latest
#执行版本
docker pull mysql:5.7 # 以上两个命令是一致的,默认拉取的就是 latest 版本的 # 我们还可以用下面的命令来查看可用版本: docker search mysql

 二、查看镜像

使用以下命令来查看是否已安装了 mysql镜像

docker images

 三、运行镜像

docker run -p 3306:3306 --name mysql --restart=always --privileged=true \
-v /usr/local/mysql/log:/var/log/mysql \
-v /usr/local/mysql/data:/var/lib/mysql \
-v /usr/local/mysql/conf:/etc/mysql \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

 

======或者创建你喜欢的目录:

mkdir -p /home/mysql/log
mkdir -p /home/mysql/data
mkdir -p /home/mysql/conf

docker run -p 3306:3306 --name mysql --restart=always --privileged=true \
-v /home/mysql/log:/var/log/mysql \
-v /home/mysql/data:/var/lib/mysql \
-v /home/mysql/conf:/etc/mysql \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

问题:缺少conf.d
改为:
docker run -p 3306:3306 --name mysql --restart=always --privileged=true \
-v /home/mysql/log:/var/log/mysql \
-v /home/mysql/data:/var/lib/mysql \
-v /home/mysql/conf:/etc/mysql/conf.d \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

 


================================================

 问题一:Error starting userland proxy: listen tcp4 0.0.0.0:3306: bind: address already in use

  1. 然后我尝试了网上重启docker容器,"systemctl restart docker",然后还是无法解决。
  2. 如果跟我一样的话,先查看当前占用端口  "netstat -tanlp"
  3. 然后就杀死进程,我的mysql进程是1330  "kill 1330"
  4. 如果你用Docker重新构建Mysql数据库就行了,切记:你得保证你的容器中没有mysql,不然会报错的

 

 

 

 

五、查看容器内部

 创建mysql配置文件:my.cnf

cd /usr/local/mysql
 
ll
 
cd conf
 
vi my.cnf

在 my.cnf 文件中 写入如下内容:

 

[client]

default-character-set=utf8mb4

[mysql]

default-character-set=utf8mb4

[mysqld]

# 设置东八区时区
default-time_zone = '+8:00'

# 设置密码验证规则,default_authentication_plugin参数已被废弃

# 改为authentication_policy

#default_authentication_plugin=mysql_native_password
authentication_policy=mysql_native_password

# 限制导入和导出的数据目录
# 为空,不限制导入到处的数据目录;
# 指定目录,必须从该目录导入到处,且MySQL不会自动创建该目录;
# 为NULL,禁止导入与导出功能
#secure_file_priv=/var/lib/mysql
secure_file_priv=

init_connect='SET collation_connection = utf8mb4_0900_ai_ci'

init_connect='SET NAMES utf8mb4'

character-set-server=utf8mb4

collation-server=utf8mb4_0900_ai_ci

skip-character-set-client-handshake

skip-name-resolve

docker run -d -p 3307:3306 --privileged=true -v /home/mysql/conf/my.cnf:/etc/mysql/my.cnf -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql02 mysql:5.7

参数说明:

--privileged=true:容器内的root拥有真正root权限,否则容器内root只是外部普通用户权限

-v /home/mysql/conf/my.cnf:/etc/my.cnf:映射配置文件

-v /home/mysql/data:/var/lib/mysql:映射数据目录

5、设置mysql字符编码

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8

[mysqld]

init_connect='SET collation_connection = utf8_unicode_ci'

init_connect='SET NAMES utf8'

character-set-server=utf8

collation-server=utf8_unicode_ci

skip-character-set-client-handshake

skip-name-resolv

默认的鉴权方式,我们修改为mysql_native_password,不然的话连接会报错。因为在mysql8以后的默认加密方式改变了,由 mysql_native_password 改为了caching_sha2_password。这种加密凡是在客户端无法访问,客户端支持的是mysql_native_password 。我们先进行第七步。

七、重启mysql服务,使其配置生效

docker restart mysql

八、设置docker启动时启动mysql

docker update mysql --restart=always

九、重启mysql

docker restart mysql

十、授权远程访问

不进行授权直接登陆的话会报错的,如图

 错误内容:

Communications link failure

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
Connection refused: connect
Connection refused: connect

10.1 进入容器内部

docker exec -it mysql /bin/bash

 10.2 登陆mysql

mysql -u root -p

此时我们使用mysql客户端连接服务器是失败的,因为默认的root不具有远程连接的权限。

10.4 查看用户连接情况

select host, user, plugin,  authentication_string, password_expired from user;

 我们看到root用户只有localhost的连接权限

10.5 修改密码认证方式

ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';

ALTER USER root@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';

-- 刷新权限
FLUSH PRIVILEGES;

 

10.6 退出容器

 先输入exit退出mysql,再输入exit退出容器。