Docker配置Mysql并设置远程连接

一、环境

Linux、Docker、云服务器

二、操作

第一步:拉取镜像

默认拉取最新版docker pull mysql,指定版本docker pull mysql:版本号

[root@VM-4-15-centos ~]# docker pull mysql

拉取成功的话,输入docker images 会出现如下情况

[root@VM-4-15-centos local]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
mysql        latest    99afc808f15b   5 weeks ago   577MB

第二步:启动容器

首先开放安全组
在这里插入图片描述

输入docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name my_mysql mysql

[root@VM-4-15-centos local]# docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name my_mysql mysql
abac92103cc8412888bc49c15b99c20acd4d9a4817732793fa96ec03d326deea

参数解读

run -d							// 后台运行
-p 3306:3306					// 宿主机端口:容器内部端口    云服务器需要开放端口
-e MYSQL_ROOT_PASSWORD=123456	// 设置默认root用户密码为 123456
--name my_mysql					// 容器名称
mysql							// 镜像名

输入docker ps,运行成功返回如下

[root@VM-4-15-centos local]# docker ps
CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS                                                  NAMES
abac92103cc8   mysql     "docker-entrypoint.s…"   3 seconds ago   Up 2 seconds   0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   my_mysql

第三步:进入容器,设置远程连接

首先 docker exec -it my_mysql bash,进入容器

[root@VM-4-15-centos local]# docker exec -it my_mysql bash
bash-4.4#

登录mysqlmysql -uroot -p123456

[root@VM-4-15-centos local]# docker exec -it my_mysql bash
bash-4.4# mysql -uroot -p123456

进入成功返回如下

mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 8.1.0 MySQL Community Server - GPL

Copyright (c) 2000, 2023, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>

添加远程连接用户alter user 'root'@'%' identified with mysql_native_password by '123456';


mysql> alter user 'root'@'%' identified with mysql_native_password by '123456';
Query OK, 0 rows affected (0.01 sec)

如果安装的是Mysql5.6左右的版本,使用如下语句
添加远程连接用户GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
Query OK, 0 rows affected (0.00 sec)

刷新权限flush privileges;

mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)

测试连接
在这里插入图片描述

第四步:设置自启动

现在当我们重启服务器,数据库远程连接时会出现
在这里插入图片描述

这是因为我们并没有设置开机自启动,服务器每次重启需要我们手动启动mysql容器docker start 容器id。但是每次都手动启动未免也太麻烦了。
设置mysql容器自启动docker update --restart=always 容器id

[root@VM-4-15-centos ~]# docker update --restart=always 60b0da3e5819
60b0da3e5819

现在服务器重启时,就不需要我们再手动启动了
重启服务器,测试连接,成功
在这里插入图片描述

### 配置 Docker 中的 MySQL 实现远程连接 为了使 MySQL 容器能够接受来自外部主机的连接请求,在创建和配置 MySQL 容器时需要注意几个方面。这不仅涉及到了解如何正确地启动容器,还需要熟悉一些重要的参数设置。 当通过 Docker 创建一个新的 MySQL 服务实例时,可以指定端口映射选项 `-p` 来暴露数据库的服务端口至宿主机上[^1]。例如: ```bash sudo docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -p 3306:3306 -d mysql:tag ``` 上述命令会将容器内部的 3306 端口绑定到本地机器上的相同端口号,且指定了根用户的密码 `my-secret-pw` 和使用的 MySQL 版本标签 `tag`。 为了让其他设备能访问这个 MySQL 数据库,则需要进一步调整其安全策略来授予特定 IP 地址或所有地址 (`%`) 对应用户账号的操作权限。可以通过执行 SQL 命令完成此操作[^4]: 进入正在运行中的 MySQL 容器打开交互式的 Bash shell: ```bash sudo docker exec -it some-mysql bash ``` 接着切换到 MySQL Shell 下面进行授权处理: ```sql mysql> USE mysql; Database changed mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'your_password'; Query OK, 0 rows affected (0.00 sec) mysql> FLUSH PRIVILEGES; Query OK, 0 rows affected (0.00 sec) ``` 这里 `'root'@'%'` 表示允许任何地方发起对该数据库 root 用户的身份验证;而 `FLUSH PRIVILEGES;` 是用来刷新存储于缓存里的权限信息以便立即生效新设定好的规则集。 除了以上提到的内容外,还应该考虑持久化保存重要资料以及优化性能等方面的问题。比如利用 Docker 卷功能把实际的数据文件夹挂载出来防止因意外删除容器而导致丢失数据的情况发生[^5]。 另外值得注意的是,虽然开放了远程访问的功能,但在生产环境中应当谨慎对待安全性问题,建议只给予信任源有限度内的控制权而不是无差别赋予全部权利给所有人。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值