gpt4 book ai didi

mysql - 如何使用 Nginx 允许安全远程连接到本地 MySQL 数据库?

转载 作者:行者123 更新时间:2023-12-04 13:15:09 24 4
gpt4 key购买 nike

如果可能的话,我想避免向外界开放默认端口 3306。我们运行 Nginx 以用于其他应用程序的反向代理。此处的目标是以安全的方式从本地网络外部使用 MySQL Workbench 等客户端访问 MySQL 数据库。 MySQL 服务器在 Debian (Linux) 虚拟机上运行。

我配置了一个服务器块,如下所述。在 MySQL Workbench 中使用非 root 用户连接到 mysql.domain.com、端口 80 会导致失败。

服务器块:

server {

server_name mysql.domain.com;

location / {
proxy_pass http://localhost:3306/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
}
}

错误信息:
Failed to Connect to MySQL at mysql.domain.com:80 with user non-root. 
Lost connection to MySQL at 'waiting for initial communication packet', system error: 10060

最佳答案

The goal here is to access the MySQL databases with clients such as MySQL Workbench from outside the local network



所有现代 MySQL GUI 客户端都支持 SSH 隧道。这是最安全的连接方法,并且需要在服务器端进行零配置:如果您可以通过 SSH 连接,那么您就可以连接到该主机上的 MySQL。

在 MySQL Workbench 中,创建连接时,选择“Standard TCP/IP over SSH”作为连接方式,然后填写 SSH 连接详细信息和 MySQL 连接详细信息。关键是将 MySQL 服务器设置为 127.0.0.1因为您通常希望连接到在您通过 SSH 连接的机器上运行的 MySQL 实例。这里的所有都是它的。

关于mysql - 如何使用 Nginx 允许安全远程连接到本地 MySQL 数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61268498/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com