这个问题与
有关Dockerized web app connecting to MySQL DB on host
我正在尝试打开从 docker 容器到主机的连接以支持 MySQL 连接。
按照我的理解,我应该能够在我的容器中执行以下操作
nc.traditional -l -p 3306 -c "nc.traditional 172.17.42.1 3306" &
打开从 Docker 容器端口 3306 到在端口 3306 上运行的主机(IP 172.17.42.1)MySQL 实例的隧道。
当我尝试从容器连接时就会出现问题
mysql --host=127.0.0.1 --port=3306 -uroot -ppassword
我收到错误并且隧道退出
root@7ec710b77baf:/var/log# mysql --host=127.0.0.1 --port=3306 -uroot -pAcc355
(UNKNOWN) [172.17.42.1] 3306 (mysql) : Connection refused
ERROR 2013 (HY000): Lost connection to MySQL server at 'reading initial communication packet', system error: 0
[1]+ Exit 1 nc.traditional -l -p 3306 -c "nc.traditional 172.17.42.1 3306"
为什么隧道会导出?我究竟做错了什么?它确实似乎联系了 MySQL 实例,因为当我尝试不同的端口时,我收到了不同的错误消息。
我无法在日志或标准输出中找到任何帮助信息。
有什么想法吗?
最佳答案
根据我的经验,您可能需要 socat 而不是 netcat。
例如
socat TCP-LISTEN:3306,fork TCP:db-host:3306
我发现 netcat 处理连接存在问题
关于mysql - netcat 用于 MySQL 连接转发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30897533/