CentOS7.2搭建ownCloud私有云并启用SSL

ownCloud简介

ownCloud(官网)是一款开源的私有云框架,可以通过它实现个人网盘的功能,如果拥有一个性能不错的VPS,那么就可以摆脱奇慢无比的百度云等网盘啦!我花了大约一天的时间总算搭好了ownCloud。

用途

  • 如果搭在VPS上,可以用作个人的网盘使用。ownCloud提供了各个平台的文件同步客户端,因此搭建好ownCloud之后即可使用客户端来同步、上传、下载文件,十分方便。
  • 可以搭在性能较好的智能路由器上,连接硬盘,这样路由器就能作为个人的NAS存储云使用。ownCoud的文档上说明了最低配置要求需要128MB的内存(推荐512MB),这对路由器的性能提出了一定需求,请注意。

推荐配置

官方文档提供了推荐的配置要求

  • 操作系统:Ubuntu 16.04 LTS.
  • Web服务器:Apache 2.4.
  • 数据库:MySQL/MariaDB 并使用 InnoDB storage engine 
  • PHP 7

安装

安装准备

在安装之前,你需要准备的内容有:

  • 一台满足最低配置要求的Linux主机,可以是云主机、路由器、服务器。
  • 主机可以从外网通过ip地址或者域名访问从外网通过ip地址或者域名访问。
  • 由于主机将会作为网盘使用,牵涉到大量的文件传输,因此带宽和硬盘都不能太小。能接近常见使用场景的最高带宽和硬盘大小为最佳。在本例中,我的云主机带宽只有1MB,硬盘20GB。因此打开网页时能明显感到延迟。如果使用路由器搭建私有云,那么带宽一般不会有问题。请确保硬盘空间和内存大小足够,如路由器支持USB,可外接硬盘,内存大小请务必满足ownCloud的最低要求(见上)。

开始安装

登录你的主机,并开始安装ownCloud。安装的方法可以参考官方文档。下面我会以CentOS7.2为例进行介绍。

数据库安装

ownCloud支持SQlite数据库,因此可以选择不安装额外的数据库系统。然而SQlite不适用于大型的系统,因此如果你使用配置足够的云主机,建议额外安装数据库,如果使用路由器,可以选择不安装数据库系统。

ownCloud支持的数据库有MySQL和MariaDB,下面以MySQL为例。

首先,centOS支持yum包管理器,可以很方便的安装各种组件。但MySQL不在yum的默认源当中,因此需要添加这项源。

可以访问这里,查看完整的安装过程。由于版本的更新,详细步骤可能有所不同,一切请以官方文档为准。MySQL5.7的安装过程如下:

# 下载源
wget https://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
# 添加源
sudo yum localinstall mysql57-community-release-el7-9.noarch.rpm
# 安装MySQL
sudo yum install mysql-community-server

请保持流畅的网络访问。至此MySQL安装完毕。

接下来,启动并查看MySQL的安装状态

# 启动mysql
sudo service mysqld start
#查看mysql状态
sudo service mysqld status

成功运行的结果如下,(注意由于不同的系统,命令显示可能不同)

CentOS7.2搭建ownCloud私有云并启用SSL

接下来,就可以登录mysql并修改root密码了。如果你是ubuntu系统,可能安装mysql的过程中系统会要求你设置root密码,那么这些步骤可以跳过。对于centOS而言,系统在第一次启动mysql时自动生成了一个随机的密码,因此最好修改它。网上提供了很多修改root密码的方式,但最好还是参考官方文档。使用如下命令:

# 查看mysql密码
sudo grep 'temporary password' /var/log/mysqld.log
# 登录mysql
mysql -uroot -p 
# 接下来输入root密码

对于centOS而言,mysql在第一次启动时创建了临时的密码,并写入了mysqld.log日志,因此通过grep命令找到临时密码的值,并使用这个值登录系统。

接下来需要修改root密码

ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass4!';

其中'MyNewPass4!'位置改为你自己的root密码。官方文档中指出,密码需要至少8位,并且包含小写、大写、数字、符号。

至此,mysql的安装就完成了。你可以使用任意的mysql客户端如navicat、workbench等测试登录,你可能还需要修改root用户的allow host,这些内容请自行搜索解决,再次不再赘述。

web appche的安装

appche web用于网页服务器的运行,在centOS下,我们只需要通过以下命令即可安装。

yum install httpd

通过以下命令来启动或关闭httpd服务器

# 启动apache服务
service httpd start
# 关闭
service httpd stop
# 重启
service httpd restart
# 查看状态
service httpd status

