部署轻量私有化备忘录memos

本文最后更新于 681 天前, 如有失效请评论区留言.

简介

memos 是一个开源的、支持私有化部署的碎片化知识卡片管理工具,可以简单理解为自主可控的轻量微博。

部署

部署很简单, 一梭子就可以了

docker 方式

docker-compose.yaml
version: "3.0"
services:
  memos:
    image: neosmemo/memos:latest
    restart: always
    container_name: memos
    volumes:
      - ~/.memos/:/var/opt/memos
    ports:
      - 5230:5230

启动服务

docker compose pull
docker compose up -d

k8s 方式

k8s yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  labels:
    k8sapp.ysicing.net/name: memos
  name: memos
spec:
  # storageClassName: tkecfs
  accessModes:
    - ReadWriteMany
  resources:
    requests:
      storage: 1Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    k8sapp.ysicing.net/name: memos
  name: memos
spec:
  replicas: 1
  selector:
    matchLabels:
      k8sapp.ysicing.net/name: memos
  strategy:
    rollingUpdate:
      maxSurge: 25%
      maxUnavailable: 0%
    type: RollingUpdate
  template:
    metadata:
      labels:
        k8sapp.ysicing.net/name: memos
    spec:
      containers:
      - image: neosmemo/memos
        imagePullPolicy: Always
        name: memos
        resources:
          limits:
            cpu: 150m
            memory: 256Mi
          requests:
            cpu: 50m
            memory: 128Mi
        volumeMounts:
        - mountPath: /var/opt/memos
          name: memos
      restartPolicy: Always
      volumes:
      - name: memos
        persistentVolumeClaim:
          claimName: memos
---
apiVersion: v1
kind: Service
metadata:
  labels:
    k8sapp.ysicing.net/name: memos
  name: memos
spec:
  ports:
  - name: http
    port: 5230
    protocol: TCP
    targetPort: 5230
  selector:
    k8sapp.ysicing.net/name: memos
  type: ClusterIP
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  labels:
    k8sapp.ysicing.net/name: memos
  name: memos
spec:
  rules:
  - host: memos.ysicing.net
    http:
      paths:
      - backend:
          service:
            name: memos
            port:
              name: http
        path: /
        pathType: ImplementationSpecific

然后 apply 到集群即可

kubectl apply -f memos.yaml

群晖部署

原理也是基于 docker 部署的,具体操作可以参考开源 Memos 在群晖上部署

高级配置

拓展 Memos 的使用

SSO 登录

这里我基于 gitea 配置的,配置如下:

Name: gitea
Identifier filter:
Client ID: xxxxx
Client secret: xxxxx
Authorization endpoint: https://xxx/login/oauth/authorize
Token endpoint: https://xxx/login/oauth/access_token
User info endpoint: https://xxx/api/v1/user
Scopes: user
Identifier: login
Display name: user
Email: email

多端支持

小程序部署具体可以参考 Rabithua/memos_wmp

移动端支持具体可以参考 Moe Memos

附录

我的私有化微博

Chapters

Sponsor

Like this article? $1 reward

Comments