树莓派基于Docker快速搭建nextcloud,附性能测试

    技术2022-07-12  81

    文章目录

    前言正文树莓派刷系统环境准备调整时区Docker安装docker-compose的安装nextcloud 运行nextcloud内网穿透配置 frp自动重新运行配置反向代理 速度测试其他推荐 总结

    排版可能更好一点的永久原文链接:树莓派基于Docker快速搭建nextcloud,附性能测试

    前言

    一年前兴起买的树莓派3B+,一番折腾最后成为了家里的电视投屏盒子(OSMC系统),我的自建云盘放在云服务器上,50G的空间快被塞满了,于是就想起来把尘封数月的树莓派复活过来,搭建一个 nextcloud,并且把之前的数据迁移过去。

    正文

    树莓派刷系统

    如果与我一样有把树莓派作为电视盒子的需求的话,这里怒推一波 OSMC,使用了一年多稳定性还挺好的 链接在此:https://osmc.tv/download/ 或者使用官方的 Raspbian ,属于比较纯粹的环境 链接在此:https://www.raspberrypi.org/downloads/

    下载好的系统使用 win32diskimager 刷入内存卡即可,十分简单,这里贴一个安装链接供参考 https://www.jianshu.com/p/a337ccae5d2b

    环境准备

    首先,ssh进入树莓派,如果是 OSMC 系统的话,用户名和密码都是osmc

    连接结果如下:

    Connecting to 192.168.3.7:22... Connection established. To escape to local shell, press 'Ctrl+Alt+]'. WARNING! The remote SSH server rejected X11 forwarding request. Linux jeffrey 4.19.55-6-osmc #1 SMP PREEMPT Sun Nov 3 22:15:28 UTC 2019 armv7l The programs included with the Debian GNU/Linux system are free software; the exact distribution terms for each program are described in the individual files in /usr/share/doc/*/copyright. Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent permitted by applicable law. Last login: Mon Mar 2 11:00:03 2020 from 192.168.3.10 osmc@jeffrey:~$

    调整时区

    root@osmc:/home/osmc/rasp-tools/frp_client# timedatectl set-timezone Asia/Shanghai root@osmc:/home/osmc/rasp-tools/frp_client# date -R Fri, 03 Apr 2020 12:38:43 +0800 root@osmc:/home/osmc/rasp-tools/frp_client# date Fri Apr 3 12:38:47 CST 2020

    Docker安装

    这里参考了这篇博客:https://docker_practice.gitee.io/install/raspberry-pi.html 整理下来,直接执行如下两行命令即可

    $ curl -fsSL get.docker.com -o get-docker.sh $ sudo sh get-docker.sh --mirror Aliyun

    如果是用的 osmc 系统,执行脚本会报如下错误:

    osmc@jeffrey:~/rasp-tools$ sudo sh get-docker.sh --mirror Aliyun # Executing docker install script, commit: f45d7c11389849ff46a6b4d94e0dd1ffebca32c1 ERROR: Unsupported distribution 'osmc'

    需要修改下 get-docker.sh 中第280行改为,因为 osmc 没有在里边有脚本配置,假装是 debian 就行了

    lsb_dist=“raspbian”

    安装完毕后输出大概是这样

    Server: Docker Engine - Community Engine: Version: 19.03.6 API version: 1.40 (minimum version 1.12) Go version: go1.12.16 Git commit: 369ce74 Built: Thu Feb 13 01:31:39 2020 OS/Arch: linux/arm Experimental: false containerd: Version: 1.2.10 GitCommit: b34a5c8af56e510852c35414db4c1f4fa6172339 runc: Version: 1.0.0-rc8+dev GitCommit: 3e425f80a8c931f88e6d94a8c831b9d5aa481657 docker-init: Version: 0.18.0 GitCommit: fec3683 If you would like to use Docker as a non-root user, you should now consider adding your user to the “docker” group with something like:

    sudo usermod -aG docker your-user

    Remember that you will have to log out and back in for this to take effect!

    WARNING: Adding a user to the “docker” group will grant the ability to run containers which can be used to obtain root privileges on the docker host. Refer to https://docs.docker.com/engine/security/security/#docker-daemon-attack-surface for more information.

    根据提示,可以把当前用户加入到 docker 组,以便这个用户能方便的使用 docker 命令(需要重启)

    sudo usermod -aG docker osmc

    出于效率考虑,可以创建 /etc/docker/daemon.json,并写入如下内容:

    { "registry-mirrors": ["http://hub-mirror.c.163.com"] }

    使用 systemctl start docker 启动服务即可

    docker-compose的安装

    docker-compose 是基于 python 的一个 docker 编排工具,能方便的聚合现有docker镜像,使用起来十分方便

    可以使用 apt-get install docker-compose 的形式安装

    nextcloud

    nextcloud 是一个开源网盘项目,基于 php7,功能非常的强悍,包括手机端、PC端、服务端的程序,在树莓派上只需要安装服务端就可以了,手机端和PC端都只是客户端,找到相关项目下载即可

    服务端项目地址:https://github.com/nextcloud/server 桌面端项目地址:https://github.com/nextcloud/desktop 安卓项目地址:https://github.com/nextcloud/android IOS项目地址:https://github.com/nextcloud/ios

    运行nextcloud

    基于官方关于树莓派运行nextcloud的文档,找到了其中的 docker-compose.yaml,并针对树莓派的特性稍微做了些修改

    version: '2' volumes: nextcloud: db: services: db: image: jsurf/rpi-mariadb command: --transaction-isolation=READ-COMMITTED --binlog-format=ROW restart: always volumes: - ./db:/var/lib/mysql environment: - MYSQL_ROOT_PASSWORD=nyist123 - MYSQL_PASSWORD=nyist123 - MYSQL_DATABASE=nextcloud - MYSQL_USER=nextcloud app: image: arm32v7/nextcloud:fpm volumes: - ./data:/var/www/html/data restart: always web: image: arm32v7/nginx ports: - 8089:80 volumes: - ./nginx.conf:/etc/nginx/nginx.conf volumes_from: - app restart: always redis: image: redis volumes_from: - app restart: always networks: nextcloud:

    在 docker-compose.yaml 目录下使用 docker-compose up -d 开始拉取镜像然后后台运行

    root@osmc:/home/osmc/rasp-tools/nextcloud# docker-compose up -d WARNING: Some networks were defined but are not used by any service: nextcloud nextcloud_db_1 is up-to-date nextcloud_app_1 is up-to-date nextcloud_redis_1 is up-to-date nextcloud_web_1 is up-to-date

    进入 http://ip地址:8089 即可开始配置数据库等信息,如果出现 504 time out,需要调整Nginx中的超时时间 在刚才的 docker-compose.yaml 中指定了数据库主机是 db,用户名是 nextcloud,数据库是 nextcloud,密码是 nyist123

    内网穿透

    内网穿透使用的 frp,服务端和客户端的配置可以参考下方的这篇博客,也可以用免费的 frp 服务,就是速度和稳定性就没法保证了,或者使用 ngrok,本人尝试下来 ngrok 有不稳定的情况,偶尔会断掉

    https://www.jianshu.com/p/00c79df1aaf0

    出于效率和体验的考虑,如果是自建 frp 服务器的话,可以用 nginx 反向代理到 frp 的 http 代理端口上,https 也在服务端的 nginx 上做

    配置 frp

    个人的 frpc.ini 如下:

    [common] server_addr = 服务器ip server_port = 服务器服务端口 privilege_token = 密码 [ssh] type = tcp local_ip = 127.0.0.1 local_port = 22 remote_port = 32656 # 远程服务器的此端口映射到 22 端口 [nextcloud] type = http local_port = 8089 # 转发到树莓派的 8089 custom_domains = 自定义网盘域名

    服务端的 frps.ini 如下:

    [common] # binde_addr是指定frp内网穿透服务器端监听的IP地址,默认为127.0.0.1, #如果使用IPv6地址的话,必须用方括号包括起来,比如 “[::1]:80”, “[ipv6-host]:http” or “[ipv6-host%zone]:80” bind_addr = 0.0.0.0 # bind_port 是frp内网穿透服务器端监听的端口,默认是7000 bind_port = 7000 #auto_token = 验证token privilege_token = 密码 #token = 密码 #frp内网穿透服务器可以支持虚拟主机的http和https协议,一般我们都用80,可以直接用域名而不用增加端口号,如果使用其它端口,那么客户端也需要配置相同的其他端口。 vhost_http_port = 8189 # http 的统一转发端口 vhost_https_port = 7179 # https 的统一转发端口 dashboard_user = 管理后台用户 dashboard_pwd = 管理后台密码 # 这个是frp内网穿透服务器的web界面的端口,可以通过http://你的ip:7500查看frp内网穿透服务器端的连接情况,和各个frp内网穿透客户端的连接情况。 dashboard_port = 端口 auth_token = 密码

    自动重新运行

    还写了一个每分钟检测 frpc 是否正常运行的小脚本 start.sh

    pid=`ps -fe | grep frpc | grep -v grep | awk '{print $2}'` if [ -z "$pid" ]; then path=/home/osmc/rasp_tools/frp_client nohup $path/frpc -c $path/frpc.ini > $path/nohup.out & echo "自动重启" else echo "已经启动PID:$pid" fi

    然后安装 apt-get install cron,每分钟运行该脚本

    在crontab -e的最后加了一行,博主用的 root 加的这一任务

    * * * * * root bash /home/osmc/rasp-tools/frp_client/start.sh

    填加完之后做一个小测试,手动运行 starts.sh,发现没问题后,停掉 frpc,等待时间到达整分钟之后,观察 fprc 有没有自动重启

    root@osmc:/home/osmc/rasp-tools/frp_client# bash start.sh 自动重启 root@osmc:/home/osmc/rasp-tools/frp_client# nohup: redirecting stderr to stdout root@osmc:/home/osmc/rasp-tools/frp_client# ps -fe | grep frpc root 1864 1 0 04:27 pts/0 00:00:00 /home/osmc/rasp-tools/frp_client/frpc -c /home/osmc/rasp-tools/frp_client/frpc.ini root 1875 1343 0 04:27 pts/0 00:00:00 grep frpc root@osmc:/home/osmc/rasp-tools/frp_client# kill -9 1864 root@osmc:/home/osmc/rasp-tools/frp_client# ps -fe | grep frpc root 1883 1343 0 04:27 pts/0 00:00:00 grep frpc # .... 等待一会儿 root@osmc:/home/osmc/rasp-tools/frp_client# ps -fe | grep frpc root 1984 1 0 04:29 ? 00:00:00 /home/osmc/rasp-tools/frp_client/frpc -c /home/osmc/rasp-tools/frp_client/frpc.ini root 1985 1 0 04:29 ? 00:00:00 /home/osmc/rasp-tools/frp_client/frpc -c /home/osmc/rasp-tools/frp_client/frpc.ini root 2010 1343 0 04:29 pts/0 00:00:00 grep frpc

    配置反向代理

    这个时候就可以根据反向代理的域名,比如我的样例里边用的 http://nextcloud.wj2015.com:8189/ 访问项目,但是这样并不友好,包括

    没有HTTPS端口是8189,不好看

    为解决上述两个问题,我在 fprs服务器配置了nginx反向代理,将域名 nextcloud.wj2015.com 配好https,再代理到 raspi.nextcloud.wj2015.com:8189,具体的 vhost 配置文件如下

    upstream nextcloud-dashboard{ server 127.0.0.1:8189; } server { listen 80; #listen [::]:80; server_name nextcloud.wj2015.com; # enforce https return 301 https://$server_name$request_uri; } server { listen 443 ssl http2; #listen [::]:443 ssl http2; server_name nextcloud.wj2015.com; ssl_certificate ssl/2018-11-09-SSL/1_nextcloud.wj2015.com_bundle.crt; ssl_certificate_key ssl/2018-11-09-SSL/2_nextcloud.wj2015.com.key; # Add headers to serve security related headers # Before enabling Strict-Transport-Security headers please read into this # topic first. add_header Strict-Transport-Security "max-age=15768000; includeSubDomains; preload;"; large_client_header_buffers 4 16k; location / { proxy_set_header Host $host:$server_port; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://nextcloud-dashboard; } }

    访问 https://nextcloud.wj2015.com 可能会看到下面的提示 根据提示改一下可信域名即可,或者一开始安装的时候就在此域名下安装(更推荐)

    改可信域名需要使用 docker exec -it nextcloud_app_1 /bin/bash 进入到 docker 容器中更改对应文件,改动之后重新启动容器就需要慎重了;或者映射对应配置文件到真实路径下

    最后能看到这个页面就算成功了

    速度测试

    由于树莓派3b孱弱的性能,OSMC系统持久输出HDMI信号以及 nectcloud 带来的 php-fpm + nginx 结构上的损失,加之内网穿透后速度很慢的网络,又卡容易丢包,不推荐使用。 除非使用更好的树莓派,或者单独只装一个 nextcloud,就像 nextcloud 官方给到的内置 nextcloud 的系统。

    其他推荐

    nextcloud的功能和插件非常之丰富,但是如果只有同步文件的需求的话,可以使用去中心化的 syncting 方便的在不同电脑上同步文件,炒鸡方便,如果有在线下载的需求,可以内网穿透 + nginx 配合HTTP鉴权简单跑一个文件管理页面。

    并且 syncting 可以自己搭建中继服务器,速度+++

    参考的其他博主链接:https://zhuanlan.zhihu.com/p/69267020?from_voters_page=true 官方网站:https://syncthing.net/

    总结

    树莓派在运行有其他耗性能的服务时,就不适合再用 nextcloud 做网盘了,如果像我一样有运行其他服务诸如 KODI 的同时,还希望能在不同电脑上同步文件,那么就可以考虑同步神器 syncting 了。

    Processed: 0.018, SQL: 9