1
buxudashi 2023-01-26 22:21:31 +08:00
弄多个域名 就解决了。
|
2
lanternxx 2023-01-26 22:57:21 +08:00
不能。MySQL 建立连接的 TCP 请求里没有携带域名,你无法获取到不存在的东西。
如果是 MySQL over TLS 的话理论上可以。因为 TLS 握手的第一个请求的 SNI 里会带上域名,但是应该没有直接可用的实现方案。而且需要抓包确认一下 Navicat 在连接 MySQL over TLS 时是否会携带 SNI 。 |
3
seagull7558 OP @lanternxx 嗯 nginx 和 traefik 都有在预读阶段通过 SNI 获取域名 但是不想加 TLS,目前看好像没有什么好方案
|
4
huanw 2023-01-26 23:03:54 +08:00
在你的 k8s 集群里跑一个自建的 ssh 服务,这个服务要支持 ssh remote forwarding ,然后在 navicate 连接时,使用这个 ssh 隧道就可以连接了
|
5
cdlnls 2023-01-26 23:10:49 +08:00
就你描述的方案应该是不可能实现的。假定你要用负载均衡代理 mysql ( traefik/ingress-nginx/或者其他的负载),它们代理 mysql 的流量肯定只能工作在传输层,mysql 并不是 HTTP 协议,这个时候负载均衡是没办法拿到域名的。
如果要实现的话,大概要自己实现一个支持 mysql 协议的代理,然后解析 host 。可以参考一下 mycat 。 |
6
ETiV 2023-01-26 23:33:49 +08:00 via iPhone
mysql 客户端连接都是在 4 层的
但是你可以自己实现一个 7 层应用层的类似 nginx 的服务,逻辑实现如下: 通过在用户名上做手脚(比如 root.prod 、root.dev ;你喜欢的话也可以用对端 IP 地址),通过某种 rewrite 规则把 .prod 、.dev 部分提取出来,再使用 root 用户名和密码去连接后端真实的 prod 、dev 的 3306 端口并创建、保持连接并转发数据 |
7
anubu 2023-01-26 23:45:32 +08:00 via Android
之前简单研究过类似场景,四层的域名转发似乎都需要依赖 sni 。没记错的话,mysql 的 sni 并不容易(或者无法实现?记不清楚了),似乎是应用层协议握手逻辑和一般应用不一样。
|
8
vibbow 2023-01-27 00:07:14 +08:00
可以实现的,并且比你想象的还简单,使用 navicat 自带的 HTTP tunnel 即可
https://github.com/vibbow/navicat-mysql-tunnel 对这个脚本稍微改一改,就可以实现不同的 HTTP_HOST 指向不同的后端了。 |
9
lambdaq 2023-01-27 00:15:39 +08:00
应该有些 mysql proxy 能做到。既然读写分离都能做到,区分 host 应该也不难。
|
10
coolwind1981 2023-01-27 09:01:05 +08:00 via Android
|
11
coolwind1981 2023-01-27 09:05:59 +08:00 via Android
@seagull7558 @vibbow HTTP tunnel 挺好的
|
12
lazyfighter 2023-01-27 09:54:30 +08:00
https://tengine.taobao.org/document/stream_sni.html 他可以做到, 楼主我觉得可以描述一下问题场景, 别说解决方案, 可能是你想偏了
|
13
johnkiller 2023-01-27 12:38:04 +08:00
域名在请求之前就已经在客户端解析成 IP 了,到入口服务器那里的报文已经没有域名了,而不像 HTTP 是会带一个 Host: xxx 字段。
通过不同 MySQL 用户名+ Proxy 来分流也许是一种可行的方式。 另外,用 tunnel 应该是最简单的,只是需要在 Navicat 上多配置一下代理。 |