|
13 jam lalu | |
---|---|---|
.github | 3 tahun lalu | |
database | 2 tahun lalu | |
front | 1 hari lalu | |
src | 13 jam lalu | |
.gitattributes | 7 tahun lalu | |
.gitignore | 3 minggu lalu | |
LICENSE | 7 tahun lalu | |
README.md | 6 hari lalu |
个人博客站项目源码,高性能高安全性低占用的博客系统,这也许是我写过的性能最高的web项目了。仅3MB的代码量! 目前日均处理请求数80-600w次,同时在线活跃用户数60-600人,数据量累计已达到数百万条,数据库+Redis+网站主程序同时运行在一台4核8GB的机器上,浏览器页面请求秒级响应,CPU平均使用率控制在10%左右,内存占用控制在400MB左右。
测试站点1:https://masuit.org,测试站点2:https://masuit.com,测试站点3:https://ldqk.xyz
一旦使用本开源项目以及引用了本项目或包含本项目代码的公司因为违反劳动法(包括但不限定非法裁员、超时用工、雇佣童工等)在任何法律诉讼中败诉的,一经发现,本项目作者有权利追讨本项目的使用费(公司工商注册信息认缴金额的2-5倍作为本项目的授权费),或者直接不允许使用任何包含本项目的源代码!任何性质的外包公司
或996公司
需要使用本类库,请联系作者进行商业授权!其他企业或个人可随意使用不受限。996那叫用人,也是废人。8小时工作制才可以让你有时间自我提升,将来有竞争力。反对996,人人有责!
.NET 9
ASP.NET Core MVC + vue3 + Blazor Server
Entity Framework Core 9 (Npgsql Provider)
Masuit.Tools
Masuit.LuceneEFCore.SearchEngine
Hangfire
FreeRedis + EFCoreSecondLevelCacheInterceptor
YARP Reverse Proxy
Vue 3 + Quasar + Pinia + Vue Router 4
操作系统:Windows 11 24H2
IDE:Visual Studio 2022 v17.14 (或更高版本)
数据库:PostgreSQL 16.x
Redis:Redis 8.x (Windows 版或兼容发行版)
Node.js:20.x LTS (前端构建)
运行时:必须是 .NET 9
操作系统:Windows Server 2019
数据库:PostgreSQL 18.x
Redis:Redis 8.x
运行时:.NET 9 + HTTP/3 (QUIC)
服务器配置:4核+8GB+6Gbps
承载流量:单日请求量平均600w左右,单日带宽1TB左右
请勿使用阿里云、百度云等活动超卖机运行本程序,否则卡出翔!!!
如何判断服务器商是否有超卖:给你的服务器跑个分,如果跑分接近于网络上该处理器公布的分数,则不是超卖的机器,计算公式:总分/核心数进行比较,由于是虚拟机,如果单独比较单核跑分,没有参考意义
最低配置 | 推荐配置 | 豪华配置 | 至尊配置 | |
---|---|---|---|---|
CPU | 1核 | 2核 | 2核 | 4核 |
内存 | 1GB | 2GB | 4GB | 8GB |
带宽 | 1Mbps | 1Mbps | 5Mbps | 1000Mbps+ |
数据库 | pgsql 9 | pgsql 14 | pgsql 15+ | pgsql 16+ |
缓存组件 | Redis 3.2+ | Redis 5.0+ | Redis 5.0+ | Redis 7.0+ |
备注 | 玩玩而已 | 几个人同时访问 | 几百个人同时访问,单日请求量600w以下 | 单日请求量600w以上 |
可直接在线实时监控服务器的运行状态,包括CPU、网络带宽、磁盘使用率、内存占用等情况,百分位统计和图表统计,可记录最近一天的服务器健康状态,通过websocket进行数据的推送,仅支持Windows,且需要Windows安装最新的更新。
对前台用户提交的留言和评论进行审核,当前台用户提交的内容可能包含有敏感词时,会进入人工审核,审核成功才会在前台页中展示。
站内消息包含评论、留言、投稿、文章合并等通知。
对网站的公告进行增删查改管理。支持定时上下架发布。
一些通用的页面管理,可自由灵活的创建静态页面。
主动式的广告投放管理,支持竞价排名,支持在banner、边栏、页内、列表内的广告展示,竞价或权重的高低决定广告出现的概率。支持按地区进行投放。
对网站打赏进行增删查改操作,自动掩码。
当前台用户每Session周期内的关键词搜索,不重复的关键词将会被记录,用于热词统计,仅记录最近一个月内的所有搜索关键词,用于统计当月、7天以及当天的搜索热词。
hangfire的可视化管理页面
服务器文件的在线管理,支持浏览、预览、压缩、解压缩、创建文件夹、上传、下载、打包下载等文件的基本操作。
App_Data:存放网站的一些常规数据,以文本的形式存在,这类数据不需要频繁更新的。
┠─cert文件夹:存放https证书
┠─ban.txt:敏感词库
┠─CustomKeywords.txt:搜索分词词库
┠─denyip.txt:IP地址黑名单
┠─DenyIPRange.txt:IP地址段黑名单
┠─GeoLite2-City.mmdb:MaxMind地址库
┠─ip2region.db:ip2region地址库
┠─mod.txt:审查词库
┠─whitelist.txt:IP地址白名单
Common:基础公共帮助类;
Configs:项目的一些配置对象
Controllers:控制器
Extensions:一些扩展类或一些项目的扩展功能,比如hangfire、ueditor、中间件、拦截器等;
Infrastructure:数据访问基础设施,包含Repository和Services,相当于老项目的DAL和BLL;
Models:存放一些实体类或DTO;
Views:razor视图
wwwroot:项目的所有静态资源;
依赖注入容器:.NET 内置容器 + Autofac(批量注入与属性注入);
静态映射:Riok.Mapperly 4.x;
缓存体系:FreeRedis 管理热点数据,EFCoreSecondLevelCacheInterceptor 提供 EF Core 二级缓存;
定时任务:Hangfire 1.8 统一调度友链回链、文章定时发布、访客统计、索引刷新等任务;
实时通信:Blazor Server + Server-Sent Events推送服务器健康状态;
硬件检测:Masuit.Tools 封装的硬件检测能力;
协议支持:Kestrel + HTTP/3 (QUIC) + 自动 HTTPS/反向代理(YARP);
全文检索:Masuit.LuceneEFCore.SearchEngine 基于 Lucene.NET 4.8 实现全文检索;
中文分词:结巴分词结合本地词库实现精准分词;
断点续传与压缩:Masuit.Tools 提供 resumable download、7z/zip 压缩能力;
Html 字符串操作:htmldiff.net-core 用于版本对比,HtmlAgilityPack 提取 DOM,HtmlSanitizer 提供表单防 XSS;
图床:支持 gitee、github、gitlab 多图床上传及本地/外部存储切换;
拦截器:授权、请求、异常、URL 重写、防火墙等中间件构建纵深防护体系;
请求来源审计:MaxMind + IP2Region + 本地数据库联合判定来访地区;
RSS:WilderMinds.RssSyndication 输出站点 RSS;
EF 批量扩展:Z.EntityFramework.Plus 提供高性能批处理;
文档转换:OpenXml + Mammoth 将上传的 Word 文档转换为 HTML;
在线文件管理:Angular FileManager + 定制 API 支持在线管理服务器文件。
构建工具链基于 Vue CLI 5 + webpack,支持按需加载与 gzip/zip 产物清理。
hangfire实现分布式任务调度;
Z.EntityFramework.Plus实现数据访问层的高性能数据库批量操作;
Lucene.NET实现高性能站内检索;
通过url的敏感词检查过滤恶意流量;
限制客户端的请求频次;
表单的AntiForgeryToken防止恶意提交;
ip2region+MaxMind地址库实现请求来源审查;
用户信息采用端到端RSA非对称加密进行数据传输;
以Windows系统为例,Linux系统请自行折腾。
安装 .NET 9 SDK/运行时:https://dotnet.microsoft.com/zh-cn/download
安装pgsql:pgsql 绿色版
安装 Redis 8.x(Windows 版或兼容发行版):redis for windows绿色版
(可选)安装 Node.js 20.x LTS,用于前端项目构建与调试
编译需要将Masuit.Tools项目和Masuit.LuceneEFCore.SearchEngine项目也一起clone下来,和本项目平级目录存放,才能正常编译,否则,将Masuit.Tools项目和Masuit.LuceneEFCore.SearchEngine项目移除,通过nuget安装也是可以的。
前往Release下载最新的压缩包解压即可。
创建数据库,名称随意,如:myblogs,然后前往Release或仓库目录 database/postgres
下载最新的 PostgreSQL 脚本/备份文件,执行 psql -U postgres -d myblogs -f xxx.sql
还原。
如需迁移到其他数据库,可先还原到 PostgreSQL,再使用 Full Convert 或自定义脚本迁移到目标数据库类型。
主要需要配置的是以下内容,其他配置均为可选项,不配置则表示不启用;
如果你使用了CDN,需要配置TrueClientIPHeader选项为真实IP请求转发头,如cloudflare的叫CF-Connecting-IP。
如果Redis不在本机,需要在配置文件中的Redis节下配置,固定为Redis,值的格式:127.0.0.1:6379,allowadmin=true,若未正确配置,将按默认值“127.0.0.1:6379,allowadmin=true,abortConnect=false”。
如需为 HttpClient 添加代理或反向代理转发,请根据环境调整 HttpClientProxy
与 ReverseProxy
节点。
其他配置请参考appsettings.json的注释按需配置即可。
配置好环境和配置文件后,可直接通过dotnet Masuit.MyBlogs.Core.dll命令或直接双击Masuit.MyBlogs.Core.exe运行,也可以通过nssm挂在为Windows服务运行,或者你也可以尝试在Linux下部署。
进入前端目录:cd front
安装依赖:npm install
(可按需使用 pnpm
/yarn
)
开发模式:npm run dev
,默认端口 http://localhost:8868
生产构建:npm run build
,产物会自动输出到 src/Masuit.MyBlogs.Core/wwwroot/dashboard
IIS:部署时必须将应用程序池的标识设置为LocalSystem,否则无法监控服务器硬件,同时需要安装.NET Core Hosting运行时环境,IIS程序池改为无托管代码。
docker/Linux:自行爬文。
https://127.0.0.1:5001/dashboard
若密码不对,可在debug模式下进入后台【用户管理】下重置密码
基于EntityFrameworkCore和Lucene.NET实现的全文检索搜索引擎:Masuit.LuceneEFCore.SearchEngine
.NET万能框架工具库:Masuit.Tools