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退出数据库客户端,退出容器,本地连接测试即可。

相关推荐
pengyi8710159 分钟前
私网IP映射公网基础原理,搭配代理IP远程访问入门
linux·服务器·网络
mseaspring36 分钟前
一款用于监控跨多台主机 Docker 容器的实时终端
运维·docker·容器
深圳市九鼎创展科技1 小时前
MT8883 vs RK3588 开发板全面对比:选型与场景落地指南
大数据·linux·人工智能·嵌入式硬件·ubuntu
NineData1 小时前
NineData 亮相香港国际创科展 InnoEX 2026,以 AI 加速布局全球市场
运维·数据库·人工智能·ninedata·新闻资讯·玖章算术
考虑考虑1 小时前
SQL语句中的order by可能造成时间重复
数据库·后端·mysql
heimeiyingwang2 小时前
【架构实战】Kubernetes日志收集:EFK/Loki架构
容器·架构·kubernetes
RisunJan2 小时前
Linux命令-ngrep(方便的数据包匹配和显示工具)
linux·运维·服务器
.千余2 小时前
【Linux】基本指令3
linux·服务器·开发语言·学习
热爱Liunx的丘丘人2 小时前
Ansible-doc及常用模块
linux·运维·服务器·ansible
SPC的存折3 小时前
D在 Alpine 容器中手动搭建 Discuz 全攻略(包含镜像一键部署脚本,可直接用)
linux·数据库·mysql·缓存