Obsidian Publish的开源替代品Markopolis

news/2024/9/18 14:54:23/ 标签: 群晖, docker, Markdown

在这里插入图片描述

什么是 Markopolis ?

Markopolis 是一款旨在提供 Markdown 文件的 Web 应用和 API 服务器。它允许您以网站形式共享 Markdown 笔记,并使用 APIMarkdown 文件交互和操作它们。类似于 Obsidian Publish,但又不会被锁定在 Obsidian 生态系统中。

软件特点:

  • 部署简单: 极其容易部署、配置和使用。
  • REST API 接口: 提供 REST API 来与笔记中的不同 Markdown 元素进行交互。
  • 可定制的 UI: 通过使用 Markopolis 作为后端,支持“自带用户界面”。
  • Obsidian Markdown 风格: 接近 Obsidian Markdown 风格并支持反向链接、待办事项和 LaTeX 方程式。
  • 即时渲染: 使用单个命令将 Markdown 笔记推送到服务器,并立即将其渲染为简单的网页。
  • 全文搜索: 实现全文搜索。
  • 暗色和亮色模式: 支持暗色和亮色模式。
  • 代码格式和待办事项: 支持代码格式和待办事项。
  • 低维护: 几乎不需要维护。
  • Docker 支持: 以可部署的 Docker 映像形式提供。
  • 本地安装: 也可以本地安装。
  • API 文档: 使用 FastAPI 生成的内置 API 文档。

Markopolis 和老苏之前介绍过的 Perlite 是同一类软件,都是基于 WebMarkdown 查看和渲染软件,但感觉上 Markopolis 未来会更强

文章传送门:Obsidian Publish的开源替代品Perlite

安装

群晖上以 Docker 方式安装。

镜像发布在 ghcr.io ,所以直接用命令行来安装。

从时间上看,latest1.1.1 一样

但是 latest 的哈希值和 1.1.1 并不一样

所以这两个版本并不能画等号。老苏测试了一下,latest 版会出现下面的错误,所以最终采用了 1.1.1

Creating network "markopolis_default" with the default driver
Creating volume "markopolis_markopolis_data" with local driver
Creating markopolis ... done
Attaching to markopolis
markopolis    | standard_init_linux.go:230: exec user process caused: exec format error
markopolis exited with code 1

docker_cli__55">docker cli 安装

如果你熟悉命令行,可能用 docker cli 更快捷

# 新建文件夹 markopolis 和 子目录
mkdir -p /volume1/docker/markopolis/data# 进入 markopolis 目录
cd /volume1/docker/markopolis# 运行容器
docker run -d \--restart unless-stopped \--name markopolis \-p 8722:8080 \-v $(pwd)/data:/app/markdown \-e MARKOPOLIS_DOMAIN="http://192.168.0.197:8722" \-e MARKOPOLIS_TITLE="老苏的笔记" \-e MARKOPOLIS_MD_PATH=/app/markdown \-e MARKOPOLIS_API_KEY=vCUJvtcnsJPxPUHZzNWNquHMzxEYEqoCWEXuwnEBaFFCtduhhTTsmwRKxWHGFvdG \ghcr.io/rishikanthc/markopolis:1.1.1

没有找到官方的说明,但是似乎并不难猜测或者理解

可变
MARKOPOLIS_DOMAINMarkopolis 的访问地址
MARKOPOLIS_TITLEMarkopolis 的标题
MARKOPOLIS_MD_PATHMarkdown 文件的存放目录
MARKOPOLIS_API_KEYMarkopolisAPI Key,用于第三方访问的认证,只要是非常长的随机字母数字字符串就可以

dockercompose__88">docker-compose 安装

也可以用 docker-compose 安装,将下面的内容保存为 docker-compose.yml 文件

注意,因为有中文,所以保存时要选择 UTF-8 格式

version: '3.8'services:markopolis:image: ghcr.io/rishikanthc/markopolis:1.1.1container_name: markopolis# restart: unless-stoppedports:- "8722:8080"volumes:- ./data:/app/markdownenvironment:- MARKOPOLIS_DOMAIN="http://192.168.0.197:8722"- MARKOPOLIS_TITLE="老苏的笔记"- MARKOPOLIS_MD_PATH=/app/markdown- MARKOPOLIS_API_KEY=vCUJvtcnsJPxPUHZzNWNquHMzxEYEqoCWEXuwnEBaFFCtduhhTTsmwRKxWHGFvdG

然后执行下面的命令

# 新建文件夹 markopolis 和 子目录
mkdir -p /volume1/docker/markopolis/data# 进入 markopolis 目录
cd /volume1/docker/markopolis# 将 docker-compose.yml 放入当前目录# 一键启动
docker-compose up -d

运行

现在在浏览器中输入 http://群晖IP:8722,会看到下面的错误

{ "detail": "Note 'home' not found."
}

