每天刷十几个平台的热榜太累了?我用一个页面全部搞定

作者:扑克中的黑桃A日期:2026/4/22

这里写目录标题

    • 前言
    • 1.什么是DailyHot?
    • 2.在飞牛OS上部署DailyHot
    • 3.docker部署DailyHot
    • 4.使用DailyHot
    • 5.安装cpolar内网穿透
    • 6.配置公网地址
    • 7.保留固定公网地址
    • 总结

前言

每天看热点,你要打开几个 App?

微博、知乎、Hacker News、V2EX、豆瓣、少数派……每个平台都有热榜,每个平台都得点进去刷一遍。等把这些都刷完,半个小时过去了,真正有用的信息反而被稀释了。

而且还有个更现实的问题——你在公司想看看知乎热榜发生了啥,结果公司网络限制,知乎打不开;你在地铁上想刷刷 Twitter(X)的趋势,结果信号不好加载不出来。平台越来越多,但访问受限的情况也越来越多。

有没有一种可能,把这些平台的热榜内容聚合到一个页面里,打开一个网址,所有热点一览无余,而且完全不用登录、不用看广告、不被算法干扰?

DailyHot 解决的就是这个问题。它是一个开源的热榜聚合工具,能够抓取微博、知乎、Hacker News、V2EX、豆瓣、少数派等多个平台的实时热门内容,统一展示在一个简洁的 Web 页面里。你可以把它理解为一个"属于自己的信息中枢"——数据跑在自己的服务器上,不依赖任何第三方,干净、没有追踪、没有推荐干扰。

这篇会讲清楚怎么把它跑起来,以及怎么配合 cpolar 实现外网访问——毕竟服务跑在局域网里,出门之后就访不了了,这个问题怎么解决,正文里会细说。

本教程将手把手带你从零部署DailyHot,只需一台普通服务器(甚至树莓派)和一条Docker命令,你就能拥有一个7×24小时运行的个人热榜仪表盘。从此,热点尽在掌握,信息主权回归自己手中。

准备好了吗?让我们开始吧!

image-20260306152455259

1.什么是DailyHot?

DailyHot是一个开源、轻量、可自托管的 每日热榜聚合工具,旨在帮助用户一键搭建属于自己的“全网热点仪表盘”。

核心功能

  • 聚合多平台热门内容
    自动抓取主流社区和新闻源(如微博热搜、知乎热榜、V2EX、Hacker News、豆瓣、少数派、微信公众号热门等)的实时榜单。
  • 私有化部署,数据自主
    所有数据在你自己的服务器上运行,不依赖第三方服务,无广告、无追踪、无账号体系。
  • 简洁美观的 Web 界面
    提供响应式网页界面,支持 PC 和手机访问,清爽无干扰,专注阅读热点。
  • 一键部署,低门槛运维
    基于Docker构建,只需一条命令即可启动,无需编程或复杂配置。
  • 自动更新 + 持久运行
    内置定时任务,每天自动刷新榜单;配合–restart unless-stopped参数,确保服务长期稳定运行。

技术特点

  • 容器化:使用Docker镜像(如rehiy/dailyhot)
  • 轻量级:资源占用低,适合云服务器、NAS、树莓派等设备
  • 开源免费:代码通常托管在GitHub,社区可参与维护与扩展

适合谁用?

  • 厌倦了算法推荐和信息茧房的用户
  • 想快速掌握全网动态的技术爱好者
  • 希望搭建个人知识/信息中枢的极客
  • 对数据隐私和自托管(Self-Hosted)理念感兴趣的人

如果你厌倦了在十几个App之间来回切换刷热榜,不如用DailyHot把它们全部“收编”到一个页面——干净、高效、完全由你掌控。

2.在飞牛OS上部署DailyHot

没有飞牛的小伙伴可以参考这份视频:https://www.bilibili.com/video/BV1o3sheAEwB/?spm\_id\_from=333.1387.search.video\_card.click

登录到群晖页面后,我们打开docker,部署dailyhot:

在“镜像仓库”搜索“DailyHot”后,点击下载:

9a1e295e5c0eefbcdcdb1c83704c2399

如图所示,点击确定:

c41d33debaca2c0d6837d4d8ea748cfd