启动appche服务器,接下来打开浏览器,从外网访问你的主机地址,如果你看到了apache的网页,就表明配置成功啦。

在centOS中,默认的网页根目录位于/var/www/html下,这个位置随着系统的不同可能有所不同,请注意。

安装ownCloud

安装ownCloud的过程也很简单,方法如下

# 下载
wget https://download.owncloud.org/community/owncloud-9.1.4.zip
# 解压
unzip https://download.owncloud.org/community/owncloud-9.1.4.zip
# 复制到网页根目录
cp -r owncloud/* /var/www/html

注意代码中的下载地址,可能随着版本的更新而失效,你可以在这里找到最新的下载地址。

通过以上三步,就能把ownCloud放到正确的目录了。这时候你可以再度打开浏览器输入地址查看,但是你可能只能看到一堆源代码,这是因为ownCloud基于php开发,但我们还没有安装PHP的运行环境。

安装PHP及相关组件

接下来我们需要安装PHP及其他的PHP组件。ownCloud官方建议安装5.6+以上的PHP版本,这也就是说如果我们使用

1
yum install php

yum只会为我们安装5.4版本的php。要安装php5.6,需要首先添加一些源。你可以在这里查看更详细的教程。

# 添加源
rpm -Uvh https://dl.Fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
# 安装PHP5.6
yum install php56w php56w-opcache

请注意,如果你使用Ubuntu安装,那么官方文档里提供了一种非常简单的方法,你可以参看这里

除了php本身之外,你还需要安装其他php的各类组件。

yum install php56w-cli php56w-common php56w-fpm php56w-gd php56w-mbstring php56w-xml

可以在这里找到所有需要的组件。

此外,还需要安装数据库连接驱动

# php-mysql
yum install php56w-mysql
# 以下可选yum install php56w-pecl-apcu

apcu是ownCloud可选安装的local cache ,用于增强性能。

php组件相关安装列表如下

CentOS7.2搭建ownCloud私有云并启用SSL

你可以使用如下命令查看所有安装的php组件

yum list installed | grep "php"

最后重启apache服务器。

service httpd restart

从浏览器打开主机地址,看看是否能够访问了呢。

配置ownCloud简介

至此,ownCloud安装完毕。接下来就是ownCloud的配置了,受篇幅所限,下面不再详述,仅提供相关的链接供参考。

初次设置

接下来打开主机地址,如果看到了ownCloud的界面即安装完成,如果提示缺少组件,请对照上文。接下来输入管理员账号和密码,并选择mysql作为数据库,填入mysql连接所需的用户名、密码、地址即可。

第一次配置时,需要输入data的存放位置,这里建议不要放在网站目录中,请将data文件夹放在其他目录。如/data/ownCloudData/位置,以防产生权限相关的安全问题。

如果提示缺少权限的问题,请参考这个文档或者这个文档的内容。

另外,如果将data文件夹放在了非网页目录,需要再次使用chown命令修改该文件夹的命令,参考这份代码

输入完必要信息之后,就能顺利登录ownCloud并正常使用啦!恭喜!

启用SSL

在chrome全面开始封杀HTTP之时,再继续用HTTP真有点说不过去啦,是时候将网站转移到HTTPS了。要使用HTTPS,你需要有一张SSL证书,可信的SSL证书大都需要付费。免费的SSL证书有两种办法可以获得

  1. 使用自签名的SSL证书
  2. StarSSL机构申请证书

下面是相关的链接

更多设置

更多配置包括配置本地缓存、建立邮箱服务等,下面是一些相关的链接

疑难解答

在搭建过程中,我碰到了形形色色的各式各样问题,如果你也如此,可以首先查看httpd中的logs获取错误日志来判断问题所在,centOS下logs的目录位于

cd /etc/httpd/logs/
ls

打开文件名包含error的日志,你可以看到各种详细的PHP发生的错误日志,并据此判断问题所在。

下面是我碰到过的问题,仅供参考。

  • 权限相关
    • ownCloud缺少权限读取配置文件
    • ownCloud报.user.ini , .htaccess文件缺失
    • 上传文件时,ownCloud没有权限写入文件暂存区
    • 上传文件时,ownCloud没有权限缺少写入data目录的权限
    • 解决:使用chown修改权限
  • 组件相关
    • 打开ownCloud时php报PDO错误
    • 解决:安装php56w-mysql
  • 邮件服务
    • 解决:修复PHP语法错误
  • 网页
    • 报SSL证书不受信任
    • 解决:没办法,要不花钱买付费证书吧

友情链接

最后,祝大家都能搭建出属于自己的私有云!

CentOS7.2搭建ownCloud私有云并启用SSL

相关推荐