我在Nginx中使用以下配置代理RDP连接:
server {
listen 80;
server_name domain.com;
location / {
proxy_pass http://192.168.0.100:3389;
}
}
但连接没有通过.我的猜测是问题出在proxy_pass中的http.谷歌搜索“ Nginx RDP”收效不高.
有人知道这是否可能吗?
最佳答案
好吧,实际上您是对的,这是http的问题,但不完全是代码块中的那个问题.让我们解释一下:
原文链接:https://www.f2er.com/nginx/532355.htmlhttp {
...
...
...
include /etc/Nginx/conf.d/*.conf;
include /etc/Nginx/sites-enabled/*;
}
因此,您在conf文件中编写的所有内容都在此http块/范围内.但是rdp不是http是一个不同的协议.
我知道Nginx可以处理此问题的唯一解决方法是在tcp级别上工作.
因此,在Nginx.conf的内部和http块的外部,您必须像这样声明流块:
stream {
# ...
server {
listen 80;
proxy_pass 192.168.0.100:3389;
}
}
使用上述配置,只需在tcp层上代理您的后端即可,当然需要花一些钱.您可能会注意到它缺少server_name属性,因此无法在流作用域中使用它,而且还会丢失http级别上的所有日志记录功能.