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
- 然后我尝试了网上重启docker容器,"systemctl restart docker",然后还是无法解决。
- 如果跟我一样的话,先查看当前占用端口 "netstat -tanlp"
- 然后就杀死进程,我的mysql进程是1330 "kill 1330"
- 如果你用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退出容器。