因为主页内容是从名为 home.md 的文件加载的。另外为了演示,老苏还准备另两个 md,目录结构如下:

.  
├─ 08/  
│└─ 在群晖上安装Git客户端.md
├─ home.md
└─ 开源项目管理工具Taiga.md

data 子目录

data/08 子目录

其中 home.md 的内容如下

---
title: Home
date: 2024-08-20 15:30:00
publish: true
---[[开源项目管理工具Taiga]]
[[/08/在群晖上安装Git客户端]]

至于另两个 md 文件,都是直接 Obsidoan 中拷贝过来的,唯一需要修改的是,在 frontmatter 中添加 publish: true

官网的 md 示例,可以在容器内的 /usr/local/lib/python3.12/site-packages/markopolis/md 目录中找到

官方的 frontmatter 中采用的是下面这种方式表示文件的路径

markopolis:fpath: f1/test.md

但老苏没采用这种方式,似乎也能正常工作。主要是不想对 frontmatter 做太多改动

至于 Markdown 的语法,可以参考官方文档:https://markopolis.app/Markdown Syntax,粗略看了下,应该就是标准的 Markdown

文件准备好之后,浏览器中输入 http://群晖IP:8722,如果不行的话,可以重启一下服务

# 重新启动所有服务
docker-compose restart

不出意外的话,现在应该可以看到主界面了

打开同级的文档

打开子目录的文档

API 接口

如果不打算开发,可以忽略这部分

在浏览器中输入 http://群晖IP:8722/docs

点开第一个 /hello,这是用来测试服务是否正常的

x-api-key 中输入 MARKOPOLIS_API_KEY 的值,然后点 Execute 执行

如果没有错误的话,会返回

{"message": "Hello, World!"
}

当然你也可以用 Apifox 等工具对接口进行测试

路线图

如果你考虑使用 Markopolis 来满足您的 Markdown 笔记共享需求,可以关注下这个项目的路线图

  • 支持 Obsidian 标注。
  • Mermaid 图表。
  • 与编辑器无关的跨设备同步。
  • 删除文件 API 接口。
  • 图形视图。
  • 每日笔记。
  • 私人页面,用密码隐藏特定页面。
  • 支持集成 Obsidian 发布和同步。
  • 支持渲染 Markdown 表。
  • 支持图像。
  • 更好的标签处理(将标签视为链接、按标签收集页面、查看所有标签的页面)。
  • 支持 DataView 查询。

参考文档

rishikanthc/markopolis: Markdown Programmable Interface
地址:https://github.com/rishikanthc/markopolis

markopolis.app
地址:https://markopolis.app/


http://www.ppmy.cn/news/1515938.html

相关文章

微分方程(Blanchard Differential Equations 4th)中文版Section4.2

正弦强迫系统 在本节中,我们研究的是外力为正弦或余弦函数的强迫谐振子方程: d 2 y d t 2 + p d y d t + q y = g ( t ) , \frac{d^2 y}{dt^2} + p \frac{dy}{dt} + qy = g(t), dt2d2y​+pdtdy​+qy=g(t), 其中 g ( t ) g(t) g(t) 是一个正弦或余弦函数。这种类型的外部强…

qt creator自动运行单元测试

qt creator自动运行单元测试 工具-选项-Testing-General,找到Automatically run,选项卡选择All。

SwiftUI 革命:打造未来派用户界面的艺术

标题:SwiftUI 革命:打造未来派用户界面的艺术 在当今快速发展的移动应用领域,用户界面(UI)的设计和实现已经成为开发者们关注的焦点。SwiftUI,作为苹果公司推出的现代UI框架,以其声明式编程范式、强大的数据绑定能力和…

【C#】【EXCEL】BumblebeeComponentsAnalysisGH_Ex_Ana_CondUnique.cs

这段代码定义了一个名为 GH_Ex_Ana_CondUnique 的 Grasshopper 组件。以下是该组件的功能和介绍: 功能介绍: 这个组件是用于在 Excel 范围内添加基于唯一值的条件格式。它允许用户高亮显示工作表中的唯一值或非唯一值。 主要特点: 条件格式…

稳石机器人 | 工业级AMR S1200L,专为多样化需求设计,柔性拓展更易用

近日,稳石机器人重磅推出基于新品控制器ROC1000的全新移动机器人AMR S1200L,专为满足生产制造和仓储物流的多样化需求而设计,无需改造现场,最快可在1周内完成部署。 重载型AMR-S1200L设计注重实用性和灵活性,可在室内…

解决执行npm run dev报错node: --openssl-legacy-provider is not allowed in NODE_OPTIONS

