Docker系列 搭建个人图床chevereto

转自我的个人博客:https://blognas.hwb0307.com。欢迎关注!

前言

老实说,chevereto和随后我要讲的nextcloud在安装的过程中都有点复杂,我也不知道大家会不会觉得太难。其实多数常见的Docker应用的安装是不需要这么复杂的;它们的复杂往往是因为我们想要得到最佳性能或者效果。我会尽量写得详细一些。如果真有什么问题,评论区留言反馈吧。

另外,我感觉Nextcloud图床对于Typora写作的非图床专业用户来说也是一种不错的选择。如果你不想在Typora中使用Chevereto图床,也可以看我的Nextcloud系列教程:Docker系列 深度使用nextcloud(三) Typora图床。

前面的学习中,我们安装了bitwardenduplicati两款实用的docker应用。本回我们将介绍另一个好用的应用,即chevereto。它的官网是:https://chevereto.com/。chevereto是一款自建图床的程序。可能小伙伴不知道什么是“图床”。简而言之,就是一款托管图片的程序吧。

在没有使用markdown之前,我对于图床没什么概念。平时自己很少自拍,也不怎么拍别人或风景嘛!不过后来接触了markdown,就不得不关心起图床了。由于Typora并没有内置的图床,所以托管markdown写作过程中图片的平台的搭建就变得非常重要了。

我最开始使用的是一款叫auxpi的图床,因为它有宝塔搭建的教程,所以自己才找到它的。就算是现在,我也觉得这是一个非常好的图床,在Github上也有2.6k的Star呢!只不过自己当时刚玩Linux不久,不太能看懂它关于API的设置,所以一直没有办法在Typora和PicGo中完美地适配auxpi。后来我看到别人用Typora+PicGo+Chevereto的方法来搭建markdown工作流程,所以就转投chevereto了。现在我可以确切地和你说,在Typora中,经过简单的设置后,Ctrl+v粘贴的图片可以直接上传到图床中!想当初我最开始用Typora的时候,还傻傻地在浏览器打开图床窗口,然后将图片拖上去,最后再复制markdown专用图片链接。没办法,那会比较小白,哈哈!

就算是在国内的网络环境,也有很多免费的图床可以用。具体可参考《2020国内能用的图床集合》。但我在很早之前就很抗拒使用第三方图床。就算是现在,我还是建议要搭建一个个人专属图床,特别是你有VPS的情况下。虽然白嫖别人的服务很爽;有些小伙伴喜欢将图床托管在github上;如果有小伙伴用notion来进行markdown写作的话,图片可以直接粘贴,也挺方便。但是,你的图片的命运就掌握在别人手中而不是自己手中。我觉得,如果你将mardown当作生产力工具的话,里面的图片应该是十分重要的。试想一下你的图床的图片丢失,之前的努力都白费了!Github毕竟是美国的东西,如果以后Github不再向中国用户开放,那你又得花时间和精力去转移你的图床,而且你不一定可以在gitee这样的平台恢复你的链接和数据。这样使用mardown的体验也会非常差!如果你有个人专属图床,只要做好备份,基本上就等于永久不失效图床。

