【打工日常】Docker部署一款简单、自托管且加密的Markdown笔记编辑器

一、项目介绍

    1.项目简述
    mininote,是一个使用Vue3和Express构建的简单、自托管、加密的Markdown笔记应用程序
    
    2.项目功能
    mininote提供一个简单个人笔记界面,支持Markdown语法,随时随地的记录你需要的一切;mininote具备高效的分类和标签功能,可以帮助你在不同的场景里面记录工作项目的进展、日常工作的任务列表和以及个人的备忘录;并且它还支持团队协作,可以创建一个工作团队的私密会议内容纪要或者是搭建项目的工作流程,并且你的笔记可以加密存储!

    mininote具有的加密功能,即每个笔记的标题和内容都使用Web Crypto API 提供的对称AES-GCM在客户端(即在您的浏览器中)进行加密。但是,笔记本的密码用于派生加密密钥。也就是说,加密的强度取决于您的密码。此外,尽管笔记是加密发送到服务器的,但这不能被认为是真正的端到端加密,因为从技术上讲,服务器有机会在您首先创建新笔记本的那一刻记录您的密码。

    3.项目开源地址
    https://github.com/muety/mininote
    

----------

二、项目搭建环境

    1. 项目测试环境

    A.项目搭建在腾讯云centos7.6,外网地址为43.138.153.157
    Linux VM-8-12-centos 3.10.0-1160.108.1.el7.x86_64 #1 SMP Thu Jan 25 16:17:31 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux

    B.docker版本为26.01,docker-compose版本为v2.26.1
    注意:本次实践部署环境为个人腾讯云的测试环境,若是生产环境请谨慎部署;对应开启了容器的端口,在linux下和防火墙下需开放对应端口。
    
    2. 本次项目实施过程
    
    使用docker下载镜像,创建好项目需要挂载的路径,通过docker-cli或者docker compose启动容器,启动容器后查看容器启动状态,查看容器的运行日志是否正常,以上全部正常执行后体验项目功能。

    3.注意:docker下载镜像有可能遇到比较慢的情况,参考以下解决措施:
    
    A.docker配置换源,进入/etc/docker的路径,如果没有就创建这个目录
    cd /etc/docker/
    mkdir -p /etc/docker
    
    B.编辑配置文件
    vim daemon.json   ##可以清空里面的内容:%d 然后复制下面的源进去wq保存
    
    {
        "registry-mirrors":[
            "https://286u3d9d.mirror.aliyuncs.com"
        ]
    }
    
    C.registry-mirrors:指定了一个镜像仓库的 URL https://286u3d9d.mirror.aliyuncs.com。 这个配置项用于设置 Docker镜像的镜像仓库地址,使得在拉取和推送 Docker 镜像时能够通过该镜像仓库进行加速。这边提供的是广东广州服务器的镜源,建议个人自己去阿里云建一个个人账号,根据实际所在区获取镜源。
    
    D.重新加载源,重启docker服务
    sudo systemctl daemon-reload 
    sudo systemctl restart docker

----------


三、项目搭建前巡检

    1. 检查docker是否正常运行
    systemctl status docker
    or
    service docker status
    注:我个人测试环境是使用systemctl进行管理,若有使用service管理请使用第二条的命令进行查看。   
    
    [root@VM-8-12-centos ~]# systemctl status docker
    ● docker.service - Docker Application Container Engine
       Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)
       Active: active (running) since Mon 2024-04-22 23:13:57 CST; 4 days ago
         Docs: https://docs.docker.com
     Main PID: 17092 (dockerd)
        Tasks: 158
       Memory: 142.3M
       CGroup: /system.slice/docker.service

    若显示docker的Active是active (running),即表明docker是正常运行的。

    2.一般我会使用docker-compose去管理,所以预先需要创建好yaml文件,vim docker-compose.yml,格式如下例子:

    version: '3.9'
    services:
        nginx:
            image: nginx
            logging:
                options:
                    max-size: 1g
            restart: always
            volumes:
                - '/var/run/docker.sock:/tmp/docker.sock:ro'
            ports:
                - '80:80'

