当前位置:   article > 正文

如何通过nginx代理实现外网访问内网mysql或oracle数据库_nginx代理mysql

nginx代理mysql

        项目开发部署中经常会遇到MySQL或Oracle数据库安装在内网,而我们的应用服务只能部署在外网,如果实现外网服务访问连接内网的数据库呢?本次介绍如何通过Nginx配置实现外网访问内网数据库。

1、前置机服务器

        首先要保证有一台前置机服务器既可以访问内网数据库,又可以通过外网进行访问到这台前置机。然后在这台前置机服务器上安装部署ngxin来实现数据代理。

2、ngxin配置

        ngxin的安装部署这里就省略了,感兴趣的可以自行百度解决。这里主要介绍如何配置数据流代理。nginx.conf配置内容如下:

  1. #user nobody;
  2. worker_processes 1;
  3. #error_log logs/error.log;
  4. #error_log logs/error.log notice;
  5. #error_log logs/error.log info;
  6. #pid logs/nginx.pid;
  7. events {
  8. worker_connections 1024;
  9. }
  10. stream {
  11. upstream oracle {
  12. server 192.168.0.1:1521; #原oracle地址
  13. }
  14. upstream mysql {
  15. server 192.168.1.102:3306;
  16. }
  17. server {
  18. listen 3335;# 反向代理后监听的端口,nginx启动后访问192.168.21.100:3335就可以访问到oracleA
  19. proxy_connect_timeout 1s;
  20. proxy_timeout 3s;
  21. proxy_pass oracle;
  22. }
  23. server {
  24. listen 8888;# 反向代理后监听的端口
  25. proxy_connect_timeout 1s;
  26. proxy_timeout 3s;
  27. proxy_pass mysql;
  28. }
  29. }

        修改配置后重启一下nginx即可,然后通过外网IP和端口访问前置机,就相当于直接访问内网数据库了。

3、测试验证

        可以通过Navicat等数据库客户端连接工具进行测试。下图的例子就是通过8888端口访问到了3306端口的数据库。


新时代农民工

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/230707
推荐阅读
相关标签
  

闽ICP备14008679号