docker安装mysql8.0.20过程

一、说明

mysql版本很多,这是8.0.20的安装过程,包括安装容器,挂载文件夹,远程访问。

二、拉取MySQL镜像

接下来,我们需要拉取MySQL的最新版本镜像。执行以下命令:

复制代码
docker pull mysql:8.0.20

可以使用以下命令查看已下载的MySQL镜像:

复制代码
docker images

三、启动

ini 复制代码
docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0.20

四、复制

将容器内mysql的数据配置复制到本机,后面那个路径就是你想要映射的文件地址

bash 复制代码
docker cp mysql:/etc/mysql /root/mysql8.0.20

建议授权一下文件夹 防止权限问题异常, 进入到root目录

bash 复制代码
chmod 777 mysql8.0.20

五、删除旧容器

arduino 复制代码
docker stop mysql && docker rm mysql

六、启动MySQL容器

使用docker run命令启动MySQL容器,并将端口映射为13422,同时将数据和日志映射到本地磁盘:

bash 复制代码
docker run  -p 3306:3306  --name mysql8  --privileged=true  --restart unless-stopped  -v /root/mysql8.0.20/mysql:/etc/mysql  -v /root/mysql8.0.20/logs:/logs  -v /root/mysql8.0.20/data:/var/lib/mysql  -v /root/mysql8.0.20/mysql/mysql-files:/var/lib/mysql-files  -v /etc/localtime:/etc/localtime  -e MYSQL_ROOT_PASSWORD=123456  -d mysql:8.0.20

修改本地登录

进入容器并登录,你会发现登录不了

进入mysql8容器

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

登录

mysql -uroot -p ,输入密码

修改配置文件

如果发现登录不了. 输入 exit 先退出容器,如果上面本地容器登录正常就跳过这步

进入 /root/mysql8.0.20 文件, 编辑 my.cnf, 在[mysqld]增加一行 skip_grant_tables 此时mysql是无密码状态

复制代码
docker restart mysql8

七、配置远程访问

为了实现远程访问,我们需要进入MySQL容器并修改相关配置。

进入数据库

css 复制代码
mysql> use mysql  
Reading table information for completion of table and column names  
You can turn off this feature to get a quicker startup with -A

Database changed

查看表

sql 复制代码
mysql> show tables;  
+---------------------------+  
| Tables_in_mysql |  
+---------------------------+  
| columns_priv |  
| component |  
| db |  
| default_roles |  
| engine_cost |  
| func |  
| general_log |  
| global_grants |  
| gtid_executed |  
| help_category |  
| help_keyword |  
| help_relation |  
| help_topic |  
| innodb_index_stats |  
| innodb_table_stats |  
| password_history |  
| plugin |  
| procs_priv |  
| proxies_priv |  
| role_edges |  
| server_cost |  
| servers |  
| slave_master_info |  
| slave_relay_log_info |  
| slave_worker_info |  
| slow_log |  
| tables_priv |  
| time_zone |  
| time_zone_leap_second |  
| time_zone_name |  
| time_zone_transition |  
| time_zone_transition_type |  
| user |  
+---------------------------+  
33 rows in set (0.00 sec)

查看用户表

sql 复制代码
mysql> select host,user,plugin from user;  
+-----------+------------------+-----------------------+  
| host | user | plugin |  
+-----------+------------------+-----------------------+  
| localhost | mysql.infoschema | caching_sha2_password |  
| localhost | mysql.session | caching_sha2_password |  
| localhost | mysql.sys | caching_sha2_password |  
| localhost | root | caching_sha2_password |  
+-----------+------------------+-----------------------+  
4 rows in set (0.01 sec)

因为 caching_sha2_password ,所以使用密码登录是不行的,需要修改

  1. 修改密码认证方式

执行以下命令将root用户的密码认证方式改为'mysql_native_password'

sql 复制代码
ALTER USER 'root'@'%' IDENTIFIED WITH 'mysql_native_password' BY 'pwd20250612';

可以自己设置密码

  1. 授予远程访问权限

执行以下命令授予root用户从任何主机远程访问的权限:

sql 复制代码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
  1. 刷新权限
ini 复制代码
FLUSH PRIVILEGES;
  1. 退出MySQL和容器
bash 复制代码
exit
exit

服务器防火墙设置

为了允许远程访问,需要在服务器上开放相应的端口。

测试远程连接

使用MySQL客户端工具连接成功

相关推荐
步行cgn4 分钟前
ES6 核心语法手册
前端·javascript·es6
sorryhc18 分钟前
React SSR同构渲染方案是什么?
前端·javascript·next.js
护国神蛙1 小时前
给你一个页面如何定时刷新
前端·javascript·浏览器
一直游到海水变蓝丿1 小时前
el-select下拉框 添加 el-checkbox 多选框
前端·javascript·vue.js
阿奇__2 小时前
element 跨页选中,回显el-table选中数据
前端·vue.js·elementui
谢尔登2 小时前
【React】SWR 和 React Query(TanStack Query)
前端·react.js·前端框架
断竿散人2 小时前
专题一、HTML5基础教程-Viewport属性深入理解:移动端网页的魔法钥匙
前端
3Katrina2 小时前
理解Promise:让异步编程更优雅
前端·javascript
星之金币2 小时前
关于我用Cursor优化了一篇文章:30 分钟学会定制属于你的编程语言
前端·javascript
天外来物2 小时前
实战分享:用CI/CD实现持续部署
前端·nginx·docker