----------


四、项目实施过程

    1.根据开源项目,找到对应的镜像进行pull,若遇到很慢的情况,先检查是否网络问题以及是否已经换源。
    docker pull ghcr.io/muety/mininote

    [root@VM-8-12-centos ~]# docker pull ghcr.io/muety/mininote
    Using default tag: latest
    latest: Pulling from muety/mininote
    c158987b0551: Pull complete 
    ffe47f20beda: Pull complete 
    44600e8ec9ae: Pull complete 
    69ec3c51c045: Pull complete 
    3a9be6a4947d: Pull complete 
    2944509d34a5: Pull complete 
    367681d9c632: Pull complete 
    9a3f778f1f65: Pull complete 
    Digest: sha256:1c3546a4ce6aea5b448c18d59a0ac9a23f7c76b8dee704fba95b3ac5f4e0726a
    Status: Downloaded newer image for ghcr.io/muety/mininote:latest

    2.若已经下载完成显示新的一行,可以输入命令查看是否上一条命令执行成功
    echo$?
    若返回0,则成功;返回其他则根据实际情况重新下载或者查找原因。

    3.docker下载完后,可以查看对应的镜像是否下载成功
    docker images |grep mininote

    [root@VM-8-12-centos ~]# docker images |grep mininote
    ghcr.io/muety/mininote      latest      108c10ab6b97   15 months ago   986MB

    4.创建Mininote目录
    mkdir -p /opt/mininote

    5.生成ssl证书

    cd /opt/mininote

    openssl genrsa -out mininote.key 2048 
    openssl req -new -key mininote.key -out mininote.csr 
    openssl x509 -req -in mininote.csr -signkey mininote.key -out mininote.crt
     
    6.下载成功后,编辑docker-compose.yml文件
    
    version: '3.9'
    services:
      mininote:
        image: 'ghcr.io/muety/mininote:latest'
        environment:
            - HTTPS_KEY=/etc/mininote.key
            - HTTPS_CERT=/etc/mininote.crt
        volumes:
            - '/opt/mininote/mininote.key:/etc/mininote.key:ro'
            - '/opt/mininote/mininote.crt:/etc/mininote.crt:ro'
            - '/opt/mininote:/app/data'
        container_name: mininote
        ports:
            - '3120:3000'

    编辑后输入wq进行保存
        
    7.为了便捷启动,也可以使用docker-cli启动
        
    docker run -d -p 3120:3000 --name mininote   -v /opt/mininote:/app/data -v /opt/mininote/mininote.crt:/etc/mininote.crt:ro     -v /opt/mininote/mininote.key:/etc/mininote.key:ro -e HTTPS_CERT=/etc/mininote.crt -e HTTPS_KEY=/etc/mininote.key ghcr.io/muety/mininote:latest

    8.启动docker-compose

    docker compose up -d  
    
    9.启动容器后,查看容器的状态是否正常  
    
    docker ps |grep  mininote
        
    [root@VM-8-12-centos mininote]# docker ps |grep  mininote
    314f808487e3   ghcr.io/muety/mininote:latest   "/bin/sh -c 'yarn st…"   About a minute ago   Up About a minute   0.0.0.0:3120->3000/tcp, :::3120->3000/tcp   mininote
    
    10.启动容器后,查看容器的日志是否正常
    
    docker logs -f mininote
    
    [root@VM-8-12-centos mininote]# docker logs -f mininote
    yarn run v1.22.19
    $ node index.js
    Listening on localhost:3000.
    

----------


五、项目体验

    注:云服务器记得放开防火墙3120!
    访问地址https://43.138.153.157:3120/,欢迎点击玩一下!
    ps:我的测试服务器是乞丐版,所以每次发了大的项目启动后,可能会把前面的项目kill掉,不然会卡爆了,请大家体谅...
    更多好玩有趣有用的内容,请关注微信公众号:零氪的云原生



  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全糖去冰吃不了苦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值