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

前言

虽然我们前面介绍了图床之类的Docker应用,但其实云盘服务才是更加贴近大众生活的Docker应用。

Nextcloud是一个类似于百度网盘、阿里云盘的服务,可以通过docker容器的方式搭建在自己的个人服务器或NAS上,有安卓和IOS客户端。我不知道有没有人在VPS上布署nextcloud。一般都是NAS用户吧!有中文界面。我个人一般是用于进行手机照片的云同步,同时还储存一些小文件,并且偶尔可以分享文件给朋友,此时朋友下载文件的速度不像免费百度云那样受到限制。

Nextcloud除了基本的文件云同步和云储存的功能外,其实还有很多进阶功能,以后有机会再开系列博文来描述它的使用吧。

本篇博文主要讲述如何通过docker来安装Nextcloud,并且借助NPM进行ssl证书的申请和自动续期。安装docker应用往往不是难事,难就难在如何方便地获得https,而这个和个人信息安全密切相关的主题在多数教程中均少有提及。

Nextcloud的特别之处还在于:Nextcloud仅仅提供特色功能。它的性能提升往往依赖其它应用,比如MYSQL和Redis;它的拓展性往往依赖强大的插件。如果你用默认的方法安装docker nextcloud,那么它的性能会受到较大的限制。

如果你可以熟练使用原生Nginx,可参考这位大佬的方案:使用docker-compose搭建nextcloud+Nginx+MySQL+Redis。我请了杜比的ZoniNG大佬测试,这个博客的方案是有效的,只是数据库权限的设置方法要变通一下。由于我对于原生Nginx的配置并不熟悉,所以并没有采用他的方案。对于新手而言,他的设置过于复杂。本回的安装方法是一种对Nextcloud性能有较大提升并且较为简便的方法。原理上,唯一不同的是我们采用Nextcloud原生app,即使用Apache进行80端口映射,而不是像大佬那样采用Nginx+Nextcloud:fpm的方法。

最后提醒一下:这个方法配置的Nextcloud对内存的占用还是比较大的。如果你觉得安装完卡顿的话,可以到htop看看是不是Nextcloud的问题。这里我大致展示一下(不知道是不是和Nextcloud有关):

不知长期使用会怎么样,现阶段感觉对其它应用没有明显的不良影响。

其它关于nextcloud的其它信息,可以访问:

  • 官方网站:https://nextcloud.com/
  • 官网github仓库(docker镜像):https://github.com/nextcloud/docker

另外,**如果有使用非443端口的NAS的童鞋在安装Nextcloud中有任何问题的,欢迎评论区留言。**我什么坑都踩过!

测试环境

我是在VPS里演示Nextcloud安装的:

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/nextcloud && mkdir -p $work && cd $work# 防火墙
sudo ufw allow 7602/tcp comment 'nextcloud' && sudo ufw reload
sudo ufw allow 6379/tcp comment 'nextcloud' && sudo ufw reload# 提前拉取镜像
docker pull nextcloud:latest
docker pull mariadb:latest
docker pull redis

配置yml文件

添加一个docker-compose文件:

vim $work/docker-compose.yml

添加以下内容:

---
version: '3.2'networks:default:name: nextcloudservices:app:image: nextcloud:latestrestart: unless-stoppedvolumes:- ./app:/var/www/htmlenvironment:- MYSQL_PASSWORD=nextcloud_password # 按需修改- MYSQL_DATABASE=nextcloud- MYSQL_USER=nextcloud- MYSQL_HOST=dbports:- 7602:80 # 按需修改networks:- defaultcache:image: redisrestart: unless-stoppedexpose:- "6379" # 可用此默认。因为这是暴露而不是映射volumes:- ./cache:/datacommand: redis-server --requirepass 'redis_password' # 按需修改 networks:- defaultdb:image: mariadb:latestrestart: unless-stopped# 下面的command与官网略有不同。它将有助于避免MYSQL数据库的4047报错。command: --transaction-isolation=READ-COMMITTED --binlog-format=ROW --innodb-file-per-table=1 --skip-innodb-read-only-compressedvolumes:- ./db:/var/lib/mysqlenvironment:- MYSQL_ROOT_PASSWORD=nextcloud_password_root # 按需修改- MYSQL_PASSWORD=nextcloud_password  # 按需修改- MYSQL_DATABASE=nextcloud- MYSQL_USER=nextcloudnetworks:- default

上线服务

cd $work && docker-compose up -d

配置NPM

ddns-go或者域名托管商后台解析好域名nextcloud.exampledomain.com

添加一个Proxy Host,反代地址是http://172.17.0.1:7602。可用泛域名的SSL证书。

