使用 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的轻量级特点使得其占用资源较少,运行速度快,我们在手机端或者电脑端都能快速打开。
  • 不但如此,我们还可以将备忘录分享给他人,增强了笔记的个性化和实用性。
相关推荐
ELI_He9991 天前
Airflow docker 部署
运维·docker·容器
slient_love1 天前
docker和docker compose部署安装
docker·容器
钱彬 (Qian Bin)1 天前
项目实践14—全球证件智能识别系统(切换回SQLite数据库并基于Docker实现离线部署和日常管理)
运维·docker·容器·fastapi·证件识别
岚天start1 天前
Docker部署NGINX实现服务四层转发方案
服务器·nginx·docker
牛奔1 天前
docker compose up 命令,默认配置文件自动查找规则
java·spring cloud·docker·容器·eureka
工具罗某人1 天前
docker快速部署jenkins
java·docker·jenkins
BigBigHang1 天前
【docker】离线设备安装镜像
运维·docker·容器
学好statistics和DS1 天前
Docker文件与本地文件,系统
运维·docker·容器
liuc03171 天前
docker下安装SearXNG
运维·docker·容器
oMcLin1 天前
如何在CentOS 8上配置并优化Docker与Kubernetes结合的容器集群,提升微服务部署效率?
docker·kubernetes·centos