设为首页 收藏本站
查看: 878|回复: 0

[经验分享] Ubuntu14.04安装分布式存储sheepdog+zookeeper

[复制链接]

尚未签到

发表于 2019-1-8 08:59:49 | 显示全部楼层 |阅读模式
Ubuntu14.04安装分布式存储sheepdog+zookeeper

  牧羊犬(Sheepdog) 是由NTT的3名日本研究员开发的开源项目,提供分布式存储管理功能。牧羊犬提供高可用性的KVM提供块级存储卷类似亚马逊电子交易系统(弹性块存储虚拟机)的客户机。目前国内阿里等一些大公司在使用。
  一、sheepdog架构图

  如上图:
  采用无中心节点的全对称架构,无单点故障,存储容量和性能可线性扩展;
  新增节点通过简单配置可自动加入(IP:PORT),数据自动实现负载均衡;
  节点故障时,数据可自动恢复;
  直接支持QEMU/KVM应用;
  二、数据具体存储方式

  如上图:
  以VDI Object存储VM数据,向用户暴露的是一个块设备;
  包含4种数据对象:VDI、Data Object、属性对象和用于快照的VM实时状态数据对象;
  以4M的小文件方式实现OBS,但很容易基于此扩展,如使用使用库替代4M的小文件;
  下面我们来具体搭建下,我们将采用sheepdog+zookeeper方式。
  环境介绍:
  系统:Ubuntu14.04
  软件:sheepdog,zookeeper
  我们这次采用的是github上的源码下来直接编译制作成deb包来进行安装的。
1.获取sheepdog源码:
root@node1:~# git clone https://github.com/sheepdog/sheepdog.git sheepdog-github
2.切换到最稳定版本0.7.6:
root@node1:~# cd sheepdog-github/
root@node1:~# git checkout v0.7.6
4.执行autogen.sh生成configure,在此之前,可能需要安装依赖:
root@node1:~# apt-get install autoconf libtool make pkg-config
root@node1:~# ./autogen.sh
5.开始编译,sheepdog本身依赖于corosync、zookeeper等集群管理工具,由于我们制作deb包,还依赖于debian的一些工具:
root@node1:~# apt-get install liburcu-dev corosync corosync-dev zookeeper zookeeperd libzookeeper-mt-dev
root@node1:~# ./configure --enable-zookeeper
root@node1:~# apt-get install debhelper dh-autoreconf devscripts
root@node1:~# make deb
6.开始安装sheepdog:
root@node1:~# cd ..
root@node1:~# dpkg -i sheepdog_0.7.6-1_amd64.deb
7.至此sheepdog已经安装完成,如果你要把这个deb包拷贝到别的机器(node2)进行安装那么就必须在那台机器上安装相应的依赖包:
root@node1:~# apt-get install zookeeperd libcfg4 libcfg6 libcpg4 libzookeeper-mt2 libcoroipcc4
特别注意:在ubuntu14.04上找不到libcfg4的包,因为libcfg4是12.04上的包,需要在/etc/apt/sources.list里面添加一条
deb http://cz.archive.ubuntu.com/ubuntu precise main
8.配置zookeeper:
一般正式环境使用zookeeper作为sheepdog集群的管理工具,需要相关配置。如果只是单节点试用,可以不配置zookeeper。
先修改myid文件,你配置第几个节点就写几,内容是1-255;
root@node1:~# vi /etc/zookeeper/conf/myid
9.然后修改zoo.cfg文件,主要填写各个zookeeper节点的信息:
root@node1:~# vi /etc/zookeeper/conf/zoo.cfg
server.1=10.0.0.18:2888:3888
server.2=10.0.0.19:2889:3889
我有两个节点所有就只有两个,这格式就是server.myid=ip+端口号;
其中第一个端口用来集群成员的信息交换,第二个端口是在leader挂掉时专门用来进行选举leader所用。
10.重启下zookeeper;
root@node1:~# service zookeeper restart
11.启动sheepdog并挂载磁盘;
root@node1:~# mkdir /mnt/sheepdog
root@node1:~# mount -t ext4 -o noatime,barrier=0,user_xattr,data=writeback /dev/sdb1 /mnt/sheepdog
root@node1:~# useradd sheepdog
root@node1:~# chown -R sheepdog:sheepdog /mnt/sheepdog
root@node1:~# sheep /mnt/sheepdog -c zookeeper:10.0.0.18:2181,10.0.0.19:2181  Sheepdog常用命令
  设置副本数:
  dog cluster format --copies=3     //copies副本数
  查看sheepdog节点:两种方式都可以






运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-660574-1-1.html 上篇帖子: ELK+FILEBEAT+KAFKA+ZOOKEEPER日志管理分析平台 下篇帖子: ZooKeeper客户端连接数过多
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表