使用docker安装mysql 8.0

打开命令行,运行

复制代码
ocker pull mysql:8.0.21

下载成功后,可以看到

进入cmd,输入

复制代码
docker run -d --name mysql -p 3306:3306 -v /root/mysql/data:/var/lib/mysql -v /root/mysql/config:/etc/mysql/conf.d  -e MYSQL_ROOT_PASSWORD=abc123456 mysql:8.0.21 --lower_case_table_names=1

-d: 这个标志表示以守护进程(detached)模式运行容器,即容器将在后台运行。

--name mysql: 给容器指定一个名称为 "mysql",方便后续管理和引用该容器。

-p 3306:3306: 端口映射,将宿主机的 3306 端口映射到容器内部的 3306 端口。这样外部应用可以通过宿主机的 3306 端口访问到 MySQL 服务。

-v /root/mysql/data:/var/lib/mysql : 数据卷挂载,将宿主机目录 /root/mysql/data 映射到容器内的 /var/lib/mysql 目录,用于持久化存储 MySQL 的数据文件。

-v /root/mysql/config:/etc/mysql/conf.d : 另一个数据卷挂载,将宿主机上的 /root/mysql/config 目录挂载到容器内的 /etc/mysql/conf.d 目录,以便于自定义 MySQL 配置文件。

-e MYSQL_ROOT_PASSWORD=abc123456: 设置环境变量,用以初始化 MySQL 的 root 用户密码为 "abc123456"。

mysql:8.0.21: 指定要运行的 Docker 镜像名称和版本,这里是 MySQL 8.0.21 版本。

--lower_case_table_names=1: 这是一个启动时传递给 MySQL 服务器的选项,设置它为 1 表示 MySQL 将把所有数据库表名转换为小写,这有助于跨不同操作系统的兼容性。

也可以用可视化工具启动

启动后,可以通过cmd查看

也可以通过可视化工具

接下来,需要进入容器,修改一些配置

复制代码
docker exec -it mysql /bin/bash

mysql -uroot -p

abc123456(手动输入密码)

修改支持mysql远程链接

复制代码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY "abc123456";

刷新数据库

复制代码
flush privileges;

至此,安装完成

使用Navicat成功连接

相关推荐
小萌新上大分5 小时前
mysql主从复制搭建
mysql·mysql主从复制·mysql主从复制配置·mysql主从复制的搭建·mysql主从复制的原理·mysql安装入门
古城小栈5 小时前
Docker 多阶段构建:Go_Java 镜像瘦身运动
java·docker·golang
华仔啊5 小时前
这 10 个 MySQL 高级用法,让你的代码又快又好看
后端·mysql
Knight_AL7 小时前
MySQL 中 UPDATE 语句的执行过程全解析
数据库·mysql
梁萌8 小时前
ShardingSphere分库分表实战
数据库·mysql·实战·shardingsphere·分库分表
川石课堂软件测试8 小时前
Mysql中触发器使用详详详详详解~
数据库·redis·功能测试·mysql·oracle·单元测试·自动化
程序员游老板9 小时前
基于SpringBoot3_vue3_MybatisPlus_Mysql_Maven的社区养老系统/养老院管理系统
java·spring boot·mysql·毕业设计·软件工程·信息与通信·毕设
专家大圣10 小时前
摆脱局域网束缚!Neko+cpolar 让跨网共享成日常
服务器·网络·docker·内网穿透·cpolar
Haooog11 小时前
Docker面试题(不定时更新)
java·docker·面试
soft200152511 小时前
从一次增删改操作开始:彻底理解 MySQL Buffer Pool 的地位与作用
数据库·mysql