启动开机自启动(根据自己所需),点击下一步:

c2ab77cef67ecbeddfc3c4380fc0d623

自定义端口,我这里是5956,点击下一步:

a765cc40e8dcb82b93d512be4eabb654

返回后,我们可以看见DailyHot已经启动了:

bbe966afe9de2e385b4d161e7112dd0a

启动后,打开浏览器,以飞牛的IP地址+设置的端口进行访问 以本机为例:http://192.168.42.147:5956

eed7ad74ebda01b345581a714bb674e1

3.docker部署DailyHot

当然你的任何设备,只要包括docker,就可以使用docker一键部署:

1docker run --restart unless-stopped --name dailyhot -p 6688:6688 rehiy/dailyhot
2

74738d07d4b9ad41cc08834b1439a992

也可以使用docker-compose部署:

新建文件夹:

1mkdir /docker/dailyhot && cd /dockerdailyhot
2

创建配置文件:

1vim docker-compose.yml
2

修改配置文件:

1version: '3'
2services:
3  dailyhot-web:
4    image: liwangsheng/dailyhot-web
5    container_name: dailyhot-web
6    ports:
7      - "5956:80"
8    environment:
9      - API=https://hot-api.bbit.fun
10    restart: always
11

最后启动即可:

1docker-compose up -d
2

4.使用DailyHot

登录到dailyhot主页面后,会出现十几个App的热榜,就不用来回刷app了,例如,我点进哔哩哔哩的热榜:

0a47548f48096ae72133a69c70f926cf

将会直接跳转到哔哩哔哩所在页面:

225715c22c3427076dab090b977bf315

各个平台跳转均很流畅:

c93ddaa21ddcbaa2882029f0afee39a9

还可以在设置栏,更改榜单顺序,把自己经常看的添加到前面:

beee07caa57bfbffb720cf64c224e1fa

使用起来是不是特别方便呢!

你已经成功用一条Docker命令部署了DailyHot——一个干净、私有的每日热榜仪表盘。它安静地运行在你的本地服务器、NAS或树莓派上,只属于你,不被算法干扰。

但问题来了:

“我出门在外,怎么访问家里的DailyHot?”