问题: 最近下载了一个开源系统,执行npm install很顺利,以为大功告成,结果运行npm run dev时报错node: --openssl-legacy-provider is not allowed in NODE_OPTIONS 解决方法: 应用程序配置(package.json&a…

Ansible初识

ansible初识 Ansible是一种自动化工具,用于配置管理、应用程序部署和任务自动化。它基于Python语言开发,使用SSH协议进行通信,并且不需要在被管理的主机上安装任何客户端。Ansible使用简单的YAML语言来描述任务和配置,使得操作简…

测试用例的设计

*涉及概念来源于《软件测试的艺术》 目录 一、为什么要设计测试用例? 二、黑盒测试与白盒测试介绍 三、测试用例常见设计方法 1.黑盒测试(功能测试) 2.白盒测试(结构测试) 四、测试策略 五、测试用例怎么写 一、为什么要设计测试用例? 由于时间…

一本读懂数据库发展史的书

数据库及其存储技术,一直以来都是基础软件的主力。数据库系统的操作接口标准,也是应用型软件的重要接口,关系重大。 作为最“有感”的系统软件,数据库的历史悠久、品类繁多、创新活跃。 对数据库历史发展的介绍,有利…

前端知识点

1.常见文本标签 2.属性 3.区块 4.表单 如果那个性别只能是单选的话要加上name属性 css 相邻选择器就是跟在被选中的里面的所有 js基本语法 js函数:就跟C语言差不多啊 改文本 引入js

【C#】【EXCEL】Bumblebee/Classes/ExColumn.cs

文章目录 Bumblebee/Classes/ExColumn.csFlow diagramDescriptionCode Bumblebee/Classes/ExColumn.cs Flow diagram #mermaid-svg-6WUm4r0wDJG9uelI {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-6WUm4r0wDJG9ue…

[Algorithm][综合训练][对称之美][经此一役小红所向无敌][连续子数组最大和]详细讲解

目录 1.对称之美1.题目链接2.算法原理详解 && 代码实现 2.经此一役小红所向无敌1.题目链接2.算法原理详解 && 代码实现 3.连续子数组最大和1.题目链接2.算法原理详解 && 代码实现 1.对称之美 1.题目链接 对称之美 2.算法原理详解 && 代码实现…

C# 循环访问目录树详解与示例

文章目录 一、目录树遍历的概念二、使用System.IO命名空间三、DirectoryInfo和FileInfo类四、递归遍历目录树五、示例:列出目录树中的所有文件和文件夹六、异常处理七、迭代方法八、总结 在C#中,访问文件系统是常见的需求之一。有时我们需要遍历目录树以…

使用SQLite进行Python简单数据存储的线程安全解决方案

在 Python 中使用 SQLite 进行简单数据存储时,线程安全是一个需要注意的问题。SQLite 本身是线程安全的,但在多线程环境下,可能仍然需要做一些额外的工作来确保数据访问的安全性。 1、问题背景 一位开发者正在编写一个简单的聊天服务器和客户…

leetcode 数组+哈希+双指针+子串+滑动窗口

——————双指针 283. 移动零 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0] …

sheng的学习笔记-AI-半监督学习

AI目录:sheng的学习笔记-AI目录-CSDN博客 基础知识 什么是半监督学习 我们在丰收季节来到瓜田,满地都是西瓜,瓜农抱来三四个瓜说这都是好瓜,然后再指着地里的五六个瓜说这些还不好,还需再生长若干天。基于这些信息&a…

数学基础 -- 微积分之线性化

微积分中的线性化 在线性代数和微积分中,线性化是指使用一个线性函数来近似描述非线性函数在某一点附近的行为。在微积分中,线性化通常是通过泰勒展开将一个非线性函数线性化的过程。 线性化公式 给定一个函数 f ( x ) f(x) f(x),我们可以…

微信小程序开发经验记录

1、把微信开发者工具安装好后,创建小程序。 AppID可以注册下,后续小程序上线会用到,前期可以使用测试号先开发程序,后续修改AppID即可。 模板选择基础模板就行。 2、开发页面如下。 左上角可以控制几个窗口的打开和关闭。模拟器窗…

arm64--内嵌汇编

内嵌汇编代码基本用法 1.作用:对于特定重要和时间敏感的代码进行优化,同时在C语言中访问某些特殊指令(例如内存屏障指令)来实现特殊功能 2.内嵌汇编代码主要有两种形式 基础内嵌汇编代码:不带任何参数 扩展内嵌汇…

【Datawhale AI夏令营第四期】 浪潮源大模型应用开发方向笔记 Task05 源大模型微调实战代码精读 RAG测试 AI简历助手代码优化 网课剩余部分

【Datawhale AI夏令营第四期】 浪潮源大模型应用开发方向笔记 Task05 源大模型微调实战代码精读 RAG测试 AI简历助手代码优化 网课剩余部分 教程基础背景知识: 微调能解决的问题正好是我需要的——模型在某个特定方面上能力不够。我感觉这种情况适用于让模型去完成…