文章来源:https://blog.ll00.cn/archives/127.html
问题描述:通过web服务器访问db服务器, 因为db服务器没有外网ip, 不支持外网直接访问;web服安装了php, 有外网IP,支持外网http访问。
补充:什么是Navicat? 在win系统下通过图形操作mysql数据库的软件, 很好用。官网地址 :https://www.navicat.com.cn
在线上环境的服务器,一般都是关闭了数据库外网访问的权限,这时候外网就不能直接连接数据库了,需要在服务器内才能操作数据库。但Navicat软件提供了HTTP通道代理连接数据库功能,只要服务器上有HTTP服务,并且端口开放了,就可以使用HTTP通道来连接数据库。
基本原理
数据库端口没开放外网访问的时候,Navicat在外网无法访问数据库。
服务器上运行着PHP,并且我们是可以访问到PHP的。
PHP可以连接MySQL数据库并执行SQL语句,因为它们都在内网和PHP支持MySQL。
虽然Navicat无法连接上MySQL,但是Navicat对数据库所有的查询可以让PHP代为查询,然后把结果返回给Navicat。
所以把一个php脚本放到服务器上,就可以让Navicat间接连接数据库,对数据库进行操作了。
上传PHP脚本
Navicat软件自带三个php代理脚本,它在Navicat安装目录下,分别是:ntunnel_mysql.php
ntunnel_pgsql.php
ntunnel_sqlite.php
这里主要讲MySQL,所以用到的是ntunnel_mysql.php
脚本,其他数据库基本同理。
将ntunnel_mysql.php
上传到服务器,并测试能否通过浏览器访问到
Navicat连接设置
在新建或者编辑连接的时候,选项卡里面都会有一个HTTP
,切换到HTTP
选项卡。
然后勾选使用HTTP通道
,通道网址
处输入ntunnel_mysql.php
的网址。
建议勾选上用base64编码传出查询
,不然有可能出现700 Invalid response: 500
错误。
这个错误主要出现在获取数据库列表和表结构的时候出现,服务器有使用防护软件,也有可能是它捣的鬼。
其他验证信息不用填。
然后在常规
选项卡里,设置好端口
、用户名
、密码
,主机
输入127.0.0.1
或者对应的内网IP
。
简单来说就是服务器上项目配置里的数据库连接配置怎么设置的,这里就怎么设置,因为是用php来代替连接数据库
测试连接
最后,测试下连接。如果有错误,按照错误信息修改下对应的配置即可。
如果测试连接时,Navivat 报错“curl_easy_perform: Coudn't not connect to server”, 请多尝试几遍。
总结
以上方法亲测有效,极力推荐。欢迎留言评论。