简年14(蚂蚁笔记(Leanote)快速部署指南)

请看这里更新后的精简内容。
本文基于 Docker,请先安装 Docker 和 Compose。
开始之前,附上源代码,以下是你要的快速部署指南。
第一步、新建一个文件夹,在里面新建三个文件,分别是:
  • 复制粘贴这里的内容保存为 app.conf 文件。
  • 复制粘贴这里的内容保存为 docker-compose.yml 文件。
  • 复制粘贴这里的内容保存为 initdb.sh 文件。
第二步、初始化数据库,一条命令:
# docker network create leanote docker-compose run --rm initdb

第三步、启动,一条命令:
docker-compose up -d leanote mongo

部署完成。现在你可以使用这个私人的云笔记工具,既能当笔记工具又能当博客用,还有全平台客户端同步。
所以全文总结起来就两句话?!
下面是一边写一边记录的内容,不看也罢。
今天打开蚂蚁笔记发现蚂蚁笔记也开始收费了(这年头笔记工具都不好活啊),嗯,不过蚂蚁笔记是开源的,我们可以自己部署到自己的服务器。
这一次边操作边写吧,废话较多,快速部署的方法在最上面,就两条命令。
一、整理信息 0. 官方文档 在 Docker Hub 上看到官方的镜像已经不再维护,所以从官方文档入手,看看怎么安装吧。
1. 下载蚂蚁笔记二进制版
wget https://jaist.dl.sourceforge.net/project/leanote-bin/2.3/leanote-linux-amd64-v2.3.bin.tar.gz

2. 安装 mongodb 我们有现成的官方镜像。
3. 导入初始数据 因为前面使用了 Docker 镜像,这里数据库地址是 mongo,数据库名称为 leanote。
mongorestore -h mongo -d leanote --dir /leanote/mongodb_backup/leanote_install_data/

4. 配置蚂蚁笔记 蚂蚁笔记的配置存储在文件 conf/app.conf 中。
修改app.secret一项, 在若干个随机位置处,将字符修改成一个其他的值, 否则会有安全隐患!
这里我们可以在 Dockerfile 中定义一个变量。
ENV APP_SECRET=V85ZzBeTnzpsHyjQX4zuKbQ8qqtJu9y2aDM55VWxAH1Q0p19poekx3xkcDVvrD0y

然后在 RUN 指令中添加 sed 命令修改。
sed -i '/app.secret/s/V85ZzBeTnzpsHyjQX4zukbQ8qqtju9y2aDM55VWxAH9Qop19poekx3xkcDVvrD0y/$APP_SECRET/g'

当然使用 volume 直接挂载配置文件也许更好。
5. 运行蚂蚁笔记 运行之前确保 mongodb 已在运行。
/leanote/bin/run.sh

以上就是全部了。出现下面这行表示运行成功。
Listening on :9000...

OK,官方文档看完之后就这些信息,整合一下。
二、初步的 Dockerfile 根据上面的信息,我们可以初步写一份 Dockerfile 了。
  • Dockerfile
FROM alpine:3.5ARG LEANOTE_VERSION=2.3 ENV APP_SECRET=V85ZzBeTnzpsHyjQX4zuKbQ8qqtJu9y2aDM55VWxAH1Q0p19poekx3xkcDVvrD0yRUN apk add --no-cache --update wget ca-certificates \ && wget https://jaist.dl.sourceforge.net/project/leanote-bin/${LEANOTE_VERSION}/leanote-linux-amd64-v${LEANOTE_VERSION}.bin.tar.gz \ && tar -zxvf leanote-linux-amd64-v${LEANOTE_VERSION}.bin.tar.gz -C / \ && rm leanote-linux-amd64-v${LEANOTE_VERSION}.bin.tar.gz \ && sed -i '/app.secret/s/V85ZzBeTnzpsHyjQX4zukbQ8qqtju9y2aDM55VWxAH9Qop19poekx3xkcDVvrD0y/$APP_SECRET/g' && apk del --purge wgetVOLUME /leanote/data/EXPOSE 9000CMD ["sh", "/leanote/bin/run.sh"]