默认情况下,DailyHot只能在局域网内访问(比如 http://192.168.42.147:5956)。一旦离开家,这个强大的信息中枢就“失联”了。要让它真正成为“随身热榜”,你需要一个关键能力:将内网服务安全暴露到公网。

这时候,cpolar就登场了。

cpolar是一款简单高效的内网穿透工具,无需公网 IP、不用配置路由器,只需几行命令,就能为你的DailyHot生成一个可从互联网任意位置访问的HTTPS地址。无论你在地铁、咖啡馆还是出差途中,打开浏览器,输入链接,你的专属热榜即刻呈现。

本教程将继续手把手教你:

  • 安装并配置cpolar
  • 将DailyHot通过cpolar映射到公网
  • 绑定自定义域名(可选)实现专业级访问体验

5.安装cpolar内网穿透

首先打开飞牛云NAS设置界面,开启ssh 连接,端口默认为22即可,开启后,我们就可以ssh 连接飞牛云NAS执行命令:

5f4dd052629beae55990037fb1cc7d73

然后我们通过输入飞牛云NAS的IP地址ssh远程连接进去,因为fnOS是基于Linux 内核开发的,所以我们可以按照cpolar的Linux安装方法进行安装:

09e2f65ca7688ad8d6791293491c8175

连接后执行下面cpolar Linux 安装命令:

1sudo curl https://get.cpolar.sh | sh
2

再次输入飞牛云nas的密码确认后即可自动安装

安装完成后,执行下方命令查看cpolar服务状态:(如图所示即为正常启动)

1sudo systemctl status cpolar
2

afe8e53fc04d11c1a147129d43332429

Cpolar安装和成功启动服务后,在浏览器上输入飞牛云主机IP加9200端口即:【http://localhost:9200】访问Cpolar管理界面,使用官网注册的账号登录,登录后即可看到配置界面,接下来在web界面配置即可:

2ada61864d693faaac167c396ef8ad75

6.配置公网地址

登录cpolar web UI管理界面后,点击左侧仪表盘的隧道管理——创建隧道:

  • 隧道名称:可自定义,本例使用了:dailyhot,注意不要与已有的隧道名称重复
  • 协议:http
  • 本地地址:5956
  • 域名类型:随机域名
  • 地区:选择China Top
    点击创建:

image-20260306162718415

创建成功后,打开左侧在线隧道列表,可以看到刚刚通过创建隧道生成了公网地址,接下来就可以在其他电脑或者移动端设备(异地)上,使用地址访问。

image-20260306162751498

访问成功。

image-20260306162830841

7.保留固定公网地址

使用cpolar为其配置二级子域名,该地址为固定地址,不会随机变化。

image-20250909154450325

点击左侧的预留,选择保留二级子域名,地区选择china top,然后设置一个二级子域名名称,我这里演示使用的是dailyhot,大家可以自定义。填写备注信息,点击保留。

image-20260306162940060

登录cpolar web UI管理界面,点击左侧仪表盘的隧道管理——隧道列表,找到所要配置的隧道,点击右侧的编辑

image-20260306163019189

修改隧道信息,将保留成功的二级子域名配置到隧道中

  • 域名类型:选择二级子域名
  • Sub Domain:填写保留成功的二级子域名
  • 地区: China Top

点击更新

image-20260306163049318

最后,我们使用固定的公网地址在任意设备的浏览器中访问,可以看到成功访问本地部署的页面,这样一个永久不会变化的二级子域名公网网址即设置好了。

image-20260306163130107

从此,你的DailyHot不再是“家里看看”,而是7×24小时在线的个人热点门户。

总结

回到开头的问题——每天刷十几个平台的热榜太累,有没有办法一个页面搞定?用 DailyHot 搭建自己的热榜仪表盘,是一个值得一试的思路。

整个部署过程不复杂,Docker 命令几分钟能跑起来,后续就是自动抓取、自动刷新,不用每天重复操作。局限的地方也得说清楚:热榜数据依赖平台接口,平台改版可能导致抓取失效;另外自托管意味着你要自己保证服务器稳定。

如果你也在找一种比"刷各个平台 App"更高效的信息获取方式,可以按正文步骤试着跑一下。有什么问题欢迎留言。


每天刷十几个平台的热榜太累了?我用一个页面全部搞定》 是转载文章,点击查看原文


相关推荐


LangGraph 入门到精通0x02:基础 API (二)
chaors2026/4/14

前言 今天继续学习一些 LangGraph 常用到的基础 API。废话少说上干货。 .点语法 Graph 的创建可以使用看着更简洁的 .语法。 graph = ( StateGraph(State) .add_node(a) .add_node(b) .add_edge(START, "a") .add_edge("a", "b") .add_edge("b", END) .compile() ) 步骤序列 StateGraph(St


你的 Android App 可能白白损失了 35% 的性能——R8 全模式配置详解
陆业聪2026/4/6

字节跳动的工程师优化启动速度时,可能花了数周分析 trace、改代码;Monzo 的团队却只改了一行配置,性能指标全线提升了 35%。这不是段子,是 Google 官方 blog 2026 年 3 月底发出来的案例。 问题来了:你的项目,是不是也开着 R8,但根本没用对? R8 到底做了什么——大多数人理解是错的 很多人对 R8 的理解停留在「代码混淆 + 压缩」。打开 minifyEnabled true,觉得任务完成了。 但 R8 实际上分两种工作模式: • 兼容模式(Compatibili


核心概念层——深入理解 Agent 是什么
想打游戏的程序猿2026/3/28

1 Agent vs ChatBot:从根本上理解区别 1.1 一个直观的例子 假设你对 AI 说:"帮我分析一下我们公司上周的销售数据,找出表现最好的产品,并给团队发一封总结邮件"。 ChatBot 的反应: ChatBot: "要分析销售数据,你可以按以下步骤操作: 1. 打开数据库,执行 SQL 查询获取上周的销售记录 2. 使用 Excel 或 Python 进行数据汇总 3. 找出销售额最高的产品 4. 撰写邮件总结发送给团队 你需要我帮你写 SQL 查询语句吗?" → ChatB


配置钉钉龙虾OpenClaw机器人调用OpenMetadata
光于前裕于后2026/3/20

目录 一、前言1️⃣钉钉(DingTalk)2️⃣OpenClaw3️⃣OpenMetadata4️⃣MCP(Model Context Protocol) 二、安装OpenClaw三、配置OpenClaw钉钉机器人四、调用OpenMetadata MCP 一、前言 先介绍下这四个工具/协议的定位与核心能力,本文将从零开始配置。 1️⃣钉钉(DingTalk) 阿里巴巴旗下的企业协作平台,2014年上线,是中国市场份额最大的企业即时通讯与办公套件之一。 核心能


10分钟搭建 Windows + WSL + Codex环境
Lei_official2026/3/12

并不是 AI 替代人,而是会用 AI 的人替代不会用 AI 的人。 我的大模型使用历程 从2023年秋季,我开始使用对话型的大模型,提升工作和学习的效率,以及回答一些生活上的常识问题。最开始是 ChatGPT 的免费版本,随着使用频率提高,慢慢会遇到问答超过上限的情况。随后便开通了Plus订阅直至今日。期间也曾使用过 Deepseek、Gemini、Minimax 等等,不过最主要的仍然是 ChatGPT,个人感觉它在回答的质量、速度、上下文方面体验最好。 在这段历程里,网页对话型 的 AI


MySQL中 SHOW FULL PROCESSLIST` 输出中 `State` 列的所有可能值
左Python右Java2026/3/4

SHOW FULL PROCESSLIST输出中State` 列的所有可能值,以及这些值代表的含义,这能帮你精准判断数据库连接的状态(包括锁相关、执行状态等)。 一、State 列核心分类及含义 State 列描述了当前线程正在执行的操作状态,不同状态对应不同的数据库行为,以下是最常见且实用的分类(按场景划分): 1. 锁相关状态(排查锁表核心) 这是你最关心的锁表相关状态,直接反映锁等待 / 阻塞: 状态值含义Waiting for t


326. Java Stream API - 实现自定义的 toList() 与 toSet() 收集器
yaoxin5211232026/2/23

文章目录 326. Java Stream API - 实现自定义的 `toList()` 与 `toSet()` 收集器📦 实现一个自定义 `toList()` 收集器🚀 使用我们的 `ToList` 收集器🔄 将其改造成 `toSet()` 收集器✅ 修改 1:使用 `HashSet` 作为容器✅ 修改 2:声明该收集器是无序的 🧪 `ToSet` 收集器完整实现示例🎯 总结一下关键点🧠 小贴士 326. Java Stream API - 实现自定义的 toL


Kafka 生产者与消费者配置详解
倚肆2026/2/15

Kafka 生产者与消费者配置详解 一、DefaultKafkaProducerFactory 生产者配置详解 配置项示例值作用说明调优建议ProducerConfig.BOOTSTRAP_SERVERS_CONFIG"localhost:9092"Kafka 集群地址列表,生产者通过此地址发现集群。配置多个地址(用逗号分隔)以提高可用性。ProducerConfig.KEY_SERIALIZER_CLASS_CONFIGStringSerializer.class消息键的序列化器。键用于分区


Spring IOC&DI(上)
阿武不想上早八2026/2/6

Spring IOC&DI(上) 1. Spring IOC&DI Spring 是包含了众多工具方法的 IOC 容器 1.1 容器 概念:容器时用来容纳物品的装置。 例子:List/Map -> 数据存储容器;Tomcat -> Web 容器 1.2 IOC 概念:全称:Inversion of Control(控制反转),是 Spring 的核心思想,把对象交给 Spring 管理,就是 IOC 思想。 总的来说,Spring 就是一个”控制反转“的容器。 2. I


【学习笔记】C++(1)
贺一航【Niki】2026/1/28

C++学习笔记 一、基础 1、类型表示范围 2、cout 3、char 4、string 5、逻辑运算符 6、枚举 7、随机数 8、数组 9、其他 一、基础 1、类型表示范围 类型 字节数 位宽 十进制范围(大约) 具体值范围 char 1

首页编辑器站点地图

本站内容在 CC BY-SA 4.0 协议下发布

Copyright © 2026 XYZ博客