前言
相信大家都用过网盘,比如国外有 Google Drive、Dropbx、OneDrive等,国内有 百度云盘、坚果云等,这些都是公共网盘,由于公司业务需要,想架设公司自己用的私有网盘。
目前市面上,稳定、成熟的私有云存储方案有:
Seafile:国内团队开发的一个国际化开源云存储项目
ownCloud:开源专业的私有云存储项目
另外,可以多去关注下 nextcloud 项目,据说 ownCloud
母公司破产后,原项目组的骨干出走并以 ownCloud
项目 folk
出新项目 nextcloud
继续开发。需要说明的是,ownCloud
母公司后来被一家德国公司收购了,ownCloud
项目还在继续开发。
这里主要介绍 ownCloud
的搭建。
ownCloud介绍
ownCloud 是开源的、免费的、专业的私有云存储解决方案,以 AGPL
许可发布,它能帮你快速地在服务器上架设一套专属的私有云文件同步网盘,可以像 Dropbox
那样实现文件跨平台同步、共享与团队协作等。
ownCloud 支持 Windows/Mac桌面端,IOS/Android手机端。基本可以替代在线网盘如百度网盘等。
Docker简介:
Docker 是个进程级的轻量化虚拟机,从狭义上来讲就是一个进程,从广义上来讲是一个虚拟容器,或者叫应用容器( Application Container )
Docker 中有三个核心概念:Image、Container、Repository。
Image:和 Windows 的那种 ISO 镜像相比,Docker 中的镜像是分层的,可复用的,而非简单的一堆文件迭在一起(类似于一个压缩包的源码和一个 Git 仓库的区别)。
Container: 容器的存在离不开镜像的支持,他是镜像运行时的一个载体(类似于实例和类的关系)。依托 Docker 的虚拟化技术,给容器创建了独立的端口、进程、文件等“空间”,Container 就是一个与宿机隔离 “容器”。容器可宿主机之间可以进行 port、volumes、network 等的通信。
-
Repository: Docker 的仓库和 Git 的仓库比较相似,拥有仓库名、tag。在本地构建完镜像之后,即可通过仓库进行镜像的分发。常用的 Docker hub 有 https://hub.docker.com/ 、 https://cr.console.aliyun.com/ 等。
Docker相对于VM有以下几个优点:
启动速度快,容器启动本质就是一个开启一个进程而已,因此都是秒启,而 VM 通常要更久
资源利用率高,一台普通 PC 可以跑成百上千个容器,你跑十个 VM 试试。
性能开销小, VM 通常需要额外的 CPU 和内存来完成 OS 的功能,这一部分占据了额外的资源
总之Docker和传统的虚拟机有着非常大的区别,下面就来部署一台Docker研究研究
0:环境检查
安装之前,我们首先确保自己的 Linux 系统内核版本高于3.10,并且系统是64位,才能体验 Docker 。
通过 uname -ir 查看是否满足要求。
>>uname -ir
安装docker
服务器系统是:CentOS6.5,在此系统中安装docker,请参考前面的文章:CentOS 7.x 上搭建docker
拉取ownCloud官方镜像
ownCloud的官方docker镜像页面
这个镜像,已经集成了 Apache + PHP
的环境。目前版本是:10.0.1
。
docker pull owncloud
需要用root用户拉取,否则会有警告:
Warning: failed to get default registry endpoint from daemon (Cannot connect to the Docker daemon. Is the docker daemon running on this host?). Using system default: https://index.docker.io/v1/
Cannot connect to the Docker daemon. Is the docker daemon running on this host?
改用MySQL数据库
owncloud 默认使用 SQLite 数据库,但对于更大的安装,官方建议选择另外一个不同的数据库,特别当使用桌面客户端同步文件时,不鼓励使用 SQLite。
拉取 mysql 官方docker镜像(目前最新是: 5.7.19 )
docker pull mysql
启动 MySQL 容器,用作 owncloud 容器的数据库。
docker run --name my-mysql -e MYSQL_ROOT_PASSWORD="Wjj+=64F" -d mysql
启动 owncloud 容器
docker run --name owncloud -p 9090:80 -v /data/db/owncloud:/var/www/html/data --link my-mysql:mysql -d owncloud
-p 9090:80 :由于宿主机已开通80端口,为了避免冲突,将容器的80端口映射到宿主机的9090端口。
--link my-mysql:mysql :将 owncloud容器(客户) 链接到 my-mysql容器(服务),链接别名:mysql。
配置nginx反向代理
配置文件内容如下:
upstream pan_server{
server 127.0.0.1:9090;
}
server {
listen 80;
server_name pan.xxx.com;
access_log /data/logs/nginx/pan.xxx.com.access.log;
error_log /data/logs/nginx/pan.xxx.com.error.log;
proxy_set_header X-Forwarded-For $remote_addr;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
add_header Cache-Control "no-cache";
proxy_pass http://pan_server;
limit_rate 256m;
client_max_body_size 0;
}
}
配好域名解析。
安装owncloud
在浏览器上访问 pan.xxx.com,进入 owncloud 安装步骤:
MySQL数据库配置:
数据库用户:root
数据库密码:Wjj+=64F
数据库名:owncloud
数据库主机:mysql 或 my-mysql
docker-compose 方式安装
也可以将上面启动 owncloud 和 mysql 容器的两个步骤合成一步完成,这里介绍 docker-compose 的使用。
docker版本要求
想要用 docker-compose,docker版本必须大于等于 1.10.0,否则会报错:
ERROR: The Docker Engine version is less than the minimum required by Compose. Your current project requires a Docker Engine of version 1.10.0 or greater.
docker-compose 安装
compose 可以通过 Python 的 pip 工具进行安装,可以直接下载编辑好的二进制文件使用,甚至直接运行在 Docker 容器中。
pip install -U docker-compose
docker-compose.yml 文件编写
version: '2'
services:
owncloud:
image: owncloud
links:
- mysql:mysql
volumes:
- "/data/db/owncloud:/var/www/html/data"
ports:
- 5679:80
mysql:
image: mysql
volumes:
- "/data/db/mysql:/var/lib/mysql"
ports:
- 3306:3306
environment:
MYSQL_ROOT_PASSWORD: "Wjj+=64F"
MYSQL_DATABASE: ownCloud
docker-compose 运行和停止
注意:docker-compose 必须在 docker-compose.yml 文件所在目录中执行,否则会报错:
ERROR:
Can't find a suitable configuration file in this directory or any
parent. Are you in the right directory?
Supported filenames: docker-compose.yml, docker-compose.yaml
docker-compose 后台启动
docker-compose up -d
docker-compose 查看状态
docker-compose ps
docker-compose 停止和删除
docker-compose stop
dcoker-compose rm
相当上面两条命令
dcoker-compose down