使用 Docker 搭建碎片化知识卡片-Memos

介绍

Memos 是一个功能全面、易于使用的开源知识库和社交平台。它不仅适合个人记录和分享信息,也适合企业或组织作为内部的知识管理工具。Memos 的活跃开发和多元化功能使其成为维护私密性和安全性的理想选项。

它旨在为用户提供一个方便的记录、分享和管理知识的环境,同时注重保护用户数据的私密性和安全性。

它具备以下功能:

  • 支持标签、过滤、搜索和多账户管理。
  • 可自定义备忘录可见性,有多种隐私设置选项。
  • 提供多样化的后端存储选择,如数据库、S3 和本地存储。
  • 支持多种单点登录选项,包括 Github、Gitlab 和 Google 等,以及自定义认证方法。
  • 增强的用户界面(UI),新的时间线页面和改进的深色模式。
  • 升级 Markdown 解析器支持扩展语法,如表格(table)和 LaTeX。
  • 支持通过 Docker 部署,允许无损数据的版本更新。
  • 可用于搭建独立微博,满足用户对 self-host 微博的需求。

使用 docker 快速部署

安装

bash 复制代码
docker pull ghcr.io/usememos/memos

运行

bash 复制代码
docker run -d --name memos -p 5230:5230 -v ~/.memos/:/var/opt/memos ghcr.io/usememos/memos:latest

然后我们就可以使用 ip + 端口的形式来访问 memos 应用了。

在 k8s 中部署

第一,在我们的 k8s 集群上新建一个文件,文件名比如叫 memos-deployment.yaml,然后将下面这段 yaml 内容 copy 进去;

yaml 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: memos
  name: memos
spec:
  progressDeadlineSeconds: 600
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      app: memos
  strategy:
    rollingUpdate:
      maxSurge: 25%
      maxUnavailable: 25%
    type: RollingUpdate
  template:
    metadata:
      labels:
        app: memos
    spec:
      containers:
        - image: 'ghcr.io/usememos/memos:latest'
          imagePullPolicy: Always
          name: memos
          ports:
            - containerPort: 5230
              name: memeos
              protocol: TCP
          resources:
            requests:
              cpu: 250m
              memory: 512Mi
      restartPolicy: Always

第二,在终端中 cd 到 memos-deployment.yaml 文件的目录,并执行下面这段命令进行应用部署:

bash 复制代码
kubectl apply -f memos-deployment.yaml

第三,我们可以使用以下命令来查看部署状态:

bash 复制代码
kubectl rollout status deployment/memos

第四,为了进一步检查,确认 pod 是否成功运行,可以使用以下命令:

bash 复制代码
kubectl get pods -l app=memos

-l app=memos 这一部分是一个标签选择器,用来只挑选出拥有app=memos标签的 pods,这样就只会显示你刚刚部署的应用的 pods。

此时已经部署完成了,但是外界还无法访问,因为默认情况下 pod 不会被分配一个可以从集群外访问的 IP 地址,所以还需要创建一个 Service 来连接外界和这个 pod,这里多说比较复杂。因为对于个人来说使用 k8s 集群的概率极低(大都应该是学习),所以只需要会使用 docker 进行部署即可。

而在企业级维度,一般都会使用各大云厂商提供的 k8s 服务,比如阿里云 ACK 等,使用这种白屏化界面部署这些开源应用简直不要太简单,就不过多赘述了。

使用

部署好之后,我们输入 ip + 端口,首先会看到一个注册页面,这里我们注册一个用户:

注册好之后,我们就会跳转到主页面,它长这个样子:

默认进来之后又成了英文,接下来我们到 Settings 中将语言设置成中文。

之后我们点击主页就可以开始记录笔记了:

移动端也很清爽:

相较于手机记事本、备忘录及一些其他笔记软件来说,memos 的优点很显而易见:

  • 开源且永久免费,只要你有一台服务器,你就可以自由地使用和修改软件,不受任何限制。
  • 按照教程使用 Docker 进行傻瓜式部署,简单几步,轻松安装
  • Memos 的界面简洁直观、易于上手,只要有浏览器,在任何一台联网设备上都可以进行访问
  • Memos的轻量级特点使得其占用资源较少,运行速度快,我们在手机端或者电脑端都能快速打开。
  • 不但如此,我们还可以将备忘录分享给他人,增强了笔记的个性化和实用性。
相关推荐
忆~遂愿1 小时前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
说实话起个名字真难啊2 小时前
用docker来安装openclaw
docker·ai·容器
恬静的小魔龙2 小时前
【群晖Nas】群晖Nas中实现SVN Server功能、Docker/ContainerManager等
docker·svn·容器
Zfox_3 小时前
CANN Catlass 算子模板库深度解析:高性能 GEMM 融合计算、Cube Unit Tiling 机制与编程范式实践
docker·云原生·容器·eureka
春日见3 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡4 小时前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
liu****4 小时前
2.深入浅出理解虚拟化与容器化(含Docker实操全解析)
运维·c++·docker·容器·虚拟化技术
logocode_li5 小时前
OCI/CRI 双标准下:从 dockerd 到 containerd 的 K8s 运行时迭代史
docker·云原生·容器·k8s
_运维那些事儿17 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
lpruoyu19 小时前
【Docker进阶-05】Docker网络
网络·docker·容器