Rat's

使用Docker快速安装NextCloud个人私有云盘
说明:NexCould是一款不错,也很漂亮的个人私有云网盘,现在使用的人是越来越多了,之前发过一篇常规的搭建教程,...
扫描右侧二维码阅读全文
22
2017/11

使用Docker快速安装NextCloud个人私有云盘

说明:NexCould是一款不错,也很漂亮的个人私有云网盘,现在使用的人是越来越多了,之前发过一篇常规的搭建教程,参考:一款不错的个人私有云:NextCloud安装教程,鉴于很多人在搭建过程中或多或少都会出点问题,今天博主发个很方便的安装方法,就是用Docker安装NextCloud,看到网上很多这样的教程都是通过编辑docker-compose.yml文件来安装的,还要配置反向代理,期间容易出现很多问题,对新手很不友好,而本教程使用纯命令形式安装,不容易出问题,适合尝鲜的新手。

截图

请输入图片描述
请输入图片描述

更新

Docker镜像已替换成更新比较频繁,体积更加小的镜像,使用的是最新稳定版Alpine Linux,环境为PHP 7Nginx

安装

Github地址:https://github.com/chrootLogin/docker-nextcloud

1、安装Docker

#CentOS 6
rpm -iUvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
yum update -y
yum -y install docker-io
service docker start
chkconfig docker on

#CentOS 7、Debian、Ubuntu
curl -sSL https://get.docker.com/ | sh
systemctl start docker
systemctl enable docker

2、安装Nextcloud

#拉取Mysql镜像,记得修改数据库信息
docker run --name mysqlnc -d \
-p 3306:3306 \
-e MYSQL_ROOT_PASSWORD=moerats \
-e MYSQL_DATABASE=moerats \
-e MYSQL_USER=moerats \
-e MYSQL_PASSWORD=moerats \
-v /root/nextcloud/mysql:/var/lib/mysql \
mysql:5.7

#拉取Nextcloud镜像
docker run -d --name nextcloud --link mysqlnc \
-v /root/nextcloud/data:/data \
-p 3000:80 \
rootlogin/nextcloud

访问地址为http://IP:3000,启动命令里的3000端口可自行替换,不过后面有关端口的命令都自行修改,/root/nextcloud为网盘的数据库,也可以自行修改。

对于CentOS系统,还需要开启3000端口,开启如下:

#CentOS 6
iptables -I INPUT -p tcp --dport 3000 -j ACCEPT
service iptables save
service iptables restart

#CentOS 7
firewall-cmd --zone=public --add-port=3000/tcp --permanent
firewall-cmd --reload

如果要用域名访问,就需要反代了。

域名访问

反代可以用NginxApacheCaddy,这里只说宝塔和Caddy。如果你网站有宝塔,就可以使用宝塔进行反代,如果没有,建议使用第2种的Caddy反代,配置很快。

1、宝塔反代
先进入宝塔面板,然后点击左侧网站,添加站点,然后再点击添加好了的域名名称,这时候就进入了站点配置,点击反向代理,目标URL填入http://127.0.0.1:3000,再启用反向代理即可。至于启用SSL就不说了,直接在站点配置就可以启用。

2、Caddy反代
安装Caddy

wget -N --no-check-certificate https://raw.githubusercontent.com/iiiiiii1/doubi/master/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
#备用地址
wget -N --no-check-certificate https://www.moerats.com/usr/shell/Caddy/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh

配置Caddy

#以下全部内容是一个整体,请修改域名后一起复制到SSH运行!

#http访问,该配置不会自动签发SSL
echo "xx.com {
 gzip
 proxy / 127.0.0.1:3000 {
    header_upstream Host {host}
    header_upstream X-Real-IP {remote}
    header_upstream X-Forwarded-For {remote}
    header_upstream X-Forwarded-Port {server_port}
    header_upstream X-Forwarded-Proto {scheme}
  }
}" > /usr/local/caddy/Caddyfile

#https访问,该配置会自动签发SSL,请提前解析域名到VPS服务器
echo "xx.com {
 gzip
 tls admin@moerats.com
 proxy / 127.0.0.1:3000 {
    header_upstream Host {host}
    header_upstream X-Real-IP {remote}
    header_upstream X-Forwarded-For {remote}
    header_upstream X-Forwarded-Port {server_port}
    header_upstream X-Forwarded-Proto {scheme}
  }
}" > /usr/local/caddy/Caddyfile

