SSFY系统 README
若要直接运行,请使用如下指令:
./gradlew clean && ./gradlew bootRun
项目文件夹结构说明:
目前整体分为两大板块:configuration和server
Configuration
所有业务的配置,包括切面、拦截器、中间件、消息处理等配置全部放置于此处。 任何带@Configuration注解的配置均放置于此
- entity文件夹:均为下述业务模块的实体类
- exception文件夹:用于存放自定义类和全局异常处理配置类
- response文件夹:用于存放返回配置类和审计类
- satoken文件夹:用于存放用户登录相关配置类
- swagger文件夹:用于存放swagger文档配置类
- threadpool文件夹:用于存放线程池配置
- utils文件夹:用于存放其他类型配置
Server
server主要存放所有的业务逻辑以及Mapper接口。业务逻辑和Mapper需要按照业务进行划分进行分开放置。
目前包含的业务有:
- alertmessage:告警xx模块,处理告警相关信息
- command:指令模块,处理下/发/指令
- defense:防御模块,包括fy对象、fy策略模板两个子模块,用于处理fy对象、fy策略模板信息
- log:日志模块,目前无文件
- rule:规则模块,用于处理静态/动态规则
- task:任务模块,用于处理任务相关信息
- user:用户模块
- whitelist:白名单模块,用于处理白名单配置
Resources
除了项目文件夹外,还有静态资源resources部分,主要存放config、mappers和静态网页资源以及下载文件。
mappers文件夹主要存放所有的Mybatis Mappers,以便于MyBatis进行扫描。
config文件夹存放包括
application.ymlapplication-dev.ymlapplication-test.ymlapplication-prod.yml
等文件, 用于进行SpringBoot和MyBatis基础配置以及方便进行配置切换。
nginx文件夹包括了所有的前端界面和Nginx配置,其中:
- nginx.conf用于进行Nginx服务器基础配置,关键设置为
include /root/nginx/configs/project.conf; - project.conf.template文件是project.conf的模板文件,其可以利用环境变量以及envsubst指令生成project.conf文件(详细代码位于
start_nginx.sh文件) - defense文件夹是前端界面文件夹
Docker相关配置
在docker-ubuntu文件夹中存放的是nginx和springboot的Dockerfile中的protection_ubuntu镜像的制作方法,
如果想要重新制作protection_ubuntu.tar文件,请重新运行docker-ubuntu文件夹中的Dockerfile以制作基础ubuntu镜像。可以使用如下指令制作:
docker build -t protection_ubuntu .
同时,在docker部署之前,请执行以下指令以联网获取GRADLE相关资源依赖以便进行断网部署:
export set GRADLE_USER_HOME=./gradle
./gradlew build && ./graldew clean
在docker-nginx中存放的是nginx前端服务镜像的制作方法,全程理论可以做到断网部署,具体制作方法请检查Dockerfile以及start_nginx.sh
在docker-springboot中存放的是springboot后端服务镜像的制作方法,全程理论可以做到断网部署,具体制作方法请检查Dockerfile以及start_springboot.sh
如果想要制作前后端Docker镜像并开启docker容器,请使用load_nginx.sh和load_springboot.sh两个脚本(load_springboot_multi.sh仅用于测试Nginx服务器负载均衡用)
数据库相关配置
目前该项目使用两种数据库:Doris和MySQL,导入Doris和MySQL表结构可使用如下语句:
# 导入Doris数据库以及表结构,IP、端口、用户名均需要修改
mysql -u root -h 192.168.107.89 -P 9030 < realtime_protection/sql/doris-2024-1-23.sql -p
# 导入MySQL数据库以及表结构,IP、端口、用户名均需要修改
mysql -u root -h 192.168.107.89 -P 3306 < realtime_protection/sql/mysql-2024-1-23.sql -p
# 导入MySQL数据库以及表结构和表中所有数据,IP、端口、用户名均需要修改
mysql -u root -h 192.168.107.89 -P 3306 < realtime_protection/sql/mysql-2024-1-23-with-data.sql -p
如果需要导出Doris表结构和MySQL表结构以及数据,可使用如下语句:
# 导出MySQL表结构和数据
mysqldump -u root -h 192.168.107.89 -P 3306 --databases realtime_protection > mysql-2024-01-23-with-data.sql -p
# 导出MySQL表结构,不导出数据
mysqldump -u root -h 192.168.107.89 -P 3306 --databases realtime_protection -no-data > mysql-2024-01-23-without-data.sql -p
# 导出doris表结构
mysqldump -u root -h 192.168.107.89 -P 9030 --databases command --no-tablespaces -no-data > doris-2024-01-23.sql -p