树莓派基于Docker快速搭建nextcloud,附性能测试
文章目录前言正文树莓派刷系统环境准备调整时区Docker安装docker-compose的安装nextcloud运行nextcloud内网穿透配置 frp自动重新运行配置反向代理速度测试其他推荐总结排版可能更好一点的永久原文链接:树莓派基于Docker快速搭建nextcloud,附性能测试前言一年前兴起买的树莓派3B+,一番折腾最后成为了家里的电视投屏盒子(OSMC系统),我的自建云盘放在云服务器
文章目录
排版可能更好一点的永久原文链接:树莓派基于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 了。
更多推荐
所有评论(0)