从零开始的Trilium安装教程
前言※※
trilium 是一款伟大的笔记软件,也是我重度使用 1 年多的生产力工具,但使用门槛实在是太高(需要部署、服务器、域名、反代、没有中文……),所以在国内知名度远不如 ob、logseq、思源等一众软件。
但只有部署服务端才能充分体会到 trilium 的强大之处,部署服务端后有以下优点:
- 多端同步,公司、家、移动端均可无缝连接
- 可部署脚本,比如我在服务端部署了倒数日、微信记笔记、每周自动生成周报、同步手机待办事项等各种脚本,形成自动化工作流
- 可部署博客系统,详见 [missing note],形成笔记博客一体化工作流
今天为大家带来一篇从零开始的 trilium 安装教程,教你如何一步一步搭建自己的笔记系统。
准备工作※※
一台服务器※※
国内云服务※※
国内云服务器一般是阿里云、腾讯云这些,如果你之后需要在 trilium 基础上搭建博客的话,我不推荐使用国内云服务,因为往往是低配高价小水管,而且之后涉及备案等程序比较麻烦。
国外云服务※※
cloudcone 和 racknerd 是两家配置不错且价格低廉的云服务商,但 racknerd 的服务器性能比同价位的 cloudcone 高一点,我推荐使用 racknerd 作为搭建 trilium 的服务器。
正好近期开始了新年特惠,价格十分合适,而且支持支付宝付款,可以说是非常友好了。
主机配置 | 价格 | 直达链接 |
---|---|---|
内存:1G CPU:1C 磁盘:21GB 每月流量:1500GB | $11.49/年 | 链接 |
内存:2G CPU:1C 磁盘:35GB 每月流量:2500GB | $17.38/年 | 链接 |
内存:3G CPU:2C 磁盘:45GB 每月流量:5000GB | $27.98/年 | 链接 |
第一档配置已经足够运行 trilium,如果只是运行 trilium,我建议先购买第一档,等以后有需求了再升级配置。
如果打算配置博客以及服务器上还想运行其他服务,比如 bitwarden、访问统计、图床等,可以按需购买其余两档。
点击链接后首先需要注册,racknerd 支持中文,根据界面引导进行注册即可,但中间有一步需要填写美国地址,建议使用美国地址生成器生成一个假地址。
在购买前你可以设置一些选项:
其中:
- 「Location」选项表示机房位置,你可以自己 ping 一下测试地址,哪个快选哪个就好,不过之后的教程中我们会给 ip 套 cf,所以其实选哪个都无所谓。
- 「Operating System」表示操作系统,建议选择 debian 系。
购买成功后,racknerd 官方会发送一封包含你服务器信息的邮件,里面包括服务器的 ip 地址、root 密码等,这是很重要的信息,建议妥善保存。
一个域名※※
namesilo 作为一家老牌的域名经销商,是购买域名的不二之选,官网地址:https://www.namesilo.com/。
首先前往 官网 注册一个账号。
注册完毕后在顶部搜索栏搜索你想购买的域名,比如:nerdsid
,系统会弹出可购买的域名列表:
如图所示我们可以购买 nerdsid.xyz、nerdsid.top 等域名,且 nerdsid.com 已经被他人持有。其中红色划线的表示续费价格,黑色加粗字体表示首次购买的价格。
可以看到.top
域名的首购价格和续费价格均比较合适,建议购买.top
域名。
点击下方的蓝色购物车按钮后,这个域名就会被加购到购物车中,在购物车中点击大红色的【CHECKOUT】按钮即可支付,namesilo 同样支持支付宝付款(都想赚中国人的钱是吧)。
ssh 通信工具※※
云服务器是运行在遥远的美国大陆,所以我们需要通过 ssh 访问到我们的云服务器。
Terminus 是一款跨平台的 ssh 软件,建议使用。官网地址:https://termius.com/。
当然,好用的终端工具还有很多,比如 xshell、tabby,选一个自己喜欢的就好。如果只是跟着我的教程的话,直接呼出 windows 自带的 cmd 就可以开始部署了,下文就以 windows 自带的终端作为演示。
cloudflare 托管※※
cloudflare 是一家网络基础设施和安全公司,提供内容分发网络(CDN)、DDoS 防护、云安全服务等,是各位站长的老朋友了。
在进行正式部署 trilium 前,我们可以使用 cloudflare 托管我们的网站,这能够隐藏我们服务器的真实 ip,并且能在一定程度上对我们的网站进行防护。
首先登陆 cloudflare,点击添加站点:
点击继续,界面会提示你需要使用什么计划,我们选择【Free】即可,点击继续,接下来到第三步,将域名的名称服务器更改为 cloudflare。
这一步需要在 namesilo 中操作,让我们回到 namesilo,登录仪表盘,进入到这个界面:
找到你之前购买的域名,点击我箭头标注的位置,会弹出以下界面:
将默认的三个 NameServer 删除,依次填入 cloudflare 的名称服务器:
点击【Submit】,这一步就完事了,修改名称服务器需要一点时间,以我个人经验来看,一般半个小时到两个小时就会修改好,等更新完毕后此处会显示成「有效」。
等待名称服务器更新后就可以使用 cloudflare 配置 dns 记录,点击仪表盘的【DNS】选项,点击【添加记录】按钮:
其中【1.1.1.1】请替换成你的 ip 地址,记得在【代理状态】中点上勾,这样 cloudflare 才会托管你的网站,一切就绪后点击保存即可。
部署 trilium 服务端※※
trilium 支持源码部署和 docker 部署两种方式,选择适合自己的就好,小白建议使用docker 部署
trilium 官方只有英文版本,不过有一个国人翻译的中文仓库:Nriver/trilium-translation,各位自行抉择。
本教程默认使用官方原版。
注意:配置服务端完成后,请先不要在服务端的 trilium 中进行任何操作!
源码部署※※
下载源码※※
前往 releases,获取最新服务端压缩包的链接(名称为:trilium-linux-x64-server-0.62.4.tar.xz)。目前最新版本是 v0.62.4,下载链接为:https://github.com/zadam/trilium/releases/download/v0.62.4/trilium-linux-x64-server-0.62.4.tar.xz
(下文以此为示例,请自行替换为最新链接)。
首先使用登录云服务器:
ssh root@你的 ip
Copy
终端会提示你输入密码,将密码复制到终端中,按下回车,登录成功的话会显示类似这样的信息:
Linux servervpn 5.10.0-8-amd64 #1 SMP Debian 5.10.46-4 (2021-08-03) x86_64
The programs included with the Debian GNU/Linux system are free software;
the exact distribution terms for each program are described in the
individual files in /usr/share/doc/*/copyright.
Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent
permitted by applicable law.
Last login: Fri Dec 29 16:51:09 2023 from 36.21.206.141
root@servervpn:~#
Copy
这表示成功登录了远程服务器,接着输入以下指令:
wget https://github.com/zadam/trilium/releases/download/v0.62.4/trilium-linux-x64-server-0.62.4.tar.xz
Copy
此时输入ls
指令会发现目录下多了一个名为trilium-linux-x64-server-0.62.4.tar.xz
的文件,依次运行以下指令:
tar -xf trilium-linux-x64-server-0.62.4.tar.xz
mv trilium-linux-x64-server /opt/trilium
cd /opt/trilium
./trilium.sh
Copy
配置自启动※※
此时通过 http://[你的 ip]:8080
应该可以访问 trilium 的初始化页面了,能访问之后先别急,让我们把 trilium 设置为自启动:
vim /etc/systemd/system/trilium.service
Copy
粘贴以下内容:
[Unit]
Description=Trilium Daemon
After=syslog.target network.target
[Service]
User=xxx
Group=xxx
Type=simple
ExecStart=/opt/trilium/trilium.sh
WorkingDirectory=/opt/trilium/
TimeoutStopSec=20
# KillMode=process leads to error, according to https://www.freedesktop.org/software/systemd/man/systemd.kill.html
Restart=always
[Install]
WantedBy=multi-user.target
Copy
其中 User 和 Group 需要填写你实际的值,root 用户一般填写
root
应用自启动:
sudo systemctl enable --now -q trilium
Copy
更新流程※※
执行指令删除 trilium:
rm -rf /opt/trilium
Copy
之后重新进行安装流程即可。
docker 部署※※
安装 docker※※
使用以下命令安装 docker 本体:
curl -fsSL https://get.docker.com -o get-docker.sh
sh get-docker.sh
Copy
为 docker 设置开启自启:
systemctl enable docker
Copy
docker 常用指令※※
docker ps
查看当前正在运行的容器- -a 查看所有容器 ID
docker stop [CONTAINER ID]
停止指定 CONTAINER ID 的容器docker rm [CONTAINER ID]
移除容器
安装 trilium※※
拉取最新镜像:
docker pull zadam/trilium:[VERSION]
# 其中[VERSION]为 Trilium 的版本号,比如要拉取 v0.62.4,则使用以下命令
docker pull zadam/trilium:0.62.4
Copy
将镜像挂载到本地并运行:
docker run --restart=always -d -p 0.0.0.0:8080:8080 -v ~/trilium-data:/home/node/trilium-data zadam/trilium:[VERSION]
Copy
更新流程※※
- 使用
docker ps
确定trilium 容器 ID - 使用
docker stop [容器 ID]
停止当前正在运行的容器 - 使用
docker rm [容器 ID]
移除 trilium 容器 - 之后按照安装镜像的流程重新进行一遍即可
反向代理※※
虽然经过以上步骤我们可以通过http://[你的 ip]:8080
的方式访问 trilium,但是也太不优雅了,这就需要进行反代,反向代理工具我推荐使用 caddy2,配置简单,自带 ssl。
安装 caddy2※※
依次执行以下指令安装:
apt install -y debian-keyring debian-archive-keyring apt-transport-https
curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/gpg.key' | gpg --dearmor -o /usr/share/keyrings/caddy-stable-archive-keyring.gpg
curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/debian.deb.txt' | tee /etc/apt/sources.list.d/caddy-stable.list
apt update
apt install caddy
Copy
配置反向代理※※
执行指令:vim /etc/caddy/Caddyfile
,粘贴以下内容:
你的域名 {
reverse_proxy localhost:8080
}
Copy
运行 caddy2:
systemctl start caddy
Copy
使用以下指令将 caddy2 配置成自启动:
systemctl enable caddy
Copy
这一步完成后你就可以通过https://[你的域名]
,访问 trilium 服务端了,这样是不是优雅多了。
配置客户端同步※※
同样在 releases 中根据你的实际操作系统下载对应客户端,假设你是 windows 系统,点击【trilium.exe】即可打开软件,打开软件的第一步需要进行初始化:
这里选择第一个选项,初始化一个 trilium 笔记仓库,点击【Next】即进入 trilium 笔记界面。接下来需要配置同步,将客户端与服务器链接起来。
首先,通过浏览器打开 trilium 服务端:https://[你的域名]
,选择第二个选项:
点击【Next】后会进入下一个界面:
这里提示你需要在客户端中填写你的服务器地址,到这一步时浏览器先放一边,不要关闭。
打开 trilium 客户端,点击左上角 trilium 的图标,进入【Options - Sync】选项:
在【Server instance address】中填写你的服务器域名,其他不用填,点击【Save】按钮保存后,点击下方的【Test sync】按钮,如果没有弹出什么报错,则代表链接成功。
这时返回浏览器,点击我红色箭头标注的位置,服务器会开始自动同步,等同步成功时,浏览器会自动重定向到 trilium 笔记界面。
搭建博客(可选)※※
有不少人或许是看了我的 [missing note]之后才对 trilium 感兴趣的。那么这里再来一个简单的博客配置教程。
导入博客主题包※※
首先需要按照 Trilium 博客主题:Ankia 使用指南,安装博客主题。
但此时我们只能通过https://[你的域名]/share
访问博客,但这也太 low 了,所以我们需要一个二级域名进行反代。
配置二级域名※※
配置二级域名同样在 cloudflare 中进行。
新建一个 A 记录,比如你想通过blog.域名
访问你的博客,那么就在名称一栏中填写blog
,IP 地址改成你服务器的地址,点击保存即可。
配置反代※※
在上文中我们使用 caddy2 进行反代,同样的我们打开 Caddyfile:vim /etc/caddy/Caddyfile
,在末尾加入:
二级域名 {
@notShare {
not path /share
}
rewrite @notnotShare /share{uri}
reverse_proxy localhost:8080
}
Copy
修改 Caddyfile 文件后需要重载:
systemctl reload caddy
Copy
现在你可以通过https://blog.域名
访问你的博客了!
结语※※
到此全部的部署已经结束,当然这只是开始使用 trilium 的第一步,还有更多好玩高级技巧等你探索,之后我也会分享自己的使用心得和高级技巧,欢迎关注。