加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql – 将Django连接到代理服务器后面的数据库

发布时间:2020-12-11 23:52:31 所属栏目:MySql教程 来源:网络整理
导读:我想将Django连接到我的生产MySQL数据库(只读),以便我可以使用它来使用真实数据测试分析应用程序. 有没有办法指定django应该通过ssh代理连接到db,就像Sequel Pro允许你指定通过特定的SSH代理用用户名和密码连接一样? 如果是这样,DATABASES条目会是什么样子

我想将Django连接到我的生产MySQL数据库(只读),以便我可以使用它来使用真实数据测试分析应用程序.

有没有办法指定django应该通过ssh代理连接到db,就像Sequel Pro允许你指定通过特定的SSH代理用用户名和密码连接一样?

如果是这样,DATABASES条目会是什么样子?

最佳答案 只需使用SSH隧道.为了简化您的工作,您可以安装autossh,它会自动检查ssh连接是否处于活动状态,并在其关闭时重新建立.

然后,您可以使用以下命令打开隧道:

autossh -f -N -L LocalPort:MySQLAddress:MySQLPort your_login@your_server

哪里:

> your_server – 您通过ssh连接的服务器
> your_login – 您在your_server上的登录信息
> LocalPort – 运行Django的机器上任何未使用的端口.该端口将用于隧道.
> MySQLAddress – MySQL服务器的地址,因为它可以从your_server访问(也就是说,如果MySQL在your_server上运行,它将是127.0.0.1)
> MySQLPort – MySQL正在侦听的端口

然后在Django设置中,将MySQL IP指定为127.0.0.1,将端口指定为上面设置的LocalPort.

一个例子:

autossh -f -N -L 10000:127.0.0.1:3306 a_user@192.168.1.3

运行此命令时,将在本地端口10000上侦听SSH隧道.因此,如果连接到localhost:10000,则您的连接将通过隧道传输到192.168.1.3服务器上的localhost:3306.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读