docker安装mysql8

上一篇提到了docker安装mysql5.7和mysql8有所不同,这一篇说一下mysql8的安装

1、宿主机创建映射目录

bash 复制代码
mkdir -p /data/mysql8/log
mkdir -p /data/mysql8/data
mkdir -p /data/mysql8/conf

这里我放在了/data/mysql8目录下

2、拉取mysql镜像

bash 复制代码
docker pull mysql:8.0.21

查看镜像

bash 复制代码
docker images

3、创建运行实例

bash 复制代码
docker run -p 13306:3306 --name mysql8 \
-v /data/mysql8/log:/var/log/mysql \
-v /data/mysql8/data:/var/lib/mysql \
-v /data/mysql8/conf:/etc/mysql \
--privileged=true \
-d mysql:8.0.21

参数说明:

  • -p 13306:3306 将容器的3306端口映射到主机的13306端口
  • -v /mysql/mysql8/conf:/etc/mysql 将配置文件夹挂载到主机
  • -v /mysql/mysql8/log:/var/log/mysql 将日志文件夹挂载到主机
  • -v /mysql/mysql8/data:/var/lib/mysql 将数据文件夹挂载到主机

4、查看运行容器

bash 复制代码
docker ps

5、设置密码

一般此时容器就可以顺利启动起来了,但是和mysql5.7不同的是,这次启动容器没有设置密码,因为多次试验后,即使使用了-e MYSQL_ROOT_PASSWORD='123456'也不会生效,需要进入容器内部设置初始化密码,有使用compose或者swarm部署的,可以参考下一章集群部署

执行

bash 复制代码
docker exec -it mysql8 bash

进入容器内部

执行

bash 复制代码
mysqladmin -u root password '123456'

另外设置完密码后,此时的root用户只能localhost访问,有需要远程访问的小伙伴可以继续执行

bash 复制代码
mysql -uroot -p
# 这里输入刚刚设置的密码

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

执行完后执行exit退出数据库客户端,退出容器,本地连接测试即可。

相关推荐
猪脚踏浪1 小时前
linux 拷贝文件或目录到指定的位置
linux
云技纵横1 小时前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神2 小时前
三、用户与权限管理
数据库·mysql
大树8817 小时前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠17 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质18 小时前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
bush418 小时前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行52018 小时前
Linux 11 动态监控指令top
linux
Inhand陈工19 小时前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信