OpenWRT安装内网穿透 Cloudflare Tunnel 教程

频道:网络应用 日期: 浏览:1050

000:前提:你要有一个域名,并且已经将DNS解析地址改到了CloudFlare


OpenWRT安装内网穿透 Cloudflare Tunnel 教程

001:这是官方CloudFlared二进制可执行文件放在Github上的网址:https://github.com/cloudflare/cloudflared(但没有openwrt,直接安装的ipk包,不过这里安装的好处是,安全,毕竟是官方的么,更新也是直接同步官方,不用等第三方编译出来,毕竟这么隐私的应用还是用官方的安全,对吧。)


002:首先用你自己的账号登入CloudFlare.com官网,登入后,在首页左侧菜单找到Zero Trust点击进入


003:上一步操作好后,会跳转到下一个菜单Zero Trust overview,在这里找到Access菜单边上的下拉箭头,找到Tunnels,进入后选择Create a tunnel创建一个隧道,Tunnel name(Required)这里


任意填写一个好记的隧道名,例如:小明的办公室,xiaomingoffice,我的家,myhome,然后


点击Save tunnel


004:接着就跳转到下一个菜单,官方给出了Windows,Linux两大家族系,Mac,和Docker的32位和64位部署安装包,这里我是安装在openwrt上的,所以都不用,但是下面自动生成的握手令牌码,我们要复制一下,让在记事本上,一会要用到,就是类似下面的这串:


cloudflared.exe service install eyJhIjoiMjg1ZDYxZWU2Mjg3MDDFIUYDSFHDSKJFHSDJKHFKSDFJJSDFLKJDSKLFJDSL;KJFLKDSJFA;SLDJFIjoiYjViNmVkNGEtMzdmOC00ODI1LTk0YzgtF;IDSLUFL;J;lfiL;TJGLFKJD;KLFU;ADSILJ;JZaTAwTkdRM0xXRTJOalF0TUdVMVl6VmhNVFF6WYDDjkyJ9


(忽略cloudflared.exe service install 这个安装命令,只需要复制下面的令牌从ey到J9结束。)


005:任意SSH工具,连接你的openwrt,输入下面下载命令,回车。

VERSION="2024.1.2"

curl -O -L \
  https://github.com/cloudflare/cloudflared/releases/download/${VERSION}/cloudflared-linux-amd64 \
&& chmod +x cloudflared-linux-amd64 \
&& mv cloudflared-linux-amd64 /usr/bin/cloudflared


#注意VERSION=””里面的数字,即是教程001:官方打开后,右侧Latest最新版本的版本号,复制过来就行了,以后有新版本就只要改这里就行,架构的话我是X86的openwrt,所以直接用这条命令,如果你是ARM或者其它架构的,把${VERSION}/后面的改掉即可,例如ARM64就是cloudflared-linux-arm64#


006:依次输入下面2条命令,回车。

touch /etc/init.d/cloudflared

在openwrt重启引导目录里创建一个名为cloudflared的文件

chmod +x /etc/init.d/cloudflared

给刚才创建的这个文件赋予一个可执行权限,类似Windows鼠标右键以管理员身份运行


007:输入nano /etc/init.d/cloudflared    将下列代码修改一处就是令牌这里,然后粘贴,CTRL+O CTRL+X 保存。

#!/bin/sh /etc/rc.common

USE_PROCD=1
START=95
STOP=01

cfd_init="/etc/init.d/cloudflared"
cfd_token="这里改成教程004:你复制好的token"

boot()
{
    ubus -t 30 wait_for network.interface network.loopback 2>/dev/null
    rc_procd start_service
}

start_service() {
    if [ $("${cfd_init}" enabled; printf "%u" ${?}) -eq 0 ]
    then
        procd_open_instance
        procd_set_param command /usr/bin/cloudflared --no-autoupdate tunnel run --token ${cfd_token}
        procd_set_param stdout 1
        procd_set_param stderr 1
        procd_set_param respawn ${respawn_threshold:-3600} ${respawn_timeout:-5} ${respawn_retry:-5}
        procd_close_instance
    fi
}

stop_service() {
    pidof cloudflared && kill -SIGINT `pidof cloudflared`
}


008:输入下面2个命令,回车。

/etc/init.d/cloudflared enable

#设置这个文件,开机启动#

/etc/init.d/cloudflared start

#现在运行这个文件#


009:输入下面2个命令,回车,一个是查看进程,一个是查看进程日志。

ps | grep cloudflared

#查询是否有这个名字的进程#看到有两行进程才算正常。

logread | grep cloudflared

#查看这个名字的进程日志#


010:这个时候回到CloudFlare我们Access-Tunnels的菜单下,刷新一下,应该就能看到


一个隧道链接的提示,隧道名是我们自己取的,在Status状态栏下显示绿色HEALTHY就代表隧道已经穿透,可以用了,如果是INACTIVE就说明隧道连接失败,可以等等,或者看看上面的步骤是否有错,如果已经HEALTHY健康状态了,就点边上的3个点,选择Congfigure,进入后选上面Public Hostname菜单,点击+Add a public hostname,进入后在Subdomain里取你的二级域名名字,


如果直接用根域名就输入@,Domain(Required)菜单里选择你托管在CF的域名,Path一般不填写


除非像宝塔这种默认安全设置这里有扩展路径例如:https://bt.cn:8888/format/,那么你就需要在Path里填写/format,下面的Service-Type这里就随便了,看你自己要穿透的协议,如果是穿透局域网里的openwrt自身,例如:http://192.168.1.1,那么这里选http就行了,后面的URL就填写192.168.1.1


以此类推,再举个例子黑群晖https://192.168.1.5:5000 ,那么Type就改成https,后面URL就填写192.168.1.5:5000即可。局Windows11电脑,局域网IP是192.168.1.10装了VNC远程桌面,VNC默认端口5900,那么应用类软件只要不是UDP,那这种TCP的就在Type里选TCP,URL里填写192.168.1.10:5900即可。


关键词:openwrt

0 留言

评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
Music