前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nginx使用反向代理转发SSH服务

Nginx使用反向代理转发SSH服务

作者头像
行 者
发布2023-10-20 14:33:34
1.8K0
发布2023-10-20 14:33:34
举报
文章被收录于专栏:运维技术迷

环境

系统:Centos7 服务器:腾讯云轻量

目的

通过nginx proxy ssh端口来达到安全、加速的效果。

部署

实现此功能需要将stream模块编译进来,依照官方文档得知:

The ngx_stream_core_module module is available since version 1.9.0. This module is not built by default, it should be enabled with the --with-stream configuration parameter.

官方文档指出,在1.9.0版本后可以使用stream模块,但此模块不是默认编译进去的,所以需要我们在编译安装nginx的时候加上它--with-stream

配置

官方的Example

代码语言:javascript
复制
Example Configuration
worker_processes auto;

error_log /var/log/nginx/error.log info;

events {
    worker_connections  1024;
}

stream {
    upstream backend {
        hash $remote_addr consistent;

        server backend1.example.com:12345 weight=5;
        server 127.0.0.1:12345            max_fails=3 fail_timeout=30s;
        server unix:/tmp/backend3;
    }

    upstream dns {
       server 192.168.0.1:53535;
       server dns.example.com:53;
    }

    server {
        listen 12345;
        proxy_connect_timeout 1s;
        proxy_timeout 3s;
        proxy_pass backend;
    }

    server {
        listen 127.0.0.1:53 udp reuseport;
        proxy_timeout 20s;
        proxy_pass dns;
    }

    server {
        listen [::1]:12345;
        proxy_pass unix:/tmp/stream.socket;
    }
}

创建配置

参照官方的Example,我们来创建 or 修改自己的配置文件。

代码语言:javascript
复制
http {}
stream {
    upstream ssh {
        hash $remote_addr consistent;

        server IP:PORT;
    }
     server {
        listen 12345;
        proxy_connect_timeout 60s;  // 注意此处不要把proxy配置放到location {}里面,否则会报错。
        proxy_timeout 60s;
        proxy_pass ssh;
    }

}
  /usr/local/nginx/sbin/nginx -t
 /usr/local/nginx/sbin/nginx -s reload
[root@LWS-QHK-NODE vhost]# ss -anptu | grep 12345
 tcp    LISTEN     0      511       *:12345                 *:*                   users:(("nginx",pid=22190,fd=16),("nginx",pid=21964,fd=16))

参考文献

stream 官方文档

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-01-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 环境
  • 目的
  • 部署
  • 配置
    • 官方的Example
      • 创建配置
      • 参考文献
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档