Docker安装MySQL

一、拉取镜像

# 拉取镜像
docker pull mysql

# 或者
docker pull mysql:latest

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

 二、查看镜像

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

docker images

 

  三、运行镜像

docker run --privileged=true \
-p 3306:3306 --name mysql \
-v /opt/docker/mysql/log:/var/log/mysql \
-v /opt/docker/mysql/data:/var/lib/mysql \
-v /opt/docker/mysql/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=mysql-root123456 \
-d mysql:5.7

参数说明:

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

--name mysql:创建的容器名称

--restart=always:总是跟随docker启动

--privileged=true:获取宿主机root权限
-v /opt/docker/mysql/log:/var/log/mysql:映射日志目录,宿主机:容器
-v /opt/docker/mysql/data:/var/lib/mysql:映射数据目录,宿主机:容器
-v /opt/docker/mysql/conf:/etc/mysql:映射配置目录,宿主机:容器
-v /etc/localtime:/etc/localtime:ro:让容器的时钟与宿主机时钟同步,避免时区的问题,ro是read only的意思,就是只读。
-e MYSQL_ROOT_PASSWORD==mysql-root123456:指定mysql环境变量,root用户的密码为=mysql-root123456

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

  四、查看正在运行的容器

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

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

docker logs -f mysql

五、设置docker启动时启动mysql

docker update mysql --restart=always

六、查看容器内部

docker exec -it mysql /bin/bash

七、登陆mysql

mysql -u root -p

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

7.1、 查看用户连接情况

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

 我们看到root用户有远程连接的权限。如果没有就放开

ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';
 
ALTER USER root@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
 
-- 刷新权限
FLUSH PRIVILEGES;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

刘贤松

一本万利

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

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

打赏作者

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

抵扣说明:

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

余额充值