本文是应网友
刘源
的要求折腾的;
什么是 Nextcloud AIO ?
Nextcloud AIO
就是Nextcloud All-in-One
,顾名思义就是一个Nextcloud
的All-in-One
版本,这是一个基于Docker
的项目,它允许仅安装一个容器,该容器可以完成创建和管理完整的Nextcloud
安装所需的所有容器的繁重工作。Nextcloud AIO
不仅提供了许多Nextcloud
功能的轻松部署和维护,而且您还可以期待用户友好的界面、无压力的更新以及让大多数功能开箱即用的更简单的方法。
Nextcloud AIO
包括:
Nextcloud
Nextcloud Office
Nextcloud Files
的高性能后端Nextcloud Talk
的高性能后端- 备份解决方案(基于
BorgBackup
) Imaginary
(用于heic
、tiff
和webp
的预览)ClamAV
(Nextcloud
的防病毒后端)- 全文检索
- …
前言
按照之前的理解,All-in-One
一般都是把软件需要用到的服务、数据库、前端等放在一个镜像里,这样可以降低用户体验的门槛,但是 Nextcloud AIO
颠覆了老苏的认知,这玩意儿像是个启动器或者批处理,你需要用的镜像还需要根据你的设置,一个一个另外下载
老苏在安装时,为了体验,勾选了全部的功能;
最后下载并生成了大概有 14
容器(下图中还差了 domaincheck
和watchtower
)
期间出了各种状况,例如下面这样,原因竟然是 nextcloud/aio-apache
下载失败导致的
所以为了避免遇到老苏在安装中遇到的网络问题,建议你把 nextcloud/aio
开头的镜像先下载回来,似乎也就 onlyoffice
、docker-socket-proxy
可能没用上
当然你的网络很稳定的话,当老苏什么都没说
反向代理
熟悉老苏的同学都知道,老苏 6
月份 vps
到期之后,就没再续签了,所以现在的反代方案是
Cloudflared
+Nginx Proxy Manager
Tailscale
+Nginx Proxy Manager
前面是什么关系不是很大,重点是 Nginx Proxy Manager
官方有详细的反代设置文档:https://github.com/nextcloud/all-in-one/blob/main/reverse-proxy.md,请找到自己的反代类型进行设置
域名 | 局域网地址 | 备注 |
---|---|---|
https://aio.laosu.cf | http://192.168.0.197:11000 | apache 主机:端口 |
主机设置
SSL
中,如果 NPM
在 Cloudflard
后面,可以不用设置,如果在 Tailscale
后面则是需要的
Advanced
中都需要加入下面的代码
client_body_buffer_size 512k;
proxy_read_timeout 86400s;
client_max_body_size 0;
【注意事项】:
如果你反代后,没有 443
端口,从官方文档看,似乎是不支持的
但老苏没有条件进行验证,只能建议你采用老苏的方案了
命令行安装
docker cli 安装
如果你熟悉命令行,可能用 docker cli
更快捷
# 新建文件夹 nextcloud-aio 和 子目录
mkdir -p /volume1/docker/nextcloud-aio/{config,data}
# 进入 nextcloud-aio 目录
cd /volume1/docker/nextcloud-aio
# 创建卷
docker volume create \
--driver local \
--name nextcloud_aio_mastercontainer \
-o device="/volume1/docker/nextcloud-aio/config" \
-o type="none" \
-o o="bind"
docker volume create \
--driver local \
--name nextcloud_aio_nextcloud_datadir \
-o device="/volume1/docker/nextcloud-aio/data" \
-o type="none" \
-o o="bind"
# 运行容器
docker run -d \
--init \
--sig-proxy=false \
--restart unless-stopped \
--name nextcloud-aio-mastercontainer \
-p 3093:8080 \
-v nextcloud_aio_mastercontainer:/mnt/docker-aio-config \
-v /var/run/docker.sock:/var/run/docker.sock:ro \
-e APACHE_PORT=11000 \
-e APACHE_IP_BINDING=0.0.0.0 \
-e NEXTCLOUD_DATADIR="nextcloud_aio_nextcloud_datadir" \
nextcloud/all-in-one:latest
3093
:是容器nextcloud-aio-mastercontainer
的访问端口;APACHE_IP_BINDING
:apache
容器侦听的主机IP
;APACHE_PORT
:apache
容器侦听的主机端口 ;
docker-compose 安装
也可以用 docker-compose
安装,将下面的内容保存为 docker-compose.yml
文件
version: '3'
services:
nextcloud-aio-mastercontainer:
image: nextcloud/all-in-one:latest
container_name: nextcloud-aio-mastercontainer
restart: unless-stopped
ports:
- 3093:8080
volumes:
- nextcloud_aio_mastercontainer:/mnt/docker-aio-config
- /var/run/docker.sock:/var/run/docker.sock:ro
environment:
- NEXTCLOUD_DATADIR=nextcloud_aio_nextcloud_datadir
- APACHE_PORT=11000
- APACHE_IP_BINDING=0.0.0.0
volumes:
nextcloud_aio_mastercontainer:
name: nextcloud_aio_mastercontainer
driver: local
driver_opts:
type: 'none'
o: 'bind'
device: '/volume1/docker/nextcloud-aio/config'
nextcloud_aio_nextcloud_datadir:
name: nextcloud_aio_nextcloud_datadir
driver: local
driver_opts:
type: 'none'
o: 'bind'
device: '/volume1/docker/nextcloud-aio/data'
然后执行下面的命令
# 新建文件夹 nextcloud-aio 和 子目录
mkdir -p /volume1/docker/nextcloud-aio/{config,data}
# 进入 nextcloud-aio 目录
cd /volume1/docker/nextcloud-aio
# 将 docker-compose.yml 放入当前目录
# 一键启动
docker-compose up -d
注意事项
- 容器的名称不能改,必须是
nextcloud-aio-mastercontainer
,否则日志中会有下面的提示
注意:容器名字中的连接线是
-
而不是_
It seems like you did not give the mastercontainer the correct name? (The 'nextcloud-aio-mastercontainer' container was not found.)
Using a different name is not supported since mastercontainer updates will not work in that case!
- 卷的名称也不能改,必须是
nextcloud-aio-mastercontainer
,否则日志中会有下面的提示
注意:容器名字中的连接线是
_
而不是-
It seems like you did not give the mastercontainer volume the correct name? (The 'nextcloud_aio_mastercontainer' volume was not found.)
Using a different name is not supported since the built-in backup solution will not work in that case!
如何重置
如果在初始安装过程中出现意外情况,您可能需要重置 AIO
安装,以便能够从头开始
具体的方法可以参考官方的文档, How to properly reset the instance?
章节:https://github.com/nextcloud/all-in-one#how-to-properly-reset-the-instance
运行
在浏览器中打开 https://群晖IP:3093
,注意,是 https
不是 http
,否则你会看到
如果提示 您的连接不是私密连接
,点 高级
点 继续前往192.168.0.197(不安全)
现在可以看到下面👇这样的界面了
注意保存密码
点最下面的按钮登录,输入密码
登录完成后看到 AIO
界面
前提是你的网络没问题,或者已经将需要的容器下载下来了,否则有可能卡在检查升级的页面上
设置域名
为了测试,都勾选了
时区需改为 Asia/Shanghai
回到顶部,点 Download and start containers
如果像下面这样,不一定是有问题,可能只是还没启动完成,稍等之后点 Reload
按钮重新加载
nextcloud-aio-nextcloud
启动的过程是比较长的,要有耐心。着急的话可以点服务后面的Starting
看日志,来了解进度;
如果没有提前下载镜像,网络又不太好的情况下,比较容易出现 Server error. Please check the mastercontainer logs for details. This page will reload after 10s automatically. Then you can check the mastercontainer logs.
当下面这样时,基本上就算正常了,可以开始下一步访问了
之所以说基本正常,是因为
Notify Push
一直在重启,日志中显示start.sh: line 36: /nextcloud/custom_apps/notify_push/bin/x86_64/notify_push: No such file or directory
,懒得再去研究了,因为这种安装方式远远没有老苏之前写的安装方式简单快捷;
注意红框中的用户名和密码
Initial Nextcloud username: admin
Initial Nextcloud password: c32b4f14f897b89be557a215001417315db3bf1a69606fd3
点 Open your Nextcloud
,会在浏览器中打开新的页面,地址是我们前面设置的域名
即使你在浏览器中输入
http://群晖IP:11000
,也会跳转为设置的域名;
输入用户名和密码,登录成功后主界面就出来了
接下里就可以正常使用了
参考文档
nextcloud/all-in-one: Nextcloud AIO stands for Nextcloud All-in-One and provides easy deployment and maintenance with most features included in this one Nextcloud instance.
地址:https://github.com/nextcloud/all-in-one
How to Install the Nextcloud All-in-One on Linux - Nextcloud
地址:https://nextcloud.com/blog/how-to-install-the-nextcloud-all-in-one-on-linux/
How to run AIO on Synology DSM.
地址:https://github.com/nextcloud/all-in-one#how-to-run-aio-on-synology-dsm
all-in-one/reverse-proxy.md at main · nextcloud/all-in-one
地址:https://github.com/nextcloud/all-in-one/blob/main/reverse-proxy.md#2-use-this-startup-command