Homepage 是一个开源的、现代的、安全的、高度可自定制的应用程序仪表板(Homepage),或者,大家更习惯称这类应用为「导航页」。
Homepage 已支持超过 15 种语言,集成了至少 25 种应用程序的快捷服务,还可自行配置天气、书签、Docker 容器概况、NAS 系统基本情况等各种小部件。有了 Homepage,我等 NAS 用户就再也不用一遍又一遍地往浏览器地址栏里输入 NAS 的 IP,不用特地去记住各种服务的端口。要做的只是把它们都一一配置在 Homepage 里,各项服务就能一触即达。
更关键的是,Homepage 很好看。
安装 Homepage 十分方便,使用 Docker Compose 即可轻松创建;配置也很简单,只要编辑 YAML
格式的配置文件,就可以直接修改你想要的任何服务,且配置即时生效,无需重启。
其实在这之前,我还发现过 Homer 这款开源的静态书签。尽管配置简单,也是直接编辑 yaml
格式的配置文件,但总感觉不够炫酷,差一点「噼咔」的感觉。所以在使用 Homepage 之后就弃用了。
那么接下来,我会教大家最基础的配置 Homepage 的服务的方法,以得到上图展示的结果。
除了参考本文,你还可以直接查阅官方文档:https://gethomepage.dev/ 。请一定要参考官方文档!!
安装
使用 Docker Compose 安装 Homepage 是最简单的方法,你只需要在 docker-compose.yml
文件中加入下面的内容:
version: '3.9'
services:
homepage:
image: ghcr.io/gethomepage/homepage:latest
container_name: homepage
ports:
- 3000:3000 #左侧端口可修改,如果有公网请一定要设置成比较少见的端口,避免内部服务泄露
volumes:
- ./homepage:/app/config #群晖需要确保本地文件夹已预先创建
- /var/run/docker.sock:/var/run/docker.sock # (可选) Docker 配置
environment:
- PUID=1000
- PGID=1000
restart: unless-stopped
./homepage
是指当前 docker-compose.yml
的目录,群晖也可以具体写到 /volume1/docker/homepage
以确保万无一失。
最后执行 docker compose up -d
启动便可。
配置
配置介绍
第一次访问 http://ip:3000 会自动在映射的文件夹内生成各类配置文件和日志文件夹,结构如下:
homepage
├── bookmarks.yaml
├── docker.yaml
├── kubernetes.yaml
├── logs
│ └── homepage.log
├── services.yaml
├── settings.yaml
└── widgets.yaml
配置简单易懂。如果需要变更某部分内容,只要修改对应的配置文件即可:
- bookmarks.yaml:书签
- docker.yaml:Docker 容器
- kubernetes.yaml:kubernetes 容器
- logs:日志目录
- services.yaml:各项服务
- settings.yaml:Homepage 设置
- widgets.yaml:小部件
默认配置下的界面比较纯粹:
只有修改配置才能让 homepage 变得又好看又好用。
修改配置
配置影响着整个 Homepage 的运行,对这些文件的修改还可能需要同时修改 docker 目录映射。
我个人的映射配置如下:
volumes:
- ./homepage/config:/app/config
- ./homepage/logs:/logs
- ./homepage/icons:/app/public/icons
- ./homepage/images:/app/public/images
因为我新增了本地图标、本地图片,还额外修改了日志存放的路径,所以将 /app/config
修改为单独映射到 /homepage/config
文件夹。结构清晰易懂。
图标、图片只是在 services.yaml
中会用到,只用映射,不用修改配置。日志除了映射外,则需要在 settings.yaml
配置好才能生效,你可以参考下面的内容来设置。
由于只要设置好 services.yaml
、 settings.yaml
就足以使用 Homepage,所以这里我也只详细介绍这两个项目的具体配置方法。其他的配置需要你自己摸索学习。
settings.yaml
首先,修改 settings.yaml
。自动生成的默认的配置如下:
---
# For configuration options and examples, please see:
# https://gethomepage.dev/en/configs/settings
providers:
openweathermap: openweathermapapikey
weatherapi: weatherapiapikey
请先查阅官方文档此处配置的说明:https://gethomepage.dev/en/configs/settings/ ,再执行下面的操作。
语言
默认显示为英语,所以先加一行配置修改为中文
language: zh-CN
还可以为 DateTime 小部件指定语言环境,例如 en-AU、en-GB 等。
日志路径
由于默认的配置会将各种 yaml
文件直接生成在根目录 config
里,而 logs
文件夹又是默认生成在 config
文件夹内。后续若是想添加本地图标,创建的 icons
文件夹又是一个目录。如果不经修改,最后会变成:
homepage
├── bookmarks.yaml
├── docker.yaml
├── kubernetes.yaml
├── services.yaml
├── settings.yaml
├── widgets.yaml
├── logs
│ └── homepage.log
└── icons
├── home.png
├── google.png
└── autobangumi.png
为了美观(强迫症),这里先修改日志路径,让它直接在根目录生成 logs
文件夹。
logpath: /
配合修改的 config
映射,再重启容器,就可以实现以下效果:
homepage
├── config
│ ├── bookmarks.yaml
│ ├── docker.yaml
│ ├── settings.yaml
│ └── xxx.yaml
├── logs
│ └── homepage.log
└── icons
├── home.png
├── google.png
└── xxx.png
若是你觉得无所谓,这一步也可以不修改。
背景图
可以使用图片链接自定义 Homepage 的背景:
background:
image: https://images.unsplash.com/photo-1502790671504-542ad42d5189?auto=format&fit=crop&w=2560&q=80
或者使用本地图片,新建一个文件夹,比如 images
,在 compose 配置里映射到 /app/public/images
volumes:
- ./homepage/images:/app/public/images
之后就可以这样引用本地的图片:
background:
image: /images/xxxx.png
特别注意:不要偷懒直接映射 /app/public
目录,会报错。
接着,可以为背景图使用不同的滤镜,比如修改透明度
background:
image: https://images.unsplash.com/photo-1502790671504-542ad42d5189?auto=format&fit=crop&w=2560&q=80
blur: sm #模糊程度,范围 sm, "", md, xl... 参考 https://tailwindcss.com/docs/backdrop-blur
saturate: 50 #饱和度,范围 0, 50, 100... 参考 https://tailwindcss.com/docs/backdrop-saturate
brightness: 50 #亮度,范围 0, 50, 75... 参考 https://tailwindcss.com/docs/backdrop-brightness
opacity: 50 #不透明度,范围 0-100
标题
此处的标题,是指标签页上的标题。
title: MIKUSA Homepage
版本号
默认情况下,发布版本显示在页面底部。要隐藏它,请使用hideVersion
设置:
hideVersion: true
布局
你可以将服务部分配置为基于 column
列 或 row
行 的布局。默认是列,所以你只要改成 row
就可以以行显示。
这一设置与 services.yaml
中的配置相关。假设你在 services.yaml
中创建了三组服务,名为 Media
、NAS
和 书签
,那么只要在 settings.yaml
中加上 raw
的样式和每行 column
的个数,就可以横向排列,节省空间。
layout:
NAS:
style: row
columns: 3
Media:
icon: jellyfin.png
style: row
columns: 3
书签:
style: row
columns: 7
其中,分组的顺序又与配置的先后顺序相关,你可以任意调整分组的先后顺序,而不用去修改 services.yaml
中的配置。你还可以为每个分组加上图标。
layout:
Media:
icon: jellyfin.png
style: row
columns: 3
NAS:
style: row
columns: 3
书签:
style: row
columns: 7
经过我个人长时间的使用,横向布局中,在 2K 分辨率下服务组件最佳个数为 3 个,书签最佳个数为 6 或 7 个。这样在手机等低分辨率的移动设备上也能获得不错的使用体验。
放上一版修改后完整的 settings.yaml
配置:
---
# For configuration options and examples, please see:
# https://gethomepage.dev/en/configs/settings
language: zh-CN
logpath: /
background:
image: https://images.unsplash.com/photo-1502790671504-542ad42d5189?auto=format&fit=crop&w=2560&q=80
# blur: sm # sm, "", md, xl... see https://tailwindcss.com/docs/backdrop-blur
# saturate: 50 # 0, 50, 100... see https://tailwindcss.com/docs/backdrop-saturate
# brightness: 50 # 0, 50, 75... see https://tailwindcss.com/docs/backdrop-brightness
opacity: 20 # 0-100
fiveColumns: true
title: MIKUNAS Homepage
layout:
Media:
icon: plex.png
style: row
columns: 3
NAS:
style: row
columns: 3
书签:
style: row
columns: 7
其他的配置我没用到也就不写了,请参考官方教程。
services.yaml
自动生成的默认的配置如下:
---
# For configuration options and examples, please see:
# https://gethomepage.dev/en/configs/services
- My First Group:
- My First Service:
href: http://localhost/
description: Homepage is awesome
- My Second Group:
- My Second Service:
href: http://localhost/
description: Homepage is the best
- My Third Group:
- My Third Service:
href: http://localhost/
description: Homepage is 😎
请先查阅官方文档此处配置的说明:https://gethomepage.dev/en/configs/services ,再执行下面的操作。
配置 服务 的话倒是简单许多,只有「分组」和「格式」上的要求。让我举个详细的例子。
例如,我需要三个新分组:Media、NAS、书签;Media 里放置一个 Plex 的服务组件、一个 Emby 的服务组件,NAS 里放置一个群晖的服务组件,书签则是放上我的个人博客。
我不建议你使用 homepage 的书签服务 bookmarks.yaml
,因为这玩意不好看。
直接在原配置的基础上修改:
---
# For configuration options and examples, please see:
# https://gethomepage.dev/en/configs/services
- Media: #分组
- Plex: #服务名
icon: plex.png #图标
href: http://127.0.0.1:32400 #服务链接
# ping: http://192.168.31.39:32400 # Ping 链接
# description: Plex #服务描述
widget: # 服务组件
type: plex
url: http://127.0.0.1:32400
key: asdfghjklk
- Emby:
icon: emby.png
href: http://127.0.0.1:8096
widget:
type: emby
url: http://127.0.0.1:8096
key: xxxxxxxxxx
- NAS:
- 我的 NAS:
icon: synology.png
href: http://127.0.0.1:5000
ping: http://127.0.0.1:5000
widget:
type: diskstation
url: http://127.0.0.1:5000
username: mikusa
password: xxxxxxxxxxxx
- 书签:
- 初之音:
icon: https://www.himiku.com/favicon.ico
href: https://www.himiku.com/
保存后,得到的效果是这样的(横向排列是因为上面教程中设置过了):
分组、服务和服务组件的格式为硬性要求,无需解释,而其他的链接、Ping 和描述也是字面意思,很好理解。需要注意的就只有 icon
图标和 widget
服务组件。
你可以为分组、服务添加 icon
图标,可以使用本地路径 /images/xxxx.png
,也可以使用图片链接 https://xxx.com/images/xxxx.png
。但 homepage 内置了 Dashboard Icons 项目1,可以直接使用该项目提供的图标。你只需要先在该项目中搜索你想使用的图标,然后直接把 xxx.png
填在图标配置里即可,例如示例中的 icon: plex.png
。
目前支持了不少服务的小组件,你可以在 https://gethomepage.dev/en/configs/service-widgets/ 搜索目前可用的服务组件。服务组件需要严格按照官方文档的要求编写,否则无法正常使用。(这好像是废话)
不过仍需说明的是,homepage 中的服务组件只是起便捷显示的作用,并不能交互。
这里举个文档中比较难懂的例子。如果你想添加 Navidrome 的组件的话,配置是这样的:
- Navidrome:
icon: navidrome.png
href: http://navidrome.host.or.ip:port
widget:
type: navidrome
url: http://navidrome.host.or.ip:port
user: usernam
token: token #md5(password + salt)
salt: randomsalt
其他的都好懂,这里 token
的意思是:你的密码需要和一串用来加密的字符组合,再使用 md5 加密,将得到的 32 位字符填到这里。
假设密码是 1234567
,加密用的 salt
是 abcdefg
,那么组合后的密码就是 1234567abcdefg
。在网上搜索 md5 加密(比如 这个)。把组合后的密码填到输入框中,点击加密,右侧生成的 32 位字符 79f150d0da4acc7c215cf222b13aa033
就是你要填写的 token
了。
于是,配置中的 token
和 salt
就这么填写。
token: 79f150d0da4acc7c215cf222b13aa033
salt: abcdefg
widgets.yaml
自动生成的默认的配置如下:
---
# For configuration options and examples, please see:
# https://gethomepage.dev/en/configs/widgets
- resources:
cpu: true
memory: true
disk: /
- search:
provider: duckduckgo
target: _blank
请先查阅官方文档此处配置的说明:https://gethomepage.dev/en/configs/widgets/,再执行下面的操作。
homepage 中 widgets.yaml
主要是用来修改页面顶部的一些小部件,比如系统状况、搜索框、天气、时间、欢迎词等等。
我自己只用到了系统状况、搜索框和时间,所以只说说这仨的用法。
系统状况中内存只有一个好办,但硬盘有很多个的话,就需要有几个盘就映射几个文件夹进去。例如群晖 NAS 中,有 volume1
、 volume2
、 volume3
三个硬盘,映射的时候就要都映射进去;怕容器写坏文件,就加上 :ro
只读。
volumes:
- /volume2:/volume2:ro
- /volume3:/volume3:ro
但配置文件是在 volume1
中,所以不用映射 volume1
。
时间、搜索完全是官方文档的教程,我就不复制粘贴过来了。最后的配置如下:
- resources:
label: System
cpu: true
memory: true
- resources:
label: Storage
expanded: true
disk:
- /
- /volume2
- /volume3
- search:
provider: [google, baidu]
target: _blank
- datetime:
text_size: xl
format:
timeStyle: short
hour12: false
效果则是这样的:
其他
反向代理
一个简单的 Nginx 反向代理配置如下:
server {
listen 80;
server_name homepage.himiku.com;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl;
server_name homepage.himiku.com;
include ssl/ssl.conf;
ssl_certificate_key ssl/himiku.com/himiku.com.key;
ssl_certificate ssl/himiku.com/fullchain.cer;
location / {
proxy_pass http://homepage:3000;
proxy_set_header X-Real-IP $remote_addr;
proxy_hide_header X-Powered-By;
proxy_set_header HOST $http_host;
}
access_log /home/wwwlogs/himiku.com.log;
}
密码登录
如果要在公网使用,加个密码比较安心。需要在 Nginx 中配置。
首先,在电脑或服务器上打开终端,假设你的密码是 yourpassword
,输入以下命令:
openssl passwd -apr1 "yourpassword"
会输出以下内容:
$ openssl passwd -apr1 "yourpassword"
$apr1$9najWLRB$G0mgXBerNnt2/7W3mH6t4/
在 nginx 配置中新建一个 basicauth
文件夹,在其中创建一个 homepage.conf
文件,按 user:password
的格式填入以下内容:
admin:$apr1$9najWLRB$G0mgXBerNnt2/7W3mH6t4/
接着,在上述 Nginx 配置中的 location
段加入 auth_basic_user_file
配置:
location / {
auth_basic_user_file basicauth/homepage.conf;
auth_basic "请登录!";
proxy_pass http://homepage:3000;
proxy_set_header X-Real-IP $remote_addr;
proxy_hide_header X-Powered-By;
proxy_set_header HOST $http_host;
}
重载 Nginx 即可生效。
总结
总之,合理利用、搭配 Homepage 提供的服务,就能在一定程度上减少敲 IP 记服务地址所耗费的时间,增加一丁点的幸福感。
参考
- 该项目由于图标数量众多,直接在网页搜索图标的话可能会使浏览器崩溃。所以建议下载该项目后,在文件管理器搜索你想用的图标。 ↩
本文作者:mikusa
本文链接:https://www.himiku.com/archives/homepage.html
封面出处:失われた深淵·葬儀(lumine)p3 / void_0 #Pixiv
版权声明:所有文章除特别声明外均系本人自主创作,转载及引用请联系作者,并注明出处(作者、原文链接等)。
大佬,请问下怎么把原生的书签取消掉呀?没看到在哪里配置呀
清空 bookmarks.yaml 里的配置
谢谢!
那个渊的评论,应该就是宝塔反代的问题,其他东西修改能实时更新,图片和标题页修改不是没用,而是需要过好几天才能生效,我也在搞这个问题.......我在想是不是因为我网页设置的纯静态导致的
docker容器外部3060端口 宝塔面板用反向代理,并按照文档修改了反代配置,反代后homepage的配置不生效 比如改标题和背景图片都没用,必须要域名:3060,而且停止容器后依然可以访问反代域名,请问homepage可以用80/443端口吗
那nginx反代3060就可以啊,我文中不是有给配置
谢谢,刚回复就看到了 但一直提交失败
就是按照文中配置的,我对比了下 宝塔反代配置里没有proxy_hide_header X-Powered-By;
加入进反代配置后短暂生效了一会,用这时间改了标题和背景图,之后无论是改任何内容都无用了
直接使用文中的配置也行不通
字数略多发不出来 请看我回复附上的网站吧 感谢
你留的网址是错的……
宝塔我没用过,反代只要这一段其实就可以了
你再检查看看,可能是缓存的问题
https://alist.motian.icu/本机存储/img-api/反代.txt
放在网站里提交不了评论
谢谢,我又试了一下,也清理了缓存 用edge和chrome访问还是一样的结果,反代后配置不同步
改成我那么写有试过吗?F12看看控制台具体是什么报错
这个应该是反向代理的缓存的问题, 清理下就行
官网教程全是英文机翻看的头疼还是大佬这个简洁明了,就是问下我是在openwrt下搭建的,其他没什么问题就是公网怎么通过homepage访问内网设备呢,我现在的方法openwrt做端口转发,service.yaml下把内网设备的地址也换成公网访问地址,内网公网都可以正常访问,但这样内网用homepage访问设备是不是也走了公网绕了个圈?不懂原理,还有就是也想知道怎么加密码访问,家宽没有80 443端口,期待解答
我只用内网访问,所有服务全部走443,暴露在公网部署这个太危险了。密码是nginx auth加上的,文末有写。
Github Demo Image
你知道demo里面第二行那些显示PVE NAS 状态的组件是什么嘛
还有就是背景图片模糊感觉不是很好看,可以用卡片模糊
但是要关掉背景图片的滤镜和亮度,推荐把背景图片的透明度调低
glances 找到了 |´・ω・) ノ
我也想知道这个是啥但是没能找到,感谢! ٩(ˊᗜˋ*)و
以上是原本要发的内容
以下是发送评论遇到的问题
还有就是输入评论的textarea没有办法换行使用shift+enter验证码这个是网上抄的,既然报错那我就移除掉好了 (⌐■_■)
换行的话应该直接回车就能换?
诶嘿,早上的时候我用回车换不了行,shift+回车才行,现在回车也可以了 ( ๑´•ω•)
发现删掉验证码会有垃圾评论,我还是加回来吧( (⌐■_■)
求助,对于群晖的nas 怎么处理呢 ,为什么我这里提示双因子认证呢 ,我打开和关闭都提示同样的一个错误 Unable to call https://192.168.1.30:5001/webapi/entry.cgi?api=SYNO.Core.System&version=3&method=info. code: 407, error: Authentication failed. 2FA enabled..
参考官方文档新建一个给homepage用的没啥权限的新用户,然后别开两步验证
尤其感谢博主大大给的首页加密码的方案,用jellfin插件总怕网址暴露之后被别人看到我在看什么,加了密码瞬间感觉舒服多了
牛逼 plus!!!我以为我已经把homepage开发到极致了,看了博主的文章才知道还能这么玩
感谢大佬的说明,在官方文档之上有了很多参考,帮助很大。
另外补充一下,如果是使用qnap的小组件的话,目前官方还不支持二步验证,需要关闭二步验证。
如果是某些插件api错误的话需要去掉url最后的"/"
谢谢你的补充
看上去还不错,不过好像不能根据主题切换不同的图标?有些图标在白色背景下能看清,但是到黑色背景就看不清了。