Django-使用frp和nginx在树莓派上对多个域名进行解析

本文主要是将多个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介绍请看下面推文

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路径。

加载完成后打开网页端,就发现两个域名都可以登录了。


一技破万法