这里构建运行会遇到一个问题,数据库没初始化。
MongoDB 运行很简单。
docker run --name mongo -v /my/own/datadir:/data/db -d mongo

但是初始化就有点麻烦了,因为初始化数据库文件在另一个容器里面。因此修改上面的 Dockerfile 中的 CMD,把 run.sh 放到数据库初始化之后执行。
也就是先写个脚本把数据库初始化的工作干了。
  • initdb.sh
#! /bin/sh mongorestore -h mongo -d leanote --dir /leanote/mongodb_backup/leanote_install_data/

啊,等会,好像不行,算了,先从安装包里面抠出来用,看看后面我有没办法自动化实现。
继续,现在有了初始化文件夹,所以直接靠 MongoDB 的镜像就可以初始化了,到时候写入 docker-compose.yml 就可以自动初始化了。
三、数据卷 现在的话基本运行没问题了,但是数据持久化就麻烦了,容器一删数据全没那就没意思了。
先来看看蚂蚁笔记的目录结构:
appbinconfmessagesmongodb_backuppublic

除了 conf/app.conf 这个文件比较容易看出来是需要挂载之外,其他的还真没看出来啊。
不过因为我们打算把数据库初始化交给数据库镜像干,所以这里我们可以删掉这个 mongodb_backup 文件夹,减少体积。
在 public 文件夹中我们看到一些 README 文件,原来用户资源统一在 public/upload 这个目录,所以这里也是一个数据卷。
应用镜像一共两个数据卷,分别是配置文件和 upload 目录。
数据库镜像一共一个数据卷,用来备份。
四、Compose 文件 上面都没有问题了,那么接下来是 docker-compose.yml 文件的编写。
为了初始化数据库,我们需要单独建立一个“一次性”的容器服务来初始化数据库,这样可以避免干扰主数据库的运行。
  • docker-compose.yml
version: '2' services: leanote: image: zuolan/leanote ports: - "9000:9000" volumes: - ./app.conf:/leanote/conf/app.conf - ./upload:/leanote/public/upload - /etc/localtime:/etc/localtime:ro links: - mongomongo: image: mvertes/alpine-mongo volumes: - ./data:/data/dbinitdb: image: mvertes/alpine-mongo links: - mongo volumes: - ./initdb.sh:/initdb.sh - ./data:/data/db command: sh /initdb.sh

  • initdb.sh
#! bin/sh apk add --no-cache wget wget https://jaist.dl.sourceforge.net/project/leanote-bin/2.3/leanote-linux-amd64-v2.3.bin.tar.gz tar zxf leanote-linux-amd64-v2.3.bin.tar.gz mv leanote/mongodb_backup / mongorestore -h mongo -d leanote --dir /mongodb_backup/leanote_install_data/

好了,好像搞定了,接下来补充刚才的 Dockerfile 内容。
  • Dockerfile
FROM alpine:edgeARG LEANOTE_VERSION=2.3RUN apk add --no-cache --update wget ca-certificates \ && wget https://jaist.dl.sourceforge.net/project/leanote-bin/${LEANOTE_VERSION}/leanote-linux-amd64-v${LEANOTE_VERSION}.bin.tar.gz \ && tar -zxf leanote-linux-amd64-v${LEANOTE_VERSION}.bin.tar.gz -C / \ && rm -rf /leanote/mongodb_backup \ && rm leanote-linux-amd64-v${LEANOTE_VERSION}.bin.tar.gz \ && apk del --purge wgetVOLUME /leanote/public/uploadEXPOSE 9000CMD ["/leanote/bin/run.sh"]

我去试下,看看有没问题。
先构建镜像:
docker build -t zuolan/leanote .

没有问题,那我们继续,初始化数据库:
docker-compose run initdb

【简年14(蚂蚁笔记(Leanote)快速部署指南)】初始化数据库完成,接下来启动即可。
docker-compose up leanote mongo

简年14(蚂蚁笔记(Leanote)快速部署指南)
文章图片
部署成功

    推荐阅读