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

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

  • 11
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Docker MySQL 是在 Docker 容器中运行的 MySQL 数据库。相比在本地安装 MySQL Server,使用 Docker 运行 MySQL 更快、更容易。您可以通过在 Docker 上运行 MySQL 来进行测试和其他任务。有关更多信息,您可以查看 Docker Hub 上的 MySQL 页面和官方 MySQL 手册。 如果您想在 Docker 上使用 MySQL,以下是一些步骤: 1. 创建一个名为 "mysql-data" 的卷,用于存储 MySQL 的数据。 2. 将该卷附加到新创建的 MySQL 容器。 3. 运行 MySQL Docker 容器。 4. 您可以使用 "docker ps" 命令来查看正在运行的容器,确保 MySQL 正在运行。 5. 您可以使用 "docker exec -it mysql /bin/bash" 命令进入 MySQL 容器内部,进行进一步的操作。 请注意,以上命令中,冒号前面的部分是主机配置,冒号后面的部分是 MySQL 容器的配置。另外,使用 "--restart unless-stopped" 参数可以在 Docker 重启时重启当前容器,但不包括已停止的容器。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [如何在 Docker 容器中运行 MySQL](https://blog.csdn.net/allway2/article/details/121583352)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Docker 安装 Mysql 容器 (完整详细版)](https://blog.csdn.net/BThinker/article/details/123471514)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值