docker部署mysql无法远程连接2003解决

背景

最近使用 docker,故将数据库和程序都用 docker 来一遍。在部署 mysql 时,本地连接访问正常,但是远程访问却提示2003或超时。网上找了一圈下来,发现全是一些复制粘贴的,更有甚者连字母都拼不全的。按照那个思路,应该离入门到放弃不远了。故特意写这篇文章,帮大家去真正的解决问题。

1. docker 安装 mysql8 版本

# docker 中下载 mysql
docker pull mysql

#启动
docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql

#进入容器
docker exec -it mysql bash

#登录mysql
mysql -u root -p
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

#添加远程登录用户
CREATE USER 'admin'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
GRANT ALL PRIVILEGES ON *.* TO '123456'@'%';

2. 检查端口是否通信

利用 telnet [ip] [port]命令进行IP和端口检查

3. 检查防火墙

centos下

systemctl  status firewalld
systemctl  stop firewalld

ubuntu下

sudo ufw status
sudo  ufw enable|disable

4. 检查监听端口

使用netstat命令检查3306端口是否监听状态

netstat -nlt  | grep 3306

 可以看出,这里采用的是 ipv4 和 ipv6 通信

5. 检查 ipv4 和 ipv6

执行下述代码,查看他们的状态

sysctl net.ipv6.conf.all.forwarding
sysctl net.ipv4.conf.all.forwarding

如果得到 net.ipv4.conf.all.forwarding=0,那么需要将对应的值修改为1

sysctl net.ipv4.conf.all.forwarding=1

6. 重启 docker 服务

sudo systemctl restart docker

最后,连接一下mysql

mysql -h xxxx -u root -p

 至此,无法远程连接的问题已经解决了。

### 配置 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]。 另外值得注意的是,虽然开放了远程访问的功能,但在生产环境中应当谨慎对待安全性问题,建议只给予信任源有限度内的控制权而不是无差别赋予全部权利给所有人。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值