另外,我觉得,chevereto是一个非常专业的图床,使用它的话图床功能具有潜在的扩展性,这对我而言有不少吸引力。此外,它还有类似的优势:

  • 有docker镜像,备份和迁移简单
  • 强大的后台管理和扩展性
  • 与PicGo的良好交互,支持markdown
  • 而且,chevereto是有收费版的,这就意味着它被一个盈利机构所维护。产品质量有保障!

    我以前是在宝塔中使用chevereto,后来迁移到docker,数据也可以有效地恢复。不过本回暂时不讨论chevereto的数据如何从宝塔迁移至Docker容器中。如果有需要的话可留言评论,以后再开一篇来讲述吧。而且我使用chevereto近2年了,十分稳定。这更加坚定了我使用chevereto作为个人图片托管平台。

    不想用个人图床的,还可以选择使用对象存储(OSS)来托管图片,也许是一个不错的方案!不过我只是听说,没有亲身实践过。你可以看一下这个:markdown书写以及图片上传到阿里云oss,或者自己Google百度一下。设置似乎也很简单。资费估计也很低!

    好了,与chevereto有关的介绍到此为止。对我来说,这确实是最重要的应用之一了。

    下面我们来看看怎么安装chevereto吧!

    测试平台

      
      
      
      
    uname -a # Linux VM-12-8-ubuntu 5.4.0-42-generic #46-Ubuntu SMP Fri Jul 10 00:24:02 UTC 2020 x86_64 x86_64 x86_64 GNU/Linuxdocker --version # Docker version 20.10.5, build 55c4c88docker-compose --version # docker-compose version 1.28.6, build 5db8d86f

    准备工作

      
      
      
      
    # 工作目录请按需修改work=~/docker/chevereto && mkdir -p $work && cd $work# 提前拉取镜像docker pull mariadb && docker pull nmtan/chevereto:1.4.1# 开放端口sudo ufw allow 7777/tcp comment 'chevereto' && sudo ufw reload# 子目录。其中app这个目录要留给www-data:www-data用户mkdir -p $work/app/images

    我们在./app文件夹中建立一个文件:

      
      
      
      
    vim ./app/php.ini

    写入以下内容:

    upload_max_filesize = 100Mpost_max_size = 100Mmemory_limit = 3072Mmax_execution_tim = 180

    这个php.ini的主要作用是自定义上传图片的基本属性。你可以先按我的来。以后不满意再改吧。

    我们简单地看一下工作目录的内容:

    └── [4.0K]  app    ├── [4.0K]  images    ├── [  93]  php.ini4 directories, 1 file

    大致就是这样。

    值得一提的是,在最近的1.6x版本中,chevereto好像不支持中文了。我也不知道为什么。所以我装了一个旧版本。如果大家介意的话,可以将:1.4.1去除。

    最后,将./app的用户(组)改为www-data:www-data

      
      
      
      
    sudo chown -R 33:33 $work/app/

    安装Chevereto

    配置yml文件

    创建docker-compose.yml文件:

      
      
      
      
    vim $work/docker-compose.yml

    填入以下内容:

      
      
      
      
    ---version: '3'services: db: image: mariadb volumes: - ./db:/var/lib/mysql:rw restart: always networks: - default environment: MYSQL_ROOT_PASSWORD: chevereto_password_root # 按需更改 MYSQL_DATABASE: chevereto # 按需更改 MYSQL_USER: chevereto # 按需更改 MYSQL_PASSWORD: chevereto_password # 按需更改 app: image: nmtan/chevereto:1.4.1 restart: always ports: - 7777:80 # 按需更改 networks: - default environment: CHEVERETO_DB_HOST: db CHEVERETO_DB_NAME: chevereto # 与db的设置一一对应 CHEVERETO_DB_USERNAME: chevereto # 与db的设置一一对应 CHEVERETO_DB_PASSWORD: chevereto_password # 与db的设置一一对应 volumes: - ./app/images:/var/www/html/images:rw # - ./app/content:/var/www/html/content:rw - ./app/php.ini:/usr/local/etc/php/php.ini:ro # - ./app/app/routes:/var/www/html/app/routes:rw depends_on: - dbnetworks: default: name: chevereto

    这里,我向童鞋们说明一下初次使用mariadb的一些技巧。

    一般,我们会用mariadb/mysql这些数据库软件来存储软件的数据,这样调用起来更加高效。在Docker的安装中,比如我要装chevereto应用,如果事先指定数据库的帐号和密码:

    CHEVERETO_DB_NAME: chevereto # 与db的设置一一对应CHEVERETO_DB_USERNAME: chevereto # 与db的设置一一对应CHEVERETO_DB_PASSWORD: chevereto_password # 与db的设置一一对应

    然后在安装时,与mariadb/mysql的对应上:

    MYSQL_DATABASE: chevereto # 按需更改MYSQL_USER: chevereto # 按需更改MYSQL_PASSWORD: chevereto_password # 按需更改

    这样在实际设置中,就不需要额外地设置数据库的帐户名。当然,这个密码你可以用bitwarden生成强密码。用户名不改也无所谓。

    在某些时候,甚至可以通过搭建一个phpmyadmin来提供一个可视化的后台来管理mysql。不过这里我们不会这样设置。

    OK,我们直接安装:

      
      
      
      
    docker-compose up -d

    我们可以登陆Portainer的后台看一下,发现在Stack里有一个chevereto

    点进去看,会发现我们刚刚安装的chevereto的应用群:

    注意它的命名规则。自己可以想想它为什么是这个名字喔!我们也可以看到IP Address,很容易可以发现它俩是同一个网段的。一目了然!

    NPM设置

    通过ddns-go或者域名托管后台解析一个域名example.com

    NPM反代http://172.17.0.1:7777。无特殊设置。如下图:

    访问https://example.com即可。会自动转到安装界面:

    自己填好相关信息就可以完成登陆了。可以用bitwarden搞一个强密码。

    直接登陆,后台就是这样:

    我们先将语言改成简体中文。如图所示,自己改吧!

    到这里,我们尝试在主页上传一张照片。随便什么都行。

    一般来说,这样chevereto就可以正常使用了。不过,为了以后更好地迁移整个目录,我建议你按下面的方法进行一些设置。原因是这样的:

  • Chevereto的功能文件夹是整个html,而不仅仅是images。如果以后只迁移images,那么用户信息将无法恢复。
  • 官方的docker镜像不支持挂载整个html
  • 通过chevereto这个例子,我们也学习一些怎么在容器Shell中和宿主Shell交互

    文件夹管理

    我们回到shell里:

      
      
      
      
    # 返回工作目录 cd $work

    观察./app目录:

      
      
      
      
    tree -hl $work/app

    内容如下:

    ├── [4.0K]  images│   └── [4.0K]  2022│       └── [4.0K]  04│           └── [4.0K]  22│               ├── [ 78K]  image.md.png│               ├── [ 73K]  image.png│               └── [ 19K]  image.th.png├── [  93]  php.ini

    我们现在要进行一些特别的操作。我们进入chevereto_app_1里面将整个html目录拷贝出来!

      
      
      
      
    docker exec -it chevereto_app_1 /bin/bash

    这个过程不用输入密码。有没有发现我们进入了另外一个地方root@651953308f35:/var/www/html#?

    没错,虽然你是用普通用户运行的docker,但是其实却是root用户在管理呢!

    我们简单地观察一下:

      
      
      
      
    ls

    有好多文件夹:

    LICENSE    app            composer.lock  custom-entrypoint.sh  importing      index.php  sdkREADME.md  composer.json  content        images                importing.php  lib

    所以我们要做的,就是将整个html目录复制出来。

    我们可以压缩整个html目录

      
      
      
      
    # 在/var/www/这个目录中工作cd /var/www/# 压缩tar zvfc html.tar.gz ./html# 传送到./images里。因为我们挂载这个目录出去了,这样就可以在宿主机访问这个压缩文件!mv html.tar.gz /var/www/html/images/# 退出容器的shellexit

    此时在宿主机器的shell中,我们再观察一下:

      
      
      
      
    tree -hl $work/app

    输出为:

    ├── [4.0K]  images│   ├── [4.0K]  2022│   │   └── [4.0K]  04│   │       └── [4.0K]  22│   │           ├── [128K]  image.md.png│   │           ├── [ 79K]  image.png│   │           └── [ 24K]  image.th.png│   └── [5.9M]  html.tar.gz└── [  93]  php.ini4 directories, 5 files

    两个压缩文件已经拷贝出来了!先转移到./app目录:

      
      
      
      
    sudo mv $work/app/images/html.tar.gz $work/app/

    我们可以将旧的images文件夹删除:

      
      
      
      
    sudo rm -r $work/app/images/

    html.tar.gz解压到$work/app/中:

      
      
      
      
    cd $work/app/ && sudo tar zfvx html.tar.gz

    这时再cd $work/app && tree -L 2看一下,已经各就各位了。

    .├── html│   ├── app│   ├── composer.json│   ├── composer.lock│   ├── content│   ├── custom-entrypoint.sh│   ├── images│   ├── importing│   ├── importing.php│   ├── index.php│   ├── lib│   ├── LICENSE│   ├── README.md│   └── sdk├── html.tar.gz└── php.ini7 directories, 9 files

    最后,不要忘记将./app文件夹所有文件改为www-data:www-data所有:

      
      
      
      
    sudo chown -R 33:33 $work/app

    改动yml文件

    下线服务

      
      
      
      
    docker-compose down

    $work/docker-compose.yml的内容改为:

      
      
      
      
    ---version: '3'services: db: image: mariadb volumes: - ./db:/var/lib/mysql:rw restart: always networks: - default environment: MYSQL_ROOT_PASSWORD: chevereto_password_root # 按需更改 MYSQL_DATABASE: chevereto # 按需更改 MYSQL_USER: chevereto # 按需更改 MYSQL_PASSWORD: chevereto_password # 按需更改 app: image: nmtan/chevereto:1.4.1 restart: always ports: - 7777:80 # 按需更改 networks: - default environment: CHEVERETO_DB_HOST: db CHEVERETO_DB_NAME: chevereto # 与db的设置一一对应 CHEVERETO_DB_USERNAME: chevereto # 与db的设置一一对应 CHEVERETO_DB_PASSWORD: chevereto_password # 与db的设置一一对应 volumes: - ./app/html:/var/www/html:rw # 挂载整个html目录 - ./app/php.ini:/usr/local/etc/php/php.ini:ro depends_on: - dbnetworks: default: name: chevereto

    然后直接上线:

      
      
      
      
    docker-compose up -d

    访问https://domain.com/dashboard可正常登陆。

    备份迁移时,备份整个$work目录即可。

    当然,不要忘记用duplicati备份$work目录喔!

    小结

    一般来说,chevereto的安装不需要这么复杂。可是,为了方便以后迁移,你还是忍受一下吧!

    html目录中,有几个比较重要的文件夹。比如,images是放图片的文件夹;content文件夹主要与系统和用户设置有关;而app/routes则与相册的设置有关。如果你需要在typora后台将图片上传到特定的相册,而不是以访客身份传输照片,就需要修改routes的相关配置。

    后面再出一个博文讲一下如何在markdown中使用chevereto吧!

    本文使用 文章同步助手 同步

    你可能感兴趣的:(Docker系列 搭建个人图床chevereto)