2019 年的今天,白菜价的服务器应有尽有。别的小朋友们服务器上面跑着各式各样的东西:博客、云盘、监控脚本……再看看我们那台闲置很久的阿里云,都已经开始「落灰」了。🤦♂️ 不如把那台服务器拿出来,部署一个属于自己的 RSS 服务器。
注:事实上,少数派上面很久之前就介绍过 Tiny Tiny RSS 的知识,当年的文章位于 如何搭建属于自己的 RSS 服务,高效精准获取信息。今天我主要介绍的是一个更为方便的,集 Tiny Tiny RSS 本身、数据库服务、Mercury 全文抓取服务、OpenCC 繁简自动转换服务以及常用插件、主题等内容为一体的安装方法,以及如何为我们自己部署的 Tiny Tiny RSS 配置域名和 HTTPS 支持的方法。
RSS 服务
相信少数派的朋友们大部分都对 RSS 已经非常了解了,对于第一次接触 RSS 的同学,推荐大家阅读少数派之前的文章。
关联阅读:高效获取信息,你需要这份 RSS 入门指南。
市面上有非常多的 RSS 聚合服务,来帮助我们统一管理、订阅、更新、筛选 RSS 源推送给我们的更新信息,避免我们被海量的文章淹没,也能保证我们多个设备上 RSS 的阅读进度一致。Feedly、Inoreader 等等都是非常不错的 RSS 服务,但是它们的免费版本都有着一定的限制,有时候无法满足我们的全部功能需求,而动辄一个月数十刀的订阅费用又让人望而却步。不慌,开源的 RSS 服务:Tiny Tiny RSS 可以满足我们 RSS 订阅的全部需求!
Tiny Tiny RSS 的搭建
Tiny Tiny RSS 是一个非常优秀的开源免费 RSS 服务引擎,可以直接部署在我们自己的服务器上面。借助于 Docker 优秀方便的容器技术和 Let's Encrypt 异常简单的 SSL 证书签署机器人 certbot
,我们几分钟之内就可以部署上线属于我们自己的 RSS 服务,运行在我们可控的服务器上,环境稳定,刷新及时,并且完全免费。👍(当然,除了服务器需要一定的费用。)
在容器、HTTPS 证书自动签署和虚拟化技术极度发达的今天,我们的整个部署过程非常方便简单,甚至只利用一台 iPad,我们就可以部署成功。接下来,我只利用 iPad 进行讲解演示我们的部署过程。请大家坐和放宽,我们立刻开始。
准备工作
在开始之前,首先我们需要准备一个位于公网的服务器,以及一个可以通过 SSH 连接到服务器上的本地设备。这里我使用我同(bai)学(piao)的已经备案的阿里云服务器作为运行 Tiny Tiny RSS 的服务器,并使用 iPad 和 Blink Shell(一个支持 SSH 协议的 iOS 终端 App)作为我的操作设备。Blink Shell 是 iPad 上面最好用的 SSH/Mosh 工具,推荐大家使用。我们在 Blink Shell 中配置好服务器私钥,通过 SSH 登录服务器。
利用 Docker 部署 Tiny Tiny RSS
安装 Docker
Docker 是非常优秀的虚拟化容器,借助于 Docker 我们可以方便的部署 Tiny Tiny RSS,首先我们在服务器上安装 Docker 本体。在服务器上面执行下面命令来安装 Docker:
curl -fsSL https://get.docker.com/ | sh
然后启动 Docker 服务:
sudo systemctl start docker
然后,我们检查一下 Docker 是否启动成功。我们执行命令 sudo systemctl status docker
:
看到如上的输出,说明我们 Docker 服务启动成功。1
安装 docker-compose
接下来我们安装 docker-compose
:一个管理和启动多个 Docker 容器的工具。由于 Tiny Tiny RSS 依赖有 PostgreSQL 的数据库服务以及 mercury_fulltext 的全文抓取服务等等,这些服务我们都借助于 Docker 部署,因此利用 docker-compose
就会大大降低我们的部署难度。
我们继续,在服务器上面执行下面的命令来安装 docker-compose
:2
curl -L https://github.com/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
之后给予安装好的 docker-compose
可执行权限:
chmod +x /usr/local/bin/docker-compose
最后我们运行 docker-compose --version
来检查安装是否成功。如果有如下输出,说明我们的 docker-compose
安装成功:
安装 Tiny Tiny RSS 及其周边服务
准备工作已经全部完成,接下来我们下载由 Awesome-TTRSS 配置的 Tiny Tiny RSS 服务的 docker-compose
配置文件:
# 创建 ttrss 目录并进入
mkdir ttrss && cd ttrss
# 利用 curl 下载 ttrss 的 docker-compose 配置文件至服务器
curl -fLo docker-compose.yml https://github.com/HenryQW/Awesome-TTRSS/raw/master/docker-compose.yml
修改 docker-compose.yml
里面的内容:
- 在配置文件的第 7 行和第 23 行,将 PostgreSQL 数据库的默认密码进行修改。暴露在公网的数据库使用默认密码非常危险。
- 在配置文件的第 18 行,将 Tiny Tiny RSS 服务的部署网址修改为我们实际的部署网址。比如我的部署网址是 https://ttrss.tenkeyseven.com
- 注意,如果你的部署 URL 包含端口(默认部署端口为 181 端口),那么这里的 URL 也需要加上端口号,格式为 {网址}:{端口}不过不必担心,如果你这里的 URL 配置不正确,那么访问 Tiny Tiny RSS 的时候,Tiny Tiny RSS 会提醒你修改这里的值为正确的 URL,按照提醒进行配置即可
之后,我们保存配置文件,启动 Tiny Tiny RSS 服务。在刚刚的 ttrss
目录下执行:
docker-compose up -d
等待脚本执行完成,如果一切没有问题,那么接下来输入 docker ps
,我们应该看到类似下面的结果:
上面内容表示我们开启了四个 Docker 容器,分别是:
- Tiny Tiny RSS 本身,监听端口为
0.0.0.0:181 → 80
,同时暴露给外网 - PostgreSQL 数据库服务
- Mercury 全文抓取服务
- OpenCC 简体、繁体中文转换服务
如果发现问题,修改 docker-compose 的配置文件后,需要执行下面的命令重启 Docker 容器们:
# 关闭 Docker 容器们
docker-compose down
# 删除已停止的 Docker 容器
docker-compose rm
# ……
# 修改 docker-compose 配置文件
# ……
# 再次开启 Docker 服务
docker-compose up -d
安装 Nginx 作为 Docker 容器的反向代理
事实上,到上一步,如果我们访问 {服务器 IP}:181
,应该可以直接看到 Tiny Tiny RSS 的 Web 前端,但是 Tiny Tiny RSS 并不能直接配置 SSL 证书,也就没法添加 HTTPS 支持。我们利用 Nginx 作为反向代理服务器,即可方便的给 Tiny Tiny RSS 单独绑定一个我们希望的域名,并利用 Let's Encrypt 来部署 HTTPS。
安装 Nginx
首先我们来安装 Nginx,以 CentOS 为例,我们直接执行下面命令即可:
sudo yum install nginx
之后开启 Nginx 服务:
sudo systemctl start nginx
检查 Nginx 是否启动成功:
sudo systemctl status nginx
开启 HTTPS 支持
之后,我们利用 Let's Encrypt 提供的 certbot
直接为 Nginx 配置 SSL 证书3 。以 CentOS 为例子,首先,我们执行下面的命令安装 certbot
:
sudo yum install certbot python2-certbot-nginx
然后运行 certbot
来签署 SSL 证书并自动配置 Nginx 服务:
sudo certbot --nginx
在这里,certbot
会要求我们输入我们希望签署 SSL 证书的域名,我们选择为 Tiny Tiny RSS 分配的域名(比如我的就是 ttrss.tenkeyseven.com
)即可。另外,如果 certbot
询问是否需要将访问该网址的全部流量重定向至 HTTPS,那么选择「是」即可。我们等待脚本执行签署任务完毕,然后重启 Nginx 服务:
sudo systemctl restart nginx
此时我们如果直接访问这一域名,应该就可以看到带有 HTTPS 的 Nginx 默认网站:
接下来,我们修改 Nginx 的配置文件,配置 Nginx 反向代理,将外部访问你的域名(对我来说,就是: https://ttrss.tenkeyseven.com
)的请求指向我们刚刚部署好的 Tiny Tiny RSS 服务。对服务器来说,也就是 127.0.0.1:181
这一地址。(如果你没有更改 Tiny Tiny RSS 的端口号的话。)
Nginx 的配置文件位于 /etc/nginx/nginx.conf
,我们打开这一文件:
- 在
http
项下,server
项前定义upstream
服务:
upstream ttrssdev {
server 127.0.0.1:181;
keepalive 64;
}
- 在刚刚
certbot
为我们生成好的相应域名配置的server
项下,注释掉第一行定义root
的内容,并将location /
项修改为:
location / {
proxy_redirect off;
proxy_pass http://ttrssdev;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Ssl on;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Frame-Options SAMEORIGIN;
client_max_body_size 100m;
client_body_buffer_size 128k;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
}
这样,我们再次执行 sudo systemctl restart nginx
重启 Nginx 服务,一切顺利的话,我们就可以通过我们刚刚签署 SSL 证书的域名访问我们部署好的 Tiny Tiny RSS 服务了!鼓掌 👏
Tiny Tiny RSS 的默认管理员账户、密码是 admin 和 password,请在第一时间进行修改。
配置 Tiny Tiny RSS
如果上面步骤没有问题的话,我们在服务器上面所部署的 Tiny Tiny RSS 本身就已经包含了:
- Mercury 全文提取服务(默认未开启)
- OpenCC 繁简自动转换服务(默认未开启)
- Fever 格式输出插件(默认已开启,用来和 Reeder 等客户端进行连接)
- 包括 Feedly、RSSHub 在内的多款主题
- 等等……
我们不需要多余的配置,开箱即可使用上面的主题和插件,根本不需要操心其他服务的部署和安装。我们登录自己的 Tiny Tiny RSS,在右上角「设置→ 插件」中即可启用上述插件,在「设置 → 主题」处就可以更改我们部署的 Tiny Tiny RSS 所用的主题。这些插件和主题在 如何搭建属于自己的 RSS 服务,高效精准获取信息 中已经介绍了使用方法,这里我就不再赘述了。
如果有同学对上面的配置还有问题,请直接参考 Awesome TTRSS 的官方文档:🐋 Awesome TTRSS | 插件
小结
Tiny Tiny RSS 的配置到这里就基本结束了,我相信你通过上面的配置一定已经在自己的服务器上部署成功了 Tiny Tiny RSS 服务,并为它添加了域名和 HTTPS 的支持。另外,Tiny Tiny RSS 还自带了账号系统,可以邀请其他志同道合的朋友们一起使用我们自己部署的 Tiny Tiny RSS。感谢阅读。
> 下载少数派 客户端、关注 少数派公众号,了解更多有趣的应用 🚀
> 特惠、好用的硬件产品,尽在 少数派sspai官方店铺 🛒
© 本文著作权归作者所有,并授权少数派独家使用,未经少数派许可,不得转载使用。