Files
frp-panel/docs/contribute.md
2025-05-25 11:06:08 +00:00

4.7 KiB
Raw Blame History

贡献指南

文档贡献指南

请fork本仓库修改仓库目录下 docs 文件夹中的内容

项目开发指南

平台架构设计

技术栈选好了下一步就是要设计程序的架构。在刚刚背景里说的那样frp 本身有 frpc 和 frps客户端和服务端这两个角色肯定是必不可少了。然后我们还要新增一个东西去管理它们所以 frp-panel 新增了一个 master 角色。master 会负责管理各种 frpc 和 frps中心化的存储配置文件和连接信息。

然后是 frpc 和 frps。原版是需要在两边分别写配置文件的。那么既然原版已经支持了就不用在走原版的路子我们直接不支持配置文件所有的配置都必须从 master 获取。

其次还要考虑到与原版的兼容问题frp-panel 的客户端/服务端都必须要能连上官方 frpc/frps 服务。这样的话就可以做到配置文件/不要配置文件都能完美工作了。 总的说来架构还是很简单的。

arch

开发

项目包含三个角色

  1. Master: 控制节点,接受来自前端的请求并负责管理 Client 和 Server
  2. Server: 服务端,受控制节点控制,负责对客户端提供服务,包含 frps 和 rpc(用于连接 Master)服务
  3. Client: 客户端,受控制节点控制,包含 frpc 和 rpc(用于连接 Master)服务

接下来给出一个项目中各个包的功能

.
|-- biz                 # 主要业务逻辑
|   |-- client          # 客户端逻辑这里指的是frp-panel的客户端
|   |-- master          # frp-panel 控制平面负责处理前端请求并且使用rpc管理frp-panel的server和client
|   |   |-- auth        # 认证模块,包含用户认证和客户端认证
|   |   |-- client      # 客户端模块包含前端管理客户端的各种API
|   |   |-- server      # 服务端模块包含前端管理服务端的各种API
|   |   `-- user        # 用户模块,包含用户管理、用户信息获取等
|   `-- server          # 服务端逻辑这里指的是frp-panel的服务端
|-- cache               # 缓存用于存储frps的认证token
|-- cmd                 # 命令行入口main函数的所在地负责按需启动各个模块
|-- common
|-- conf
|-- dao                 # data access object任何和数据库相关的操作会调用这个库
|-- doc                 # 文档
|-- idl                 # idl定义
|-- middleware          # api的中间件包含JWT和context相关用于处理api请求鉴权通过后会把用户信息注入到context可以通过common包获取
|-- models              # 数据库模型,用于定义数据库表。同时包含实体定义
|-- pb                  # protobuf生成的pb文件
|-- rpc                 # 各种rpc的所在地包含Client/Server调用Master的逻辑也包含Master使用Stream调用Client和Server的逻辑
|-- services            # 各种需要在内存中持久运行的模块,这个包可以管理各个服务的运行/停止
|   |-- api             # api服务运行需要外部传入一个ginRouter
|   |-- client          # frp的客户端即frpc可以控制frpc的各种配置/开始与停止
|   |-- master          # master服务包含rpc的服务端定义接收到rpc请求后会调用biz包处理逻辑
|   |-- rpcclient       # 有状态的rpc客户端因为rpc的client都没有公网ip因此在rpc client启动时会调用master的stream长连接rpc建立连接后Master和Client通过这个包通信
|   `-- server          # frp的服务端即frps可以控制frps的各种配置/开始与停止
|-- tunnel              # tunnel模块用于管理tunnel也就是管理frpc和frps服务
|-- utils
|-- watcher             # 定时运行的任务比如每30秒更新一次配置文件
`-- www
    |-- api
    |-- components # 这里面有一个apitest组件用于测试
    |   `-- ui
    |-- lib
    |   `-- pb
    |-- pages
    |-- public
    |-- store
    |-- styles
    `-- types

调试启动方式:

  • master: go run cmd/*.go master

    client 和 server 的具体参数请复制 master webui 中的内容

  • client: go run cmd/*.go client -i <clientID> -s <clientSecret>
  • server: go run cmd/*.go server -i <serverID> -s <serverSecret>

项目配置文件会默认读取当前文件夹下的.env 文件,项目内置了样例配置文件,可以按照自己的需求进行修改

详细架构调用图

structure

本体配置说明

settings.go 这里有详细的配置参数解释,需要进一步修改配置请参考该文件