RSSManX安装部署指南
RSS Man X是我两年前入坑RSS后,为了方便更多人更方便地使用RSS所发起的一个项目,主要是用docker-compose整合了一些常用的服务如TTRSS、RSSHub、Huginn、OpenCC等并进行了一些优化调整,如自动更新,反反爬虫等。这篇文章会尽可能详尽地讲解安装部署的步骤以及安装过程中可能会遇到的一些问题。
RSS Man X会利用到docker和docker-compose,首先需要确保你的服务器正确安装了这些软件
1. Docker环境准备
检查服务器中是否已经安装了docker和docker-compose,并检查他们的版本是否太老。比如输入docker --version
来检查docker的版本
docker的版本建议不要低于19,docker-compose的版本建议不要低于1.20
~ » docker --version
Docker version 20.10.12, build 20.10.12-0ubuntu2~20.04.1
~ » docker-compose --version
docker-compose version 1.25.0, build unknown
如果上面命令执行后提示command not found
,那么说明并没有安装对应的软件包(或是安装的路径并不在当前用户的PATH变量中,尝试切换到root操作,详细的原因和解决方法见后文)
1.1 Ubuntu/Debian安装Docker
ubuntu和debian主要是用apt安装和管理软件包,可以使用以下命令来安装,根据实际情况选择是否要加sudo。下面以Ubuntu为例。Debian下的安装略有不同,可以参见Docker官方文档,以及清华镜像源。其中download.docker.com
连接不同的可以尝试讲域名部分更换为中科大提供的镜像地址mirrors.ustc.edu.cn/docker-ce
# 首先移除老旧的软件包
sudo apt-get remove docker docker-engine docker.io containerd runc
sudo apt-get update
# 安装一些必要的依赖
sudo apt-get install \
ca-certificates \
curl \
gnupg \
lsb-release
如果你的服务器在墙外,可以直接使用docker官方的软件源
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
如果你的服务器在墙内,可以使用由中科大提供的镜像
curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu \
$(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
导入docker软件源后即可开始安装docker,安装完成后可以输入docker --version
来检查docker的版本
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin
1.2 CentOS/Fedora安装Docker
CentOS和Fedora使用yum安装和管理软件包,新版本则是使用dnf,不过两者功能一致且高度兼容。下面以CentOS为例,Fedora可参见官方文档或清华镜像源
# 1. 首先移除老旧的软件包
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
# 2.
sudo yum install -y yum-utils
# 3.A 之后使用官方docker软件库
sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
# 3.B 墙内方案
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
sudo sed -i 's+download.docker.com+mirrors.tuna.tsinghua.edu.cn/docker-ce+' /etc/yum.repos.d/docker-ce.repo
# 4. 即可开始安装
sudo yum update
sudo yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin
1.3 安装或更新docker-compose
docker-compose目前有两个主要版本V1和V2,都是可用的。V1使用Python编写,使用时类似sudo docker-compose up -d
,V2则是Golang编写,与前者高度兼容,但是是作为docker的插件安装的,使用时类似sudo docker compose up -d
,中间的短杠不需要了。
如果是按照上文的步骤安装的docker,那么默认已经安装了docker compose v2,可以通过docker compose version
查看版本
~ » docker compose version
Docker Compose version v2.3.3
如果需要是安装的比较老的v1版本的docker-compose,想要单纯更新docker-compose而又不想动其他东西的话,可以更新安装v1版本的docker-compose。
首先删除老旧版本(如果有的话)
rm $DOCKER_CONFIG/cli-plugins/docker-compose
sudo rm /usr/local/lib/docker/cli-plugins/docker-compose
pip uninstall docker-compose
然后使用pip来安装
pip3 install docker-compose
墙内也可以临时使用镜像源下载
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple
如果提示pip命令不存在需要先安装一下
# Ubuntu/Debian
sudo apt install python3-pip
# CentOS/Fedora
sudo yum install python3-pip
如果pip报错试着升级一下pip的版本
python3 -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple --upgrade pip
1.4 为Docker配置镜像源
如果Docker下载镜像非常慢,你可能需要单独配置一下Docker的镜像源。==注意:Docker安装软件源的镜像和Docker镜像或者说映像的国内源并不是同一个,英文表述可能更准确一些:==
- 上文安装docker时配置的是docker的repo,repo里含有docker的软件包,国内的镜像为Docker CE安装软件包的镜像
- 现在我们要配置的是Docker Hub的Mirror,Docker里拉取Image默认会访问Docker Hub,国内有多个Docker Hub镜像或是Docker镜像加速器,如中科大的源
在/etc/docker/daemon.json
文件中写入以下内容,如不存在可先行创建,注意json中列表的最后一项末尾是没有逗号的
{
"registry-mirrors": [
"https://mirror.ccs.tencentyun.com",
"https://docker.mirrors.ustc.edu.cn"
]
}
配置完成后sudo systemctl restart docker
重启docker服务,然后输入sudo docker info
,在输出结果的末尾可以看到Registry Mirrors
里会出现我们刚刚配置的Docker Hub镜像
群辉等NAS的系统并不是标准版Linux,安装的也是魔改版docker,上面的配置文件地址并不适用,建议自行搜索对应的文档或教程。
2. 安装RSS Man X
RSS MAN X项目旨在为 RSS 的同好提供一个方便地搭建自己的 RSS 服务的捷径,毕竟不是所有 RSS 爱好者都懂代码 😂。RSS Man X能够有 RSS 订阅管理、RSS 在线阅读界面,进阶功能包括服务健康自检、海外站点 RSS 解锁等,提供不同的版本供选择,三个版本的 docker-compose
文件对应不同的需求,包含的组件和服务有差异。
组件 / 服务 / 功能名称 | 标准版 | Lite 版 | Ultimate 版 ✨ |
---|---|---|---|
TTRSS | ✅ | ✅ | ✅ |
RSSHub | ✅ | ✅ | ✅ |
Huginn | ✅ | ||
Mercury | ✅ | ✅ | |
OpenCC | ✅ | ||
Redis | ✅ | ✅ | |
Browserless | ✅ | ||
数据持久化保存 | ✅ | ✅ | ✅ |
容器自动更新 | ✅ | ✅ | |
容器健康检查 | ✅ | ✅ | |
海外站点加速 | ✅ | ||
智能路由 | ✅ | ||
反反爬虫 | ✅ |
2.1 安装流程
安装好了 docker
和 docker-compose
后,可以使用git clone https://github.com/Colin-XKL/RSSmanX --depth=1
快速克隆本仓库,也可以通过这个镜像地址下载仓库zip文件,Gitee上也有镜像不过不经常更新。
- cd 进入文件夹,修改
.env
中的值,如密码和TTRSS入口URL等 - 运行
sudo docker-compose up -d
- 等待程序跑完
- 安装完成 ✅
2.2 相关事宜
访问你设置的
SELF_URL
即可看到 Tiny Tiny RSS 的登陆页面,使用默认账户admin
,密码password
登陆即可开始使用如开启海外站点解锁支持,第一次冷启动需要等待 3-5 分钟才能完全启动所有组件。
数据默认保存位置
~/.docker/Database
(注意以执行docker命令的用户为准,如使用root账户执行,则文件位于root用户home目录)默认情况下只有 TTRSS 和 Huginn 可以从外部访问,其他组件互相可以访问但不能直接从外部访问以提高安全性。组件间互相访问可以使用
容器名+指定端口
,端口默认为 80,如http://rsshub/xxxxx
即可访问到 RSS Man X 内的监听 80 端口的 rsshub 实例。在 TTRSS 中将原来订阅的
https://rsshub.app/*
更改为http://rsshub/*
即可使用 RSS Man X内的自建 RSSHub 实例,并激活反反爬虫和海外源加速等功能如无法访问rsshub的官方文档站点,可以使用我维护的反代站点https://rsshub-doc.azure.colinx.one/
关于 ARM 平台的支持可查阅置顶的 issue,替换部分不支持arm架构的docker镜像为支持arm的镜像即可。
RSS Man X的除 lite 以外的版本默认包含了自托管的 mercury 实例,你只需要在插件配置页面设置 mercury 实例地址为
service.mercury:3000
即可,同理,OpenCC实例地址为service.opencc:3000
如果部分RSS源不能订阅,检查是否使用了非常规端口。在
.env
文件中设置RSS_ALLOEW_PORTS
若部署后某个应用一直无法通过浏览器访问,请检查是否绑定到了
6000
/6666
等特殊端口,浏览器会拦截对这些端口的访问参见这里ls
没有显示.env
文件是因为以点开头的文件在Linux中都是默认隐藏的,可以使用ls -a
查看到vi/vim编辑文本太麻烦可以尝试使用nano
RSS Man 里所有容器绑定了服务器的/etc/localtime,使用
sudo timedatectl set-timezone Asia/Shanghai
设定系统的时区为上海后,容器里的时区也可以同步,这样日志里的时间就是东八区了
获取帮助
- For Tiny tiny RSS problems: https://tt-rss.org/wiki.php http://ttrss.henry.wang/
- For RSShub problems: https://docs.rsshub.app/faq.html
- For Huginn problems: https://github.com/huginn/huginn#readme