tls参数会自动帮你签发ssl证书,如果你要使用自己的ssl,改为tls /root/xx.crt /root/xx.key即可。后面为ssl证书路径。

启动Caddy

/etc/init.d/caddy start

就可以打开域名进行访问了。

3、Nginx配置
如果你使用其它的,这里就大概发个Nginx反代配置,直接添加到配置文件即可。

#在配置文件里添加
location / {
     proxy_pass http://127.0.0.1:3000;
     proxy_redirect off;
     proxy_set_header X-Real-IP $remote_addr;
     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }

最后要注意的是,安装的时候,Mysql数据库地址填localhost:3306

Vultr新用户注册送100美元/16个机房按小时计费,支持支付宝,【点击查看】。
最后修改:2019 年 07 月 19 日 05 : 33 PM

发表评论

107 条评论

  1. WZZHeHe

    这个是否可以启用 SSL ?

    1. Rat's
      @WZZHeHe

      可以的,我更新下这个教程吧。

  2. admin

    第一次配置时出现504,进容器改了nginx的配置还是没有用

    1. admin
      @admin

      大佬,如何解决这个问题?

      1. Rat's
        @admin

        看是不是带不动,我没出现这问题,你加点swap试试。

        1. admin
          @Rat's

          跟服务器配置没有关系,刚开始用1核1G的云服务器搭建的,后改成本地2核4G的搭建,首次配置都会出现504

          1. Rat's
            @admin

            那就不是很清楚了。

  3. 轻言

    大佬,你这个默认数据库密码是多少呀,用了以后不知道怎么抓里面的数据

    1. Rat's
      @轻言

      数据库root密码secret,nextcloud数据库,用户名,密码,分别是nextcloud、nextcloud、secret。如果不正确请留言。

    2. Rat's
      @轻言

      这个我倒没注意看,我有空看下。

      1. Jair
        @Rat's

        同求默认数据库密码!找到可以发我邮箱 吗? Pzhier@163.com 谢谢!

        1. Rat's
          @Jair

          数据库root密码secret,nextcloud数据库,用户名,密码,分别是nextcloud、nextcloud、secret。如果不正确请留言。

          1. Jair
            @Rat's

            谢谢你,我已经学会如何安装NC了。还想学习一下如何整合onlyoffice,要是博主有文章推荐,就再感激不过了。

            1. Rat's
              @Jair

              onlyoffice是收费的吗

  4. 无聊到底

    大佬,如何修改nextcloud网盘数据库为以前教程里一键aria2+filebrower的数据库啊?顺便问一下端口改成800是不是命令要改成800:800啊

    1. Rat's
      @无聊到底

      你是说的改存储目录?端口只改前面的-p 800:80。

      1. 无聊到底
        @Rat's

        是的我想问下怎么修改储存目录,改成前面教程Aria2+AriaNg+Filebrowser的下载目录

        1. Rat's
          @无聊到底

          把-v参数后面的文件夹改成你的存储目录就行了。

  5. xigua

    win10上docker安装nextrcloud行么,我装完访问直接400报错。。。。

    1. Rat's
      @xigua

      这个没试过Win安装,所以暂时不是很清楚。

  6. 柒年

    请问怎么配置ssl文件

    1. Rat's
      @柒年

      这个就是临时用用,暂时还找不到配置简单,又带域名及ssl的镜像,你要域名并配置ssl的话,可以试试snap,教程:https://www.moerats.com/archives/429/。

  7. 柒年

    安装镜像的时候,直接选择带有容器的镜像,会比较好,注意要开放服务器端口,不然无法访问的。

  8. Sgt

    help!!!
    You are accessing the server from an untrusted domain.
    Please contact your administrator. If you are an administrator of this instance, configure the "trusted_domains" setting in config/config.php. An example configuration is provided in config/config.sample.php.
    Depending on your configuration, as an administrator you might also be able to use the button below to trust this domain.

    1. 北漂女岁月
      @Sgt

      这个问题是端口更换了 在config.php里面把端口改跟你实际的一样就解决了

    2. Rat's
      @Sgt

      这个你就需要用谷歌翻译,然后看提示解决。

  9. 11

    那么上传的文件放在哪里呢?

  10. sword

    默认站点呢,,,端口绑定失败

    1. Rat's
      @sword

      什么提示。