运维系列(亲测有效):centos7中docker安装并创建运行mysql8.0




前言

安装docker 参考:运维系列:docker安装并拉取镜像(missing signature key、Error response from daemon、x509: certificate has expired o)

docker run --name=mysql01 -e MYSQL_ROOT_PASSWORD=123456asdfgh! -p 3306:3306 -d mysql

虽然 docker 安装 mysql 不是一个很好的方案,但是为了个人使用方便,使用 docker 安装 mysql 还是没什么问题的。

本文为了方便,我们直接通过yum方式安装。所以,我们在安装之前需要电脑可以联网,不然我们这种方式是安装不了的。

当然,你也可以自行下载mysql镜像,然后再通过 docker 安装,不过这不在本文的讨论范围。

一. 安装docker

这块给一个简略版

yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
yum install docker-ce-17.12.0.ce
systemctl enable docker
systemctl start docker

在这里插入图片描述
在这里插入图片描述

vim /etc/docker/daemon.json
{
"registry-mirrors":["https://b9pmyelo.mirror.aliyuncs.com"]
}


二、拉取镜像

# 拉取镜像
docker pull mysql
 
# 或者
docker pull mysql:latest
 
# 以上两个命令是一致的,默认拉取的就是 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

命令解决:

  • -p 3306:3306:指定宿主机端口与容器端口映射关系

  • –name mysql:创建的容器名称

  • –restart=always:总是跟随docker启动

  • –privileged=true:获取宿主机root权限

  • -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:让容器的时钟与宿主机时钟同步,避免时区的问题,ro是read only的意思,就是只读。

  • -e MYSQL_ROOT_PASSWORD=123456:指定mysql环境变量,root用户的密码为123456

  • -d mysql:latest:后台运行mysql容器,版本是latest。

或者使用下面的命令:

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

五、查看正在运行的容器

# 查看正在运行的容器
docker ps
# 查看所有的docker容器
docker ps -a

这个时候如果显示的是up状态,那就是启动成功了。如果是restarting,说明是有问题的。我们可以查看日志:

docker logs -f mysql

可能会发现:

Failed to access directory for --secure-file-priv. Please make sure that dir

此时如果我们执行第六步也会报错:

Error response from daemon: Container xxx is restarting, wait until the cont。。。

此时我们需要执行第七步。

六、查看容器内部

docker exec -it mysql /bin/bash

七、修改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

默认的鉴权方式,我们修改为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

11.1 进入容器内部

docker exec -it mysql /bin/bash

11.2 登陆mysql

mysql -u root -p

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

在这里插入图片描述

上面的密码不要输入,直接回车进入。

11.3 选择数据库

show databases;
use mysql;

在这里插入图片描述
不要忘记最后的分号。

11.4 查看用户连接情况

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

在这里插入图片描述
我们看到root用户只有localhost的连接权限。

11.5 修改密码认证方式

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

– 刷新权限

FLUSH PRIVILEGES;

11.6 退出容器

exit

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

此时,我们通过客户端工具就可以连接mysql了。

十二. 问题

1. 底下评论

1. 第四步后会出错。

2023-04-11 09:52:07+08:00 [ERROR] [Entrypoint]: mysqld failed while attempting to check config
command was: mysqld --verbose --help --log-bin-index=/tmp/tmp.EBz70EUuv4
mysqld: Can't read dir of '/etc/mysql/conf.d/' (OS errno 2 - No such file or directory)
修改命令:
先删除

1: docker stop mysql
2: docker rm mysql
3: docker run -p 3306:3306 --name mysql --restart=always --privileged=true -v /docker/mysql/log:/var/log/mysql -v /docker/mysql/data:/var/lib/mysql -v /etc/localtime:/etc/localtime:ro -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

区别: 命令行3去掉了
-v /docker/mysql/conf:/etc/mysql

2. 可通过这个挂载配置文件

-v /docker/mysql/my.cnf:/etc/my.cnf

3. 登录mysql 使用命令:

mysql -h localhost -u root -p

密码:123456
否则会报

Access denied for user 'root'@'localhost' (using password: YES)

2. 作者互动

  • 你的意思是不要-v /docker/mysql/conf:/etc/mysql这个吗?
    我记得有这个也不影响的吧!我的文章都是自己验证过的,第四步查看状态当时确实有问题。第四步的问题,去掉这个就可以了,你是这个意思吗?

  • 改成
    -v /docker/mysql/conf:/etc/mysql/conf.d
    就可以,后面加一个conf.d的文件夹,
    我刚试过了,确实解决了

3. 底下评论

[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
[mysqld]
default-time_zone = '+8:00'
authentication_policy=mysql_native_password
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 -p 3306:3306 --name mysql --restart=always --privileged=true \
-v /mysql/log:/var/log/mysql \
-v /mysql/data:/var/lib/mysql \
-v /mysql/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0

3. 作者互动

  • 需要先创建log\data\conf这几个文件夹吗

  • 不需要

  • 有的需要,我不创建就会报错,找不到此文件夹。

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

  • 不同版本的docker镜像对应的配置文件地址不同,有的
    /etc/mysql,有的/etc/mysql/conf.d/

  • 应该是的,我没有关注过这个问题

4. 底下评论

执行 :

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

之前需要加一句 :

update user set host='%' where user=root;

其他没啥问题 .

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

这个破版本镜像真害人,没su,apt,yum,nano,vi, 啥也没用 怎么做啊?哎!!!

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘123456’;
create user ‘root’@‘%’ identified by ‘123456’;
grant all privileges on . TO ‘root’@‘%’ with grant option;
flush privileges;







北冥牧之

Docker安装MySQL

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

坦笑&&life

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值