03.搭建nextcloud私有云盘

03.搭建nextcloud私有云盘

我最近想把自己玩过的好玩的docker镜像整理一个合集,而这篇文章写的比较早,也是docker部署的,所以也依旧收录进这个系列。并且我目前也已经不在使用这款笔记了,目前换到了halo。

前言

突然有个需求,需要搭建一个文档存储协同的私有服务,经过多方搜索后找到onlyoffice服务可以满足我的文档编辑相关需求,而存储方面则可以利用nextcloud搭建一个私有云盘服务来满足,这样利用nextcloud+onlyoffice就可以满足我的文档在线协同存储需求,其实说白了就是可以编辑ofiice等文件并分享的的私有云盘.

前期我采用传统的镜像一个一个启动,后边我又换成了docker-compose来部署,所以我也提供了两种方案。还有一点就是我的数据库采用的是postgresql,系统还支持mysql和MariaDB,或者直接使用内置的sqLite。如果采用mysql,MariaDB配置方式和我的postgresql大同小异,内置sqLite则简单很多,直接忽略文章中数据库这一块的所有操作。


image.png

安装启动服务

方式一传统部署,方式二docker-compose部署,推荐第二种,简单。

不管哪种,先安装docker。

方式一

拉取nextcloud镜像和数据库镜像

数据库镜像是可选的,还可以采用mysql或者直接使用nextcloud内置的sqlLite,我这边采用postgresql。还有就是因为我需要操作office,还安装了onlyoffice服务,可以忽略。

    docker pull docker.io/nextcloud
    docker pull postgres
    docker pull onlyoffice/documentserver

创建启动容器

如果不使用内置数据库,那首先数据库需要初始化好存储仓库,我创建了一个cloud仓库专门用来保存数据并且启动。

启动数据库(非必须)
docker run --restart=always --name postgresql -v /etc/localtime:/etc/localtime -v /data/postgresql:/var/lib/postgresql/data -e POSTGRES_PASSWORD=123456 -d -p 35432:5432 postgres

-e POSTGRES_PASSWORD=123456的意思是数据库密码默认123456

启动office服务(非必须)

docker run  --name onlyoffice  -i -t -d -p 9000:80 onlyoffice/documentserver
启动nextcloud
docker run --restart=always  --name nextcloud -p 8080:80 -v /nextcloud:/var/www/html --link postgresql:postgresql -d nextcloud

-name nextcloud 设置容器名字

--restart=always 表示总是自启动,会在关机等重启机器后重启容器

-p 8080:80 表示把本机8080端口映射到容器内的80端口,就是你要访问时需要本机ip:8080(你可以选择自己想要端口).

-v /nextcloud:/var/www/html 用来把容器相关资源映射到本地/nextcloud目录下(你可以选择自己对应目录),方便数据持久化和外部修改页面配置等等.

--link postgresql:postgresql 非必须,链接postgresql数据库的容器,方便配置(后面细讲作用)

方式二

安装docker-compose

curl -L https://github.com/docker/compose/releases/download/1.10.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose

编写docker-compose文件

创建一个专属文件夹,以nextcloud为例,在里面创建docker-compose.yml文件

version: '2'
services:
  nextcloud:
    container_name: nextcloud_app
    image: nextcloud
    ports:
      - "8080:80"
    volumes:
      - ./app:/var/www/html
    links:
      - postgresql
    restart: always

  onlyoffice:
    container_name: nextcloud_office
    image: onlyoffice/documentserver
    ports:
      - "9000:80"
    restart: always

  postgresql:
    container_name: nextcloud_db
    image: postgres:11.4
    environment:
      - POSTGRES_PASSWORD:123456
    volumes:
      - ./postgresql:/var/lib/postgresql/data
      - /etc/localtime:/etc/localtime
    restart: always

networks:
  default:
    external:
      name: nextcloud

启动容器

在docker-compose.yml同级目录操作。
第一次启动会自动拉取镜像,所以要有网。并且采用了网络连接方式,得手动创建一个net桥。
创建net:

docker network create nextcloud

启动:

docker-compose up -d

等到以上服务正式启动好了后,接下来就是配置了。

初始化配置

浏览器访问ip:8080

image.png
  • 4.1 输入管理员账户密码

  • 4.2 数据目录建议保持不动,默认就好

  • 4.3 数据库选择

    内置SQLite数据库,存储文件较少可以直接选择默认安装完成就好.

    如果选用其他数据库,以PostgreSQL为例:

image.png

数据库用户名和密码就不用说了,数据库名对应数据库需要提前创建好.

最重要的数据库主机就是数据库的访问ip+端口号.

注:但是我填的postgresql是不是有点眼熟,对,就是--link(方式二里面使用的net方式,目的一样). 我的数据库用的也是docker容器,使用--link可以将PostgreSQL数据库的容器以别名形式传递过来,所以这边直接可以使用postgresql表示数据库(这是docker容器间的一种通信方式,注意一点是PostgreSQL容器一定要在nextcloud容器前启动).

白名单配置和使用

如果你需要域名和一些新的ip端口可以访问,需要修改/nextclou/config/config.php中配置(没有请添加)

  'trusted_domains' =>
  array (
    0 => 'www.xxx.com:10080',
  ),

然后就是使用和邮箱的配置可以进行自行摸索.

配置onlyoffice(非必须,我只是为了在线操作word等)

进入云盘以管理员账号登录,点击用户->应用来安装ONLYOFFICE插件:


image.png

然后用户->设置->ONLYOFFICE来填入自己服务的地址即可。


image.png

效果图:


image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,123评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,031评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,723评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,357评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,412评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,760评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,904评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,672评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,118评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,456评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,599评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,264评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,857评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,731评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,956评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,286评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,465评论 2 348

推荐阅读更多精彩内容