文章

蜗牛星际+Frp+Caddy+Cloudflare折腾记

黑裙如何实现外网访问?本文详细介绍使用Frp内网穿透,Caddy反向代理,Cloudflare CDN加速的方法。

蜗牛星际+Frp+Caddy+Cloudflare折腾记

一段时间没有折腾什么东西,感觉人都颓废了。

前一阵蜗牛星际炸雷了之后,网上很多小机箱搞的很火爆。鉴于一直想搞一个NAS但又苦于昂贵的价格,赶上这班车直接就剁了一个A款。

选择A款的原因,其实是因为便宜,在一个有个外面板不会直接漏硬盘在外面,网上有很多对比评测。

黑裙的系统是918(其实马爸爸家的卖家都会给装好),google上也有很多就不复读了。

下面正文开始。

1. 利用Frp内网穿透

迫于没有公网IP,以及黑裙,只能走反向代理的方式从外网访问,这时候Frp就很重要了。

要使用Frpc,首先需要安装docker,在套件中心的第三方中找到Docker,安装。

在Docker中的注册表搜索frpc,安装oldiy/frpc这一映像,详见使用说明

服务器端安装详见Frp 的 GitHub page

安装好之后frpc.ini以及vps上的frps.ini参考如下:

1 Port to Subdomain

对于有域名的同学,可以直接使用Frp将内网的端口映射到外网的subdomain,可以直接实现访问,由于黑裙的原因,证书申请有些问题,https访问会有insecure的提示,可以将local_port设置为5000走http访问(5000为默认Http端口,5001为默认Https端口,可以更改)。

NAS端配置文件:

1
2
3
4
5
6
7
8
9
10
11
[common]
server_addr = [your ip]
server_port = [your port]
token = [your token]
tcp_mux = true

[nas]
type = tcp
local_ip = 127.0.0.1
local_port = 5001
subdomain = nas

Server配置文件,默认路径/etc/frps/frps.ini,取决于frps解压路径:

1
2
3
4
5
6
7
8
9
[common]
bind_port = [your port]
log_file = ./frps.log
log_level = info
log_max_days = 3
token =  [your token]
max_pool_count = 50
tcp_mux = true
subdomain_host = your.domain

访问方式 https://nas.your.domain

2 Port to Port

对于没有域名(或想使用caddy申请证书)的同学,可以采用映射port的方法,配置文件如下。

NAS端配置文件:

1
2
3
4
5
6
7
8
9
10
11
[common]
server_addr = [your ip]
server_port = [your port]
token = [your token]
tcp_mux = true

[nas]
type = tcp
local_ip = 127.0.0.1
local_port = 5001
remote_port = 5001

Server配置文件,最后一行可有可无:

1
2
3
4
5
6
7
8
9
[common]
bind_port = [your port]
log_file = ./frps.log
log_level = info
log_max_days = 3
token =  [your token]
max_pool_count = 50
tcp_mux = true
#subdomain_host = your.domain

访问方式 https://[your ip]:5001

2. 利用Caddy反向代理

对于有域名又不想麻烦申请证书的同学,可以用Caddy做反向代理,使用上面Port to Port的方式。

Caddy的使用教程详见Caddy 的 Github page

简单的CaddyFile如下:

1
2
3
4
5
6
7
nas.your.domain {
    tls your@email.com

    proxy / https://127.0.0.1:5001 {
        insecure_skip_verify
    }
}

访问方式 https://nas.your.domain

3. 利用Cloudfare CDN加速

对于访问速度慢的VPS,或不想暴露真实IP的同学,可以使用CDN加速,这里推荐Cloudfare的免费CDN。

Caddy的安装文件需要在网站上定制(增加cloudflare的支持),在Download界面Plugin中添加dns.cloudflare

Caddy的配置文件也需要相应修改:

1
2
3
4
5
6
7
8
9
nas.your.domain {
    tls {
        dns cloudflare
    }

    proxy / https://127.0.0.1:5001 {
        insecure_skip_verify
    }
}

CloudFlare设置好DNS解析,并将Cloudflare nameservers加入到VPS的DNS nameserver中,详见Changing your domain nameservers to Cloudflare

访问方式 https://nas.your.domain

Reference

Frp 的 Github page
oldiy/frpc
Caddy 的 Github page
Changing your domain nameservers to Cloudflare

本文由作者按照 CC BY 4.0 进行授权