本文主要是将多个web服务放在树莓派端进行,然后用frp进行内网穿透到公网上,再使用nginx反向代理将域名跟端口解析到一块,最终实现域名访问web站。
所需资源
- 公网服务器(具体配置请看上文链接)
- 域名
准备工作
本文是用Django框架做的web,服务器端口放在7071,通过二级域名来确定访问那个web端,在配置之前已经将Django框架运行了,本地端口号为8000和8001。如果不了解web端部署的可以看Django部署.
域名解析配置子域名
本文以wanfa.club 为例:
登录域名的解析后台,在wanfa.club下增加两条A记录: dev , det,记录值为部署frp服务端的公网服务器的ip。
代表dev.wanfa.club下的所有的子域名,会全部指向此台公网服务器。
frp配置
frp作为内网穿透的高性能反向代理应用,支持tcp/udp/http/https四种协议,可以将部署在本机的web服务映射到外网中,具体frp介绍请看下面推文
frps配置(服务器端)
[common]
# frp监听的端口,用作服务端和客户端通信
bind_port = 7000
# 服务端通过此端口接监听和接收公网用户的http请求
vhost_http_port = 8080
# frp提供了一个控制台,可以通过这个端口访问到控制台。可查看frp当前有多少代理连接以及对应的状态
dashboard_port = 7500
启动查看输出(如果对这个命令不熟悉或者出错的话可以取看上文的frp链接再去找原因)
sudo ./frpc -c ./frpc.ini
frpc配置(客户端,也就是树莓派端)
[common]
# 部署frp服务端的公网服务器的ip
server_addr = x.x.x.x
# 和服务端的bind_port保持一致
server_port = 7000
# 代理服务一 ,[]内的代理服务名称在全局范围内确保唯一,每个人的每个代理服务不能重名,
# 否则会影响正常使用。
[ssh1]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 6001
[tcp]
type = http
local_port = 8000
custom_domains = dev.wanfa.club
[tcp-1]
type = http
local_port = 8001
custom_domains =det.wanfa.club
启动查看输出
sudo ./frpc -c ./frpc.ini
现在配置完成后都运行不会报错,但是访问不了网页,这是因为公网默认监听的80端口,要用nginx反向代理到vhost_http_port对应的端口。
nginx 配置
个人理解nginx在初步使用中就是作为一个反向代理转发的功能,也就是监听服务器80端口,有请求就解析然后转发给相应的服务器端口,前面将frp配置好之后,也就是打开了frp中
直接使用apt-get install nginx安装就可以,不用多说。接下来主要是配置方法。
首先确保frp将服务器跟树莓派连接到一块,并且设置好服务器端口监听和接受公网用户的http请求。如下:
#frps.ini
vhost_http_port =8080
并且子域名在域名解析中设置好了(方法可以百度,比较简单),这儿解析的子域名是dev.wanfa.club。也就是说可以访问dev.wanfa.club等于访问树莓派端的localhost:8000。
然后修改nginx.conf文件,一般在/etc/nginx/文件夹下
events{
worker_connections 4096;
}
http{
server{
listen 80;
server_name det.wanfa.club;
location / {
proxy_pass http://122.51.176.104:8081;
proxy_set_header Host $host;
}
}
}
server{
listen 80;
server_name dev.wanfa.club;
location /{
proxy_pass http://122.51.176.104:8081;
proxy_set_header Host $host:80;
}
}
然后重新加载一下
/usr/sbin/nginx -s reload
这儿可以whereis nginx查看一下nginx路径。
加载完成后打开网页端,就发现两个域名都可以登录了。