实时展示rss订阅最新消息
-
打包后镜像大小仅有约20MB,通过docker实现一键部署
-
支持自定义配置页面数据自动刷新
-
响应式布局,能够兼容不同的屏幕大小
-
良好的SEO,首次加载使用模版引擎快速展示页面内容
-
支持添加多个RSS订阅链接
-
简洁的页面布局,可以查看每个订阅链接最后更新时间
-
支持夜间模式
-
config.json配置文件支持热更新
-
在原作者基础上,进行二次开发,增加了识别关键词后,推送通知到飞书和Telegram(2024年6月2日) 注意⚠:docker-compose.yml 中端口默认是9898
2023年7月28日,进行了界面改版和升级
已提供 docker-compose 方式,可以一键完成安装启动运行 注意⚠:docker-compose.yml 中端口默认是9898
部署前请先配置,配置都在 config.json 中修改,使用前请先去 config.json 中增加自己飞书机器人的webhook地址 或 Telegram 的 token 和 chat_id,注意
config.json 中的 refresh 单位为分钟,表示多少分钟请求一次所需的 rss 订阅源
TG机器人创建和权限赋予教程请看 https://www.telegramhcn.com/article/161.html
配置文件位于config.json,sources是RSS订阅链接,示例如下
{
"values": [
"https://linux.do/latest.rss",
"https://rss.nodeseek.com",
"https://hostloc.com/forum.php?mod=rss&fid=45&auth=389ec3vtQanmEuRoghE%2FpZPWnYCPmvwWgSa7RsfjbQ%2BJpA%2F6y6eHAx%2FKqtmPOg",
"https://v2ex.com/feed/tab/tech.xml",
"https://www.dalao.net/feed.htm"
],
"refresh": 5,
"autoUpdatePush": 7,
"nightStartTime": "06:30:00",
"nightEndTime": "19:30:00",
"keywords": ["cc","cloudcone","rn","racknerd","咸鱼","4837","jpp","hk2p"],
"notify" : {
"feishu": {
"api": ""
},
"telegram": {
"api": "https://api.telegram.org/bot${token}/sendMessage",
"chat_id":"",
"token": ""
}
},
"archives": "archives.txt"
}
名称 | 说明 |
---|---|
values | rss订阅链接(必填) |
refresh | rss订阅更新时间间隔,单位分钟(必填) |
autoUpdatePush | 自动刷新间隔,默认为0,不开启。效果为前端每autoUpdatePush分钟自动更新页面信息,单位分钟(非必填) |
nightStartTime | 日间开始时间 ,如 06:30:00 |
nightEndTime | 日间结束时间,如 19:30:00 |
环境要求:Git、Docker、Docker-Compose
克隆项目
git clone https://github.com/okhanyu/rss-reader
进入rss-reader文件夹,运行项目
docker-compose up -d
国内服务器将Dockerfile中取消下面注释使用 go mod 镜像
#RUN go env -w GO111MODULE=on && \
# go env -w GOPROXY=https://goproxy.cn,direct
部署成功后,通过ip+端口号访问
这里需要注意/ws,若不设置proxy_read_timeout参数,则默认1分钟断开。静态文件增加gzip可以大幅压缩网络传输数据
server {
listen 443 ssl;
server_name 域名;
ssl_certificate 域名证书.cer;
ssl_certificate_key 域名证书.key;
gzip on;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
location / {
proxy_pass http://localhost:9898;
}
location /ws {
proxy_pass http://localhost:9898/ws;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header Host $host;
proxy_read_timeout 300s;
}
}
server {
listen 80;
server_name 域名;
rewrite ^(.*)$ https://$host$1 permanent;
}