Advanced中添加以下记录以增强兼容性。详见官网配置关于反代的说明。

location /.well-known/carddav {return 301 $scheme://$host/remote.php/dav;
}location /.well-known/caldav {return 301 $scheme://$host/remote.php/dav;
}

完整配置图如下所示:

NPM有443端口时的Nextcloud配置

观察Nextcloud的客户端日志,当出现:

Initializing finished
New nextcloud instance

即可直接登陆网站:https://nextcloud.exampledomain.com进行设置。

我随便设置一个帐户。这个可以自定义!

admin
GoK*@s$&3%oXiQTewxoE*v*5@Q*a!D7WGLQDbwFt!NTiaQ!P6DUf5v

如图所示:

有些人不安装推荐应用。我这里就直接安装试试看。国内环境安装速度也还行。你也可以不点,反正你需要的话以后可以自己装嘛!最后,耐心地等待初始化的完成吧。

很快就成功了。有443端口就是简单!

最后,为了让redis生效,我们需要配置$work/app/config/config.php:

sudo vim $work/app/config/config.php

添加以下内容:

//'memcache.local' => '\\OC\\Memcache\\APCu' // 用本地式缓存使用APCu // 注释这行
'memcache.local' => '\\OC\\Memcache\\Redis',
'memcache.distributed' => '\\OC\\Memcache\\Redis', // 分布式缓存使用Redis
'memcache.locking' => '\\OC\\Memcache\\Redis', // 启用Redis缓存的文件锁
'redis' => array('host' => 'cache', // 这里和mariadb的逻辑相同,填写容器links时映射的主机名'port' => 6379,'password' => 'redis_password' // 这是之前在配置docker-compose时配置的redis密码
),
'filelocking.enabled' => 'true',

然后重启docker-nextcloud服务:

cd $work && docker-compose down && docker-compose up -d

NPM无443端口时的额外配置

当初我在NAS安装Nextcloud的时候,没有443端口,安装Nextcloud非常地费劲!有时跳转的时候,地址栏的<NPM-443端口>可能会消失掉。

经过一翻折腾,我发现用非443端口使用Nextcloud还要进行一些额外的配置。相关的教程非常的少,真的恶心!市面上很多Up主也是直接在自己的NAS里安装Nextcloud,但他们往往是在局域网中使用Nextcloud,不会配https。然而作为一个云盘,没有https能忍吗?

又或者他们只在VPS中演示怎么安装。如上所述,如果你有443端口,这些问题根本不可能出现。

下面我们对于无443端口的NAS给另外一些配置上的建议。

首先,上线服务后不要登陆网站并注册用户。我们修改$work/app/config/config.php文件的内容:

sudo vim $work/app/config/config.php

在文件中添加以下内容:

如果内容已经有默认值,则添加或更改记录即可。比如trusted_domains。自己看着办!

每一行最后的,号一定不可以省略!

//'memcache.local' => '\\OC\\Memcache\\APCu' // 用本地式缓存使用APCu // 注释这行
'memcache.local' => '\\OC\\Memcache\\Redis',
'memcache.distributed' => '\\OC\\Memcache\\Redis', // 分布式缓存使用Redis
'memcache.locking' => '\\OC\\Memcache\\Redis', // 启用Redis缓存的文件锁
'redis' => array('host' => 'cache', // 这里和mariadb的逻辑相同,填写容器links时映射的主机名'port' => 6379,'password' => 'redis_password' // 这是之前在配置docker-compose时配置的redis密码
),
'filelocking.enabled' => 'true',
'trusted_domains' =>
array (0 => '<nextcloud.exampledomain.com>', // 这一般是可以识别,不用改
),
'overwritehost' => '<nextcloud.exampledomain.com>:<NPM-443端口>', // 按需修改
'overwriteprotocol' => 'https',
'overwrite.cli.url' => 'http://<nextcloud.exampledomain.com>:<NPM-443端口>', # 这里有个逗号不要忘记

为什么要特别地设置config.php文件的相关参数呢?如果访问地址带端口号且属于反向代理,nextcloud往往无法正确地识别,此时nextcloud内部将阻止此地址对nextcloud进行访问。因此,我们需要提前对overwritehost变量进行特别声明。overwriteprotocoloverwrite.cli.url是为了强制https访问,这里也顺便加上以防NPM的设置不生效(还没试过删除会不会影响登陆)。

如图所示(如果没有设置管理员帐户,有些参数和值是没有;但我们要设置的几个参数的样式是类似的):

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eAtSZhID-1651276377407)(https://chevereto.hwb0307.com/images/2022/04/11/image-20220411112948184.png)]

重启服务,让config.php的改动生效:

cd $work && docker-compose down && docker-compose up -d

观察nextcloud客户端的日志(也可以用Portainer看):

docker logs -f nextcloud_app_1 # 有时候是nextcloud-app-1

当log出现Command line: 'apache2 -D FOREGROUND'的字样时,说明nextcloud已经重启成功。

此时可以访问https://<nextcloud.exampledomain.com>:<NPM-443端口>创建管理员帐户。后面的操作和VPS一样。设置完管理帐户后,可以自动登陆或者访问https://<nextcloud.exampledomain.com>:<NPM-443端口>登陆后台使用nextcloud。

如果你不小心注册了帐户再来修改config.php,在日志中很可能会有这种报错:

[access_compat:error] [pid 32] [client <你的电脑ip>] AH01797: client denied by server configuration: /var/www/html/data/htaccesstest.txt

这全是由于地址原因导致的htaccess不过关。**所以端口号的问题真的很烦!**这个时候你可以重新注册一个帐户。这个时候的系统就会有2个用户。它们的权限区别我以后再了解一下。

后台任务

Nextcloud的官话,自己感受一下:为了优化性能,正确配置后台任务非常重要。对于较大的实例,推荐配置为 ‘Cron’。详情请参考相关文档。

根据使用docker-compose搭建nextcloud+Nginx+MySQL+Redis大佬文章的建议:由于nextcloud内部的文件和配置会在用户操作过程中产生变化,所以需要启用一个定时任务去定期整理和归档这些数据到数据库或者应用到配置中。问了ZoniNG大佬,这个也是必要的,说是属于php的优化。

如果你不配置,可能在设置——管理——基本设置会有这种警告:

首先,使用docker ps -a查看nextcloud的容器ID。如果你按本教程,一般是nextcloud_app_1或者是nextcloud-app-1

打开crontab的配置进行编辑:

sudo vim /etc/crontab

加入如下内容:

# run nextcloud cron task every 5 min
*/5 * * * * root docker exec -u 33 nextcloud_app_1 php -f /var/www/html/cron.php 2>&1 /dev/null

这里我留个小问题:root可否换成test_user(就是你自己用的非root用户)?欢迎大家在评论区留下自己的答案!

Beta: Redis测试

个人推测,不知道没有redis的时候是否会这样

这里有一个简单的方法可以测试Redis有没有生效。你在上传很多图片后,可以在此页面快速往下滑动:

与此同时,可调用htop观察:

可看到数据被大量地调用。同时可以发现页面的刷新还是蛮快的。

小结

对于VPS用户来说,Nextcloud的安装非常容易,基本上没有什么难度。对于NAS用户来说就比较折腾;但是,如果成功安装,Nextcloud就非常有用了!

另外,我觉得非443端口使用的时候Nextcloud慢吞吞的。不知道是不是自己的NAS配置太差(蜗牛星际)。我在VPS上用还是非常流畅的。希望有NAS用户安装Nextcloud时给多些反馈!

更多进阶使用,可以看看使用docker-compose搭建nextcloud+Nginx+MySQL+Redis。我觉得这个才是完全体(羡慕)。

关于对Nextcloud的深度使用可以看我后续的更新。敬请期待喽!

附:Nextcloud团队的合体照

参考资料

  • 官方docker镜像:https://hub.docker.com/_/nextcloud
  • 使用Docker快速部署NextCloud
  • Docker:Nextcloud 网盘的安装
  • 官方docker-compose.yml示例:https://github.com/nextcloud/docker/blob/master/.examples/docker-compose/with-nginx-proxy/mariadb/fpm/docker-compose.yml
  • https://www.linuxserver.io/blog/2019-04-25-letsencrypt-nginx-starter-guide里面包含nextcloud的配置
  • Nextcloud Nginx Proxy Manager in 10 Minutes!:我的docker-compose脚本主要是根据该视频进行改进的。
  • 另一种不错的方案:Nextcloud with a MariaDB along with Nginx Proxy Manager and DuckDns Using A Portainer Stack
  • 使用docker-compose搭建nextcloud+Nginx+MySQL+Redis
  • Nextcloud fpm running on docker with nginx on host always returns 404 page
  • How to fix Nextcloud 4047 InnoDB refuses to write tables with ROW_FORMAT=COMPRESSED or KEY_BLOCK_SIZE
  • 官网:关于Nextcloud反向代理的说明

Docker系列 搭建个人云盘服务nextcloud相关推荐

  1. 梅林固件路由器搭建私有云盘服务

    梅林固件路由器搭建私有云盘服务 1.开放路由器ssh登录 2.ssh登录路由器 3.安装服务 安装entware vi entware-ngu-setup.sh # 复制文末脚本内容 chmod +x ...

  2. 每月成长一步步_如何搭建个人云盘(NextCloud搭建篇,适用于Ubuntu)

    1. 前期准备 需要一台ubuntu16.04的linux主机,当然,存储容量越大越好,最好不要低于20G,否则存储什么呢 从git上拉取的最新的nextcloud源码,不过后面有详细命令,可直接复制 ...

  3. 【搭建NextCloud私有云盘服务】采用docker在linux上进行部署,内含nextCloud移植(迁移服务器)方法

    1.前言 完成的效果: 在linux上搭建NextCloud云盘服务,可以通过域名访问到云盘服务,并且安装有SSL证书,可进行https访问. 例如: 服务器公网ip为47.110.66.88 域名为 ...

  4. Docker系列 搭建自动备份服务duplicati

    转至我的个人博客:https://blognas.hwb0307.com.欢迎关注! 前言 在Docker系列 搭建密码管理应用bitwarden中,我们安装了一个实用的Docker应用bitward ...

  5. 通过Docker容器搭建私有网盘(NextCloud)

    Nextcloud是一款开源免费的私有云存储网盘项目,可以让你快速便捷地搭建一套属于自己或团队的云同步网盘,从而实现跨平台跨设备文件同步.共享.版本控制.团队协作等功能.它的客户端覆盖了Windows ...

  6. 搭建私有云:owncloud(用Docker构建owncloud私有云盘)

    网上各种云盘都要收费,又或有速度限制,感觉用起来不方便,想抽时间想搭建一个私有云盘.下面讲解下搭建私有云:owncloud. 搭建私有云:owncloud(用Docker构建owncloud私有云盘) ...

  7. nextcloud+宝塔在阿里云服务器上搭建个人云存储盘(如何在服务器上搭建个人云盘)

    以下操作经实践,已成功执行实现.读者若安装失败,可在云服务器操作台上初始化云盘,再次进行重装.望读者,不畏挫折,愈败愈战,请别因为环境的安装失败影响你的学习的兴趣,不妨多次"重启试试&quo ...

  8. 使用 Nextcloud 搭建私人云盘,并利用内网穿透实现公网远程访问

    文章目录 一.前言 二.环境搭建 三.测试局域网访问 四.执行内网穿透 4.1 ubuntu 本地安装 cpolar 4.2 创建隧道 4.3 测试公网访问 五.配置固定 http 公网地址 5.1 ...

  9. 树莓派64位系统_树莓派4b+Ubuntu server+Nextcloud搭建私人云盘(1):准备系统

    最近剁手买了一个4G版本的树莓派4b,并配了64g tf卡.我打算用它来搭建一个自己的私人服务器. 需求:树莓派4b+一部本地电脑+网线+路由器+一部有公网ip的云主机 首先,我们先到官方下载Ubun ...

最新文章

  1. Docker核心技术之网络管理
  2. 天津商业大学计算机科学与技术分数线,天津商业大学录取分数线2021是多少分(附历年录取分数线)...
  3. sublime php 乱码,sublime打开TXT文件乱码的问题
  4. 机器人演唱邓丽君是真的吗_20年后,高科技让她与邓丽君终相逢
  5. 利用Sql Server2005发送邮件
  6. 在Flex中使用本地共享对象
  7. [linux学习] 字符界面linux安装vmtools
  8. 数学建模学习1.18——模糊综合评价模型
  9. FPGA实现cameralink解码
  10. Springboot整合minio
  11. 《经济学通识》十二、谈环保
  12. [转载][shell]linux常用入门命令
  13. 质量与效能 | 11月29日TF84
  14. 戒梭先生:随笔|合格交易者要达到的三个境界
  15. embarrass的用法和搭配_求embarrass和它对应的形容词的相关用法
  16. 关于冯诺依曼结构、哈佛结构、增强型的哈佛结构
  17. 不要做联表查询!!!
  18. 二进制整数及其表达方式
  19. oracle中求下月同日,以月计算的期限,自本月某日至下月同日为一个月。
  20. i春秋之SQL(详细WP)

热门文章

  1. 大数据在医疗领域应用有哪些挑战?
  2. Web安全工具大集合
  3. Android新闻客户端实训-Day1类Day2接口基操
  4. 袁萌浅谈C919大飞机(五)
  5. 计算机考试成表格,2010年职称计算机考试:Word创建表格
  6. excel 宏命令 VB 批量删除word表格的指定行
  7. 为什么子进程要继承处理器亲缘性?
  8. 最全Hadoop视频教程(从入门到精通 视频教程下载)Hadoop八天完全攻克Hadoop视频教程 Hadoop开发新版Hadoop视频教程
  9. 思科虚拟服务器修改域名,思科域名服务器设置
  10. 同步锁(synchronized)_37