一、说明
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 ,所以使用密码登录是不行的,需要修改
- 修改密码认证方式:
执行以下命令将root用户的密码认证方式改为'mysql_native_password'
:
sql
ALTER USER 'root'@'%' IDENTIFIED WITH 'mysql_native_password' BY 'pwd20250612';
可以自己设置密码
- 授予远程访问权限:
执行以下命令授予root用户从任何主机远程访问的权限:
sql
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
- 刷新权限:
ini
FLUSH PRIVILEGES;
- 退出MySQL和容器:
bash
exit
exit
服务器防火墙设置
为了允许远程访问,需要在服务器上开放相应的端口。
测试远程连接
使用MySQL客户端工具连接成功