最近有一些监听社交媒体(比如微博、抖音、Instagram等)的需求,在一位大佬的指点下,发现了 RSSHub,可以比较好地满足我的需求。只需要解析 RSS 流,就可以获得最新动态,免去了逐个网站解析的烦恼。
RSSHub 提供了现成的源可供使用,不过缓存的时间较长(10分钟)。而且由于是公用的,个别订阅源可能会出现不可用的情况。为了更加稳定地使用,我们可以自行部署 RSSHub,官方文档介绍了具体的部署过程。这里参照官方文档选用 Docker 进行部署,并作一些补充。
Docker 和 Docker Compose 的安装,可参阅网络文档,或查看本博客的使用 Docker 搭建 Typecho 个人博客一文中的部分内容。
使用 Docker 一键部署
直接运行如下命令,Docker 会自动拉取镜像,并启动容器。
docker run -d --name rsshub -p 1200:1200 diygod/rsshub
随后在浏览器中打开 http://你的IP:1200
,就可以看到 RSSHub 的首页了。
使用如下命令关闭 RSSHub:
docker stop rsshub
如果不需要启用 HTTPS 的话,就可以直接通过 IP 和端口来使用 RSSHub了。或者将域名解析至部署 RSSHub 的服务器,并将容器的 1200 端口映射到公网的 80 端口,就可以直接通过域名来使用。
使用 Docker Compose 部署
RSSHub 本身并不支持直接配置 SSL/TLS 证书,为了启用 HTTPS,需要用到第三方软件对其进行反向代理。这里选用 Nginx,也可以选择 Apache、Caddy 等 Web 服务器。
为了方便服务的启动,这里使用 Docker Compose 来部署,可以同时启动 RSSHub 和 Nginx,并使两个容器处在同一网络内,可以很方便地进行反向代理。
部署前应将域名解析至当前服务器,并准备好与域名匹配的 SSL/TLS 证书。
预备工作完成后就可以开始部署了。首先准备 docker-compose.yml
,挂载路径请按照实际情况进行修改。
version: '3'
services:
nginx:
image: nginx:alpine
container_name: rsshub_nginx
ports:
- 80:80
- 443:443
volumes:
- ./ssl/:/var/www/ssl/:ro
- ./conf/nginx/nginx.conf:/etc/nginx/nginx.conf:ro
- ./conf/nginx/rss.example.com.conf:/etc/nginx/conf.d/rss.example.com.conf:ro
restart: always
depends_on:
- rsshub
rsshub:
image: diygod/rsshub
container_name: rsshub
expose:
- 1200
restart: always
environment:
- NODE_ENV=production
然后准备 Nginx 的配置文件。先是全局配置文件,这里启用了 GZIP 压缩算法。
user www-data www-data;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
charset UTF-8;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 60;
gzip on;
gzip_vary on;
gzip_comp_level 6;
gzip_buffers 16 8k;
gzip_min_length 1000;
gzip_proxied any;
gzip_disable "msie6";
gzip_http_version 1.0;
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript image/svg+xml image/x-icon;
include /etc/nginx/conf.d/*.conf;
}
再是站点配置,请将 example.com
换成自己的域名。
server {
listen 80;
listen [::]:80;
server_name rss.example.com;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl http2 fastopen=3 reuseport;
listen [::]:443 ssl http2 fastopen=3 reuseport;
server_name rss.example.com;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log warn;
ssl_certificate /var/www/ssl/fullchain.cer;
ssl_certificate_key /var/www/ssl/example.com.key;
ssl_session_timeout 1d;
ssl_session_cache shared:SSL:50m;
ssl_session_tickets off;
ssl_dhparam /var/www/ssl/dhparam.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers 'ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256';
ssl_prefer_server_ciphers on;
add_header Strict-Transport-Security max-age=15768000;
ssl_stapling on;
ssl_early_data on;
resolver 114.114.114.114 valid=300s;
resolver_timeout 10s;
location / {
proxy_pass http://rsshub:1200;
}
}
其中 proxy_pass
后 URL 中的地址应和 docker-compose.yml
中的服务名称(不是 container_name
,但本文中恰好一样)保持一致,比如这里就是 rsshub
,端口号保持默认即可。
通过如下命令启动 RSSHub:
docker-compose up -d
启动后就可以用域名通过 HTTPS 来使用 RSSHub 了。
使用如下命令关闭 RSSHub:
docker-compose down
RSSHub 的部署过程就介绍到这,关于 RSSHub 的详细使用以及高级配置,请参阅官方文档。