Quartz & Obsidian | 总之又有新文具
第一步:BGM - In Motion启动!
先放上成果:Lyin’s Room。
前段时间在象上刷到Quartz,算是一个支持Obsidian双链玩法的博客?点了收藏之后今天适逢周六,刚好呢又到了晚上十一点(人家的一个不干正事又不打算睡觉的时间),虽然呢也没有什么笔记要整理,但是就是看到漂亮的东西想试一试。搭建并不算难,而且很漂亮!于是来写一下笔记记录过程。
第一步:BGM - In Motion启动!Let the hacking begin!
首先来讲一下我对Quartz的使用感受。它的框架也是基于Hugo啦,这直接降低了我的心理负担,因为算是一个很熟悉的东西。
它默认支持:
- 搜索
- 本地预览
- 夜间模式
- 文章目录(可以修改层级和目录序号的显示)
- 支持Obsidian的双链玩法,直接打开Obsidian就写!无痛保存!
- 最近的文章
- 文章Tag
- Front-Matter(这好像并不是必须的)
但是它的缺点是本身并不支持归档(Archive)的功能。于是作为归档功能的替代,在此隆重向大家介绍我用Obsidian时常用的MOC(Map of Content),算是一种整理思路。轻轻地推荐这篇最早让我了解到Map of Content的一篇文章:Obsidian · 网课学习笔记整理 From Seviche.cc。
其实概括而谈MOC就是放弃用Obsidian本身的文件夹功能给笔记归类(并非必要,只是我很懒得整理),直接建立一个索引页,里面用双链功能创建文章,索引页就像归档或总目录一样,带你去任何一页笔记。
而Quartz的使用完全适配这种笔记管理思路,在Quartz中,_index.md
文件就是博客主页,可以被任意编写,因此可以作为索引/文章目录页使用。
注意:我基本没有什么计算机基础,以下内容不保真!有疑问的话建议去原作者的仓库底下提Issue :D
你需要有些什么
那么就开始吧!
基本上只需要跟着作者的Setup一步步走下来。
- Fork作者的仓库: Quartz Repository
- Clone仓库到本地,可以用Github Desktop也可以敲命令行:
git clone https://github.com/YOUR-USERNAME/quartz
于是此时你已经有了一个quartz
文件夹了。
你所有的内容都可以在quartz/content
中找到。里面默认有notes
、private
、templates
三个文件夹,顾名思义分别存放笔记、隐私笔记(不显示)、模板文件夹。
但是你的笔记并不一定需要放在/content/notes
中,完全可以放在/content
下。
同时里面还有_index.md
文件,它里面的内容直接展现为播客主页。
Obsidian配置
- (可选)新建一个笔记库,或者直接将你的笔记库移动到
/content
文件夹。- 但假设这么做了,文件夹层级目录则为
/content/Vault
,你可以用Obsidian在里面新建、修改笔记。 - 那么此时就涉及一个问题,可是
_index.md
文件是放在/content
目录中的,这意味着你在Obsidian中见不到它。 - 可是按照我的笔记使用逻辑,我希望博客主页(
index.md
)直接作为我的笔记索引页,放满我的笔记双链(幻想),如果它不能在Obsidian里修改,那就会很不方便。
- 但假设这么做了,文件夹层级目录则为
- 我希望一打开笔记就能修改所有东西。因此我是这么做的:直接将我的Obsidian笔记库位置放在了根目录
quartz
中,并将上述三个文件夹、一个_index.md
剪切到了笔记库中,删掉quartz/content
,并把笔记库重命名为content
。 - 在Obsidian的
设置 > 文件与链接
中打开始终更新内部链接
,内部链接类型:基于仓库根目录的绝对路径
。
安装hugo-obsidian
需要确保你已经安装了 Go (>= 1.16) 。
go install github.com/jackyzha0/hugo-obsidian@latest
如果遇到报错:
go install: github.com/jackyzha0/hugo-obsidian@latest: module github.com/jackyzha0/hugo-obsidian: Get "https://proxy.golang.org/github.com/jackyzha0/hugo-obsidian/@v/list": dial tcp 142.251.42.241:443: connectex: A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond.
解决办法:
执行命令go env -w GOPROXY=https://goproxy.cn
安装Hugo
- Install Hugo | Hugo
- 运行命令行:
cd <quartz文件夹地址>
make serve
- 如果此时显示
'make'不是内部或外部命令,也不是可运行的程序 或批处理文件
,那么就需要安装工具make。 - 参照make不是内部或外部命令,也不是可运行的程序或批处理文件解决方案,逐步安装完毕并配置好PATH环境变量。
- 假如对安装有疑惑的话可以参考:MinGW下载和安装教程的前六步。
- 关于环境变量的配置,请不要仅安装在当前的用户变量中,而是安装在系统变量中。
- 确认上述步骤无误,如果此时执行命令行
make serve
仍显示不是内部或外部命令
的话,将MinGW\bin
下的mingw32-make.exe
重命名为make.exe
。
- 执行命令行后,博客生成成功,访问
http://localhost:1313/
本地预览。
发布你的页面
全程按照Deploying Quartz to the Web操作,完全不知道原理,我至今也没真正搞懂Github分支是什么,不知道为什么我本地所作的一些修改全都安静无缝地Push到了Hugo分支里。但它就是成功了(成功了)。
我就这样静静地操作到了最后一步绑定域名。
关于子域名我是这么干的:
- 在仓库根目录
Add file
,写一个文件名为CNAME
且没有后缀的文件。在里面写入你要绑定的域名:c.gregueria.icu
。 - 然后去DNS设置里,子域名记录,记录类型为
CNAME
,IP地址/目标主机:
你的GitHub用户名.github.io`。 - 然后去
Setting > Pages > Custom domain
把你的域名写好,保存。
大功告成!
其余的配置
在config.toml
和/data/config.yaml
和/data/graphConfig.yaml
中可以修改网站基本配置。
尚未解决的问题
- 这个分支到底是怎么回事啊。
- 网站证书无效,搜了一圈教程都没能解决,现在它还是一个很不安全的网站呢。并且虽然我什么也没动但是网站时常掉线,感觉是我绑定域名那一步有些问题。
- 看到有人的网站装修(jzhao.xyz)很漂亮,这个也太炫了吧?!!!!
- 人家哪有那么多笔记要放啊?!!!