解决Docker MySQL无法被宿主机访问的问题

1 问题描述

Docker启动MySQL容器后,创建一个localhost访问的用户:

create user test@localhost identified by 'test';

但是在宿主机中无法通过该用户登录:

mycli -u test

在这里插入图片描述

2 原因

Docker中的MySQL创建localhost的用户只能在Docker内部访问,而不能通过外部访问。

至于为什么能在宿主机访问root,是因为默认存在两个root,分别是:

  • root@localhost
  • root@%

在这里插入图片描述

test只有一个localhost

在这里插入图片描述

3 解决方案

创建test@%或者创建test@172.17.0.1即可:

create user test@% identified by 'test';
create user test@172.17.0.1 identified by 'test';
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!对于 Docker 中 Superset 无法连接宿主机 MySQL问题,可以尝试以下解决方案: 1. 确保宿主机 MySQL 服务正常运行,并且已经配置了正确的用户名、密码以及数据库连接信息。您可以在宿主机上使用命令行或者图形化工具来验证连接是否正常。 2. 在 Docker 中运行 Superset 容器时,确保正确映射了宿主机 MySQL 的端口。例如,如果宿主机 MySQL 使用的是默认的 3306 端口,则可以使用以下命令来运行 Superset 容器: ``` docker run -p 8088:8088 -e SUPERSET_CONFIG=superset.config -e SUPERSET_CONFIG=superset.config -v /path/to/superset:/home/superset superset ``` 其中,`-p 8088:8088` 表示将容器的 8088 端口映射到宿主机的同样端口,`-v /path/to/superset:/home/superset` 表示将宿主机中的 Superset 配置文件目录挂载到容器中。 3. 在 Superset 的配置文件中,确保正确配置了 MySQL 数据库的连接信息。您可以在 Superset 配置文件中找到以下配置项,并根据宿主机 MySQL 的配置进行相应修改: ``` SQLALCHEMY_DATABASE_URI = 'mysql://username:password@hostname:port/database_name' ``` 其中,`username`、`password`、`hostname`、`port` 和 `database_name` 需要替换为宿主机 MySQL 的实际信息。 4. 如果仍然无法连接,可以尝试检查宿主机防火墙设置,确保允许 Superset 容器访问宿主机 MySQL 的网络连接。 希望以上解决方案对您有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值