内容简介:自建云盘系列——Seafile (支持分布式存储)
Seafile是国内团队开发的一款开源的云存储产品,其具有全平台客户端,和OwnCloud不相上下,但是和OwnCloud不同的是,它的后端是由 Python 开发的,而且还支持集群甚至Ceph分布式文件系统,个人感觉,它比OwnCloud,以及NextCloud更加专注于存储,另外两个由于插件的存在反而向云平台靠拢了,有些"臃肿"。
不过……Seafile有个很蛋疼的地方,是它的国内站下载的版本和国外站下载的不同……国内站的那个免费版是社区版(开源版),而国外站的那个则是限制了免费用户数的Pro版(企业版可能?),功能差别当然也是有的,参见下图,主要还是看需求吧,毕竟实际上开源版本的大部分人都够用了,而它的企业版授权按人数算的,也是不便宜。我建议如果用的人多,那么还是开源版吧,如果就两三个人用,而且追求折腾,那么使用三用户免费的Pro版也挺好的。
这儿我以Pro版安装介绍下Seafile的安装流程,因为两者的基础安装流程是相同的,区别只是在于Pro版可以额外安装和配置其它东西
一.下载
首先,来给个下载地址
社区版:请前往https://www.seafile.com/download/ 直接下载
Pro版:请前往https://customer.seafile.com/ 注册后将有下载地址
二.安装
我目前下载的版本是6.0.13,所以下载的压缩包名为seafile-pro-server_6.0.13_x86-64.tar.gz ,你可以注意到,官方还提供了带Ubuntu后缀名的压缩包,在文件夹说明中,该包内程序在Ubuntu 16.04环境下编译,具有更好的支持LDAPS和Ceph的特点,看你需要吧,我用不着所以差不多了
默认情况下,Seafile是内置Web服务器的,但是由于很多情况下服务器上会跑Nginx,所以不能让Seafile独占80和443端口,而我们又不喜欢访问还额外带个端口,那么,我们就需要配置Nginx来反代Seafile,而不是"单纯"的使用Seafile的一键安装脚本
(是的,Seafile自带一键安装脚本,setup-seafile.sh可以使用 SQLite 作为数据库一键安装,而setup-seafile-mysql.sh可以使用 Mysql 作为数据库一键安装,其实这俩都是假的一键,还有个真的一键,不过会帮你装全家桶,要的话可以看看——> 传送门 )
好了,回归正题,配置Seafile和Nginx一起工作其实是在安装Seafile的前提下的一个额外选项,所以我们首先要做的还是装Seafile,怎么装?当然是上面提到的一键咯
//首先来做下一键安装的前提准备 yum install python-setuptools python-imaging python-ldap MySQL-python python-memcached python-urllib3 pip install boto
这边需要注意,因为Seafile要求的是Python2.7,所以请Centos6预先安装Python2.7,安装方法我博客里有,不过那个有些麻烦,我后来还找到了一个办法,这儿说一下
//ius源依赖epel源 yum install epel-release -y rpm -Uvh https://centos6.iuscommunity.org/ius-release.rpm //是的,ius源内包含了python2.7 yum install python27 python27-devel -y //替换默认python顺便修复yum只能用python 2.6的问题 ln -sf /usr/bin/python2.7 /usr/bin/python sed -i '1s/python/python2.6/g' /usr/bin/yum wget https://bootstrap.pypa.io/get-pip.py python get-pip.py rm -rf get-pip.py
那么,又来了一个问题,yum装的那些python依赖只是给默认的Python 2.6用的,所以要给新的2.7用我们需要用pip装
pip install image ldap mysql memcached urllib3 boto
这样就OK了
然后,上传解压你下载的程序包,我选择丢到/opt/seafile 目录中
然后执行进入/opt/seafile/seafile-pro-server-6.0.13 目录 执行./setup-seafile-mysql.sh
恩,python的模块没问题了,还差个java,小意思,需要注意版本必须在1.7及以上
//你要装sunjdk啥的也行,poppler-utils是用于处理PDF的,顺便一起装了,反正也要用 yum install java-1.7.0-openjdk poppler-utils
然后继续执行一键脚本,依次填空,然后一路回车,很快就OK了
接着我们配置Nginx,来反代Seafile内置的Web服务器,在nginx的配置目录中(我的OneInStack环境要在vhost目录中)创建一个新的配置文件,内容如下
server { listen 80; listen 443 ssl http2; ssl_certificate /path/to/your.crt; ssl_certificate_key /path/to/your.key; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5; ssl_prefer_server_ciphers on; ssl_session_timeout 10m; ssl_session_cache builtin:1000 shared:SSL:10m; ssl_buffer_size 1400; ssl_stapling on; ssl_stapling_verify on; server_name your.domain.com; #强制跳转HTTPS #if ($ssl_protocol = "") { return 301 https://$host$request_uri; } proxy_set_header X-Forwarded-For $remote_addr; location / { fastcgi_pass 127.0.0.1:8000; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param PATH_INFO $fastcgi_script_name; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; fastcgi_param REMOTE_ADDR $remote_addr; #启用HTTPS fastcgi_param HTTPS on; fastcgi_param HTTP_SCHEME https; access_log /data/wwwlogs/seahub.access.log; error_log /data/wwwlogs/seahub.error.log; } location /seafhttp { rewrite ^/seafhttp(.*)$ $1 break; proxy_pass http://127.0.0.1:8082; client_max_body_size 0; proxy_request_buffering off; proxy_connect_timeout 36000s; proxy_read_timeout 36000s; } location /media { #这儿也要看你安装位置 root /opt/seafile/seafile-server-latest/seahub; } }
然后重启nginx
下面的修改也可以通过Web管理界面进行(先用端口访问修改)
修改/opt/seafile/conf/ccnet.conf
//这儿是要去除端口 如果你像我一样开了强制跳转,请用https SERVICE_URL = http://www.myseafile.com
修改/opt/seafile/conf/seahub_settings.py
//参照着新增如下这行,还是注意https问题 FILE_SERVER_ROOT = 'http://www.myseafile.com/seafhttp'
接着启动Seafile
./seafile.sh start ./seahub.sh start-fastcgi
这儿会让你创建管理员账号,然后就可以访问域名了,用创建的账号登陆
到这边其实就好了,下面说些其它的修改
三.优化
官方建议在用户数达到一定量的情况下配置Memcached,以减小系统压力
//这边的python-devel在Centos6下换成python27-devel yum install gcc libffi-devel python-devel openssl-devel libmemcached libmemcached-devel pip install pylibmc pip install django-pylibmc
然后修改/opt/seafile/conf/seahub_settings.py
//添加如下内容 CACHES = { 'default': { 'BACKEND': 'django_pylibmc.memcached.PyLibMCCache', 'LOCATION': '127.0.0.1:11211', } }
然后重启Seahub
//请在/opt/seafile/seafile-server-latest 或者你安装的位置执行 ./seahub.sh restart
这样就好了,当然这儿需要你自己装memcached,这个就不用我说了吧,不然你肯定启动失败的
另外,Seafile好像不会默认开机启动,所以如果需要这个请参考官方的开机脚本 ——> 传送门
以上所述就是小编给大家介绍的《自建云盘系列——Seafile (支持分布式存储)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 分布式存储ceph对象存储配置zone同步
- 未来的互联网存储:5 大分布式存储平台深入比较(中)
- GlusterFS分布式存储搭建双机复制卷结合Keepalived实现存储高可用
- 探索分布式存储应用
- 分布式存储架构设计
- 大数据之一 分布式存储
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
High-Performance Compilers for Parallel Computing
Michael Wolfe / Addison-Wesley / 1995-6-16 / USD 117.40
By the author of the classic 1989 monograph, Optimizing Supercompilers for Supercomputers, this book covers the knowledge and skills necessary to build a competitive, advanced compiler for parallel or......一起来看看 《High-Performance Compilers for Parallel Computing》 这本书的介绍吧!