一、拉取镜像
# 拉取镜像 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:latest
======或者创建你喜欢的目录:
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
================================================
五、查看容器内部
创建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退出容器。
标签:--,character,mysql,home,docker,password,安装 From: https://www.cnblogs.com/liyanxi/p/17394203.html