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 安装流程

安装好了 dockerdocker-compose 后,可以使用git clone https://github.com/Colin-XKL/RSSmanX --depth=1快速克隆本仓库,也可以通过这个镜像地址下载仓库zip文件,Gitee上也有镜像不过不经常更新。

  1. cd 进入文件夹,修改.env中的值,如密码和TTRSS入口URL等
  2. 运行 sudo docker-compose up -d
  3. 等待程序跑完
  4. 安装完成 ✅

2.2 相关事宜

  1. 访问你设置的 SELF_URL 即可看到 Tiny Tiny RSS 的登陆页面,使用默认账户 admin,密码 password 登陆即可开始使用

  2. 如开启海外站点解锁支持,第一次冷启动需要等待 3-5 分钟才能完全启动所有组件。

  3. 数据默认保存位置~/.docker/Database(注意以执行docker命令的用户为准,如使用root账户执行,则文件位于root用户home目录)

  4. 默认情况下只有 TTRSS 和 Huginn 可以从外部访问,其他组件互相可以访问但不能直接从外部访问以提高安全性。组件间互相访问可以使用容器名+指定端口,端口默认为 80,如http://rsshub/xxxxx即可访问到 RSS Man X 内的监听 80 端口的 rsshub 实例。

  5. 在 TTRSS 中将原来订阅的 https://rsshub.app/* 更改为 http://rsshub/* 即可使用 RSS Man X内的自建 RSSHub 实例,并激活反反爬虫和海外源加速等功能

  6. 如无法访问rsshub的官方文档站点,可以使用我维护的反代站点https://rsshub-doc.azure.colinx.one/

  7. 关于 ARM 平台的支持可查阅置顶的 issue,替换部分不支持arm架构的docker镜像为支持arm的镜像即可。

  8. RSS Man X的除 lite 以外的版本默认包含了自托管的 mercury 实例,你只需要在插件配置页面设置 mercury 实例地址为 service.mercury:3000 即可,同理,OpenCC实例地址为service.opencc:3000

  9. 如果部分RSS源不能订阅,检查是否使用了非常规端口。在.env文件中设置RSS_ALLOEW_PORTS

  10. 若部署后某个应用一直无法通过浏览器访问,请检查是否绑定到了6000/6666等特殊端口,浏览器会拦截对这些端口的访问参见这里

  11. ls没有显示.env文件是因为以点开头的文件在Linux中都是默认隐藏的,可以使用ls -a查看到

  12. vi/vim编辑文本太麻烦可以尝试使用nano

  13. RSS Man 里所有容器绑定了服务器的/etc/localtime,使用sudo timedatectl set-timezone Asia/Shanghai 设定系统的时区为上海后,容器里的时区也可以同步,这样日志里的时间就是东八区了

获取帮助

2.3 链接