使用V2R做反向代理内网穿透
环境
内网服务器Prob1位于内网LAN1,
内网服务器Prob2位于内网LAN2,
外网服务器Serv1位于IP 123.123.123.123
内网节点配置
内网节点没有inbound,只需要配置一个bridge,一个outbound(以及默认的direct),一对路由规则
Prob1
{
"log": {
"loglevel": "debug",
"access": "/var/log/v2r_tunnel_access.log",
"error": "/var/log/v2r_tunnel_error.log"
},
"reverse":{
"bridges":[
{
"tag":"bridge",
"domain":"probe1.nowhere.com"
}
]
},
"outbounds": [
{
"tag":"tunnel",
"protocol":"vmess",
"settings":{
"vnext":[
{
"address":"123.123.123.123",
"port":10103,
"users":[
{
"id":"3301381f-6324-4d53-ad4f-1cda48b3012f",
"alterId":64
}
]
}
]
}
},
{
"tag":"direct",
"protocol":"freedom",
"settings":{}
}
],
"routing":{
"rules":[
{
"type":"field",
"inboundTag":["bridge"],
"domain":["full:probe1.nowhere.com"],
"outboundTag":"tunnel"
},
{
"type":"field",
"inboundTag":["bridge"],
"outboundTag":"direct"
}
]
}
}
配置说明
bridge中的domain,必须要存在于服务器的portal中,否则会报failed to process reverse connection的错误
2020/07/20 17:43:41 [Info] [4068778249] v2r.com/core/proxy/vmess/inbound: received request for tcp:aaa.nowhere.com:0
2020/07/20 17:43:41 [Info] [4068778249] v2r.com/core/app/dispatcher: taking detour [portal_bridge02] for [tcp:aaa.nowhere.com:0]
2020/07/20 17:43:41 [Info] [4068778249] v2r.com/core/app/reverse: failed to process reverse connection > v2r.com/core/app/reverse: empty worker list
2020/07/20 17:43:41 [Info] [4068778249] v2r.com/core/app/proxyman/inbound: connection ends > v2r.com/core/proxy/vmess/inbound: connection ends > io: read/write on closed pipe
公网服务节点配置
外网服务器没有outbound,对应每个内网节点,要配置一个portal,一对inbound(分别对应bridge和client)和一对路由规则。规则中不需要再设置domain。
在这种规则配置下,对应每一个protal,会有一个专门的inbound连接,方便用户端选择使用不同的内网。
{
"log": {
"loglevel": "debug",
"access": "/var/log/v2r_access.log",
"error": "/var/log/v2r_error.log"
},
"reverse":{
"portals":[
{
"tag":"portal_probe2",
"domain":"probe2.nowhere.com"
},
{
"tag":"portal_probe1",
"domain":"probe1.nowhere.com"
}
]
},
"inbounds":[
{
"tag":"to_probe2",
"port":10100,
"protocol":"vmess",
"settings":{
"clients":[
{
"id":"234ffdb8-ef14-4278-a4e6-2af32cc312cf",
"alterId":64
}
]
}
},
{
"tag": "tunnel_probe2",
"port":10101,
"protocol":"vmess",
"settings":{
"clients":[
{
"id":"3301381f-6324-4d53-ad4f-1cda48b3012f",
"alterId":64
}
]
}
},
{
"tag":"to_probe1",
"port":10102,
"protocol":"vmess",
"settings":{
"clients":[
{
"id":"a11efdb8-ef34-4278-a4e6-2af32cc010fc",
"alterId":64
}
]
}
},
{
"tag": "tunnel_probe1",
"port":10103,
"protocol":"vmess",
"settings":{
"clients":[
{
"id":"3301381f-6324-4d53-ad4f-1cda48b3012f",
"alterId":64
}
]
}
}
],
"routing":{
"rules":[
{
"type":"field",
"inboundTag":["to_probe2"],
"outboundTag":"portal_probe2"
},
{
"type":"field",
"inboundTag":["tunnel_probe2"],
"outboundTag":"portal_probe2"
},
{
"type":"field",
"inboundTag":["to_probe1"],
"outboundTag":"portal_probe1"
},
{
"type":"field",
"inboundTag":["tunnel_probe1"],
"outboundTag":"portal_probe1"
}
]
}
}
如果想在当前节点也创建socks5代理, 可以在inbounds里添加一个socks, 然后再添加到routing.rules, 例如
...
{
"tag":"client_bridge02",
"port":10102,
"protocol":"vmess",
"settings":{
...
}
},
# 添加的socks入口
{
"tag": "socks_bridge02",
"port": 10200,
"listen": "192.168.10.20",
"protocol": "socks",
"settings": {
"udp": true
}
},
#
{
"tag": "tunnel_bridge02",
"port":10103,
"protocol":"vmess",
"settings":{
...
}
},
...
"routing":{
"rules":[
...
{
"type":"field",
"inboundTag":["client_bridge02","socks_bridge02"], # 将socks_bridge02添加到inboundTag
"outboundTag":"portal_bridge02"
},
...
创建服务
对于已经运行了v2r的机器,可以再创建一个新的服务,例如
$ more /etc/systemd/system/v2r-tunnel.service
[Unit]
Description=V2R Tunnel Service
Documentation=https://www.v2r.com/
After=network.target nss-lookup.target
[Service]
Type=simple
User=root
CapabilityBoundingSet=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
AmbientCapabilities=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
NoNewPrivileges=true
ExecStart=/usr/bin/v2r/v2r -config /etc/v2r/config_tunnel.json
Restart=on-failure
[Install]
WantedBy=multi-user.target
通过systemctl enable 命令加入开机自启动
附安装记录(arm64)
apt install lrzsz
rz
chmod u+x go.sh
./go.sh --version v4.26.0 --local v2r-linux-arm64.4.26.0.zip
systemctl is-enabled v2r.service
cd /etc/v2r/
rz
vi config-lan.json
rm config.json
mv config-lan.json config.json
systemctl start v2r.service
ps aux|grep v2r
tail -f /var/log/v2r_tunnel_error.log
使用V2R做反向代理内网穿透的更多相关文章
- 借助FRP反向代理实现内网穿透
一.frp 是什么? frp 是一个专注于内网穿透的高性能的反向代理应用,支持 TCP.UDP.HTTP.HTTPS 等多种协议.可以将内网服务以安全.便捷的方式通过具有公网 IP 节点的中转暴露到公 ...
- frp实现基于反向代理的内网穿透
个人博客主页: xzajyjs.cn frp是什么 简单地说,frp就是一个反向代理软件,它体积轻量但功能很强大,可以使处于内网或防火墙后的设备对外界提供服务,它支持HTTP.TCP.UDP等众多协议 ...
- 使用FRP做内网穿透
Github地址:https://github.com/fatedier/frp 什么是FRP? frp 是一个可用于内网穿透的高性能的反向代理应用,支持 tcp, udp 协议,为 http 和 h ...
- 测试龙芯 LoongArch .NET之 使用 FastTunnel 做内网穿透远程计算机
龙芯3A5000 已经上市,与龙芯3A5000配套的三大编译器GCC.LLVM.GoLang和三大虚拟机Java.JavaScript..NET均已完成开发,从老伙计哪里搞来一台3A5000 机器,安 ...
- 【代理】内网穿透工具 frp&frps
frp 是一个高性能的反向代理应用,可以帮助您轻松地进行内网穿透,对外网提供服务,支持 tcp, http, https 等协议类型,并且 web 服务支持根据域名进行路由转发. ### frp 的作 ...
- 【新晋开源项目】内网穿透神器[中微子代理] 加入 Dromara 开源社区
1.关于作者 dromara开源组织成员,dromara/neutrino-proxy项目作者 名称:傲世孤尘.雨韵诗泽 名言: 扎根土壤,心向太阳.积蓄能量,绽放微光. 拘浊酒邀明月,借赤日暖苍穹. ...
- 分享下超实用的用skura frp做内网穿透的经验
操作目的: 使无公网ip的主机能被外网访问,实现ssh对服务器的远程管理 硬件准备: 1.服务端:skura frp主机(skura frp 免费提供,有待创建) 2.客户端:接在无线路由器(内网)上 ...
- Mac配置内网穿透
闲语: Java开发过程中,往往会对接第三方,而在对接过程中,双方间使用的最多的"通讯"方式就是异步通知.可是异步通知过程中,只能通知到外网地址,可是在调试过程我们都是在本地进行- ...
- 使用阿里云服务器配置frp实现Windows系统RDP内网穿透
1.frp服务器采用阿里云ecs的centos7.5系统,客户端是台windows10的系统,做一个RDP服务的内网穿透用. 2.首先下载frp到服务器(链接:https://github.com/f ...
- FastTunnel-开源内网穿透框架
FastTunnel - 打造人人都能搭建的内网穿透工具 FastTunnel是用.net core开发的一款跨平台内网穿透工具,它可以实现将内网服务暴露到公网供自己或任何人访问. 与其他穿透工具不同 ...
随机推荐
- 问题--QT只有全屏的时候才能使用
1.问题 安装的版本是3.8.0,只有在全屏的时候在编辑界面不会卡,其余情况会直接卡死在这. 2.解决方式 安装了较低版本的3.14.2,解决了上述问题
- 【Git】常用 Git 命令清单
[来源]https://blog.csdn.net/hj7jay/article/details/53431717
- crypto常用工具
古典密码 维吉尼亚密码(Vigenere): https://github.com/atomcated/Vigenere(加密解密程序,包含自动猜测密钥功能) https://www.guballa. ...
- 如何看待《李跳跳》APP因被腾讯公司发律师函称“不正当竞争”而无限期停止更新?
一波未平一波又起,继李跳跳无限期停更后,又一安卓神奇工具被下发律师函!近期各路安卓工具APP,被某讯大厂可谓是尽数剿灭~ 不难看出此次行动是"蓄谋已久"了.与李跳跳.大圣净化类似的 ...
- [转帖]K8s Pod Command 与容器镜像 Cmd 启动优先级详解
https://cloud.tencent.com/developer/article/1638844 前言 创建 Pod 时,可以为其下的容器设置启动时要执行的命令及其参数.如果要设置命令,就填写在 ...
- PG数据库的离线rpm包下载
PG数据库的离线rpm包下载 背景 周末时间研究数据库的版本. 发现PostgreSQL数据库的版本号已经变成了一年一个大版本. 兼容起来其实成本很高. 想着能够在能够上网的机器上面弄好多套数据库. ...
- [转帖]nginx中rewrite和if的用法及配置
nginx中rewrite和if的用法及配置 文章目录 nginx中rewrite和if的用法及配置 @[toc] 一.rewrite应用 1.rewrite跳转场景 2.rewrite实际场景 3. ...
- [转帖]django使用html渲染页面样式+数据库管理员的创建
一.django页面渲染 1.在templates中创建html格式的文件-index.html,在该文件中添加body,设置样式,比如: <h1 style = "backgroun ...
- Oracle 监控客户端的连接数量趋势
Oracle 监控客户端的连接数量趋势 背景 前期简单总结了table方式将表信息展示出来的方法 但是感觉这样非常不直观. 想着能够做出一个趋势来. 时序数据库的最佳的使用方式. 之前的确是太靠自己的 ...
- [转帖] 如何kill一条TCP连接?
https://www.cnblogs.com/codelogs/p/16838850.html 原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处. 简介# 如果你的程序写 ...