Ceph-Seed 包含以下两点功能:
- 快速部署Ceph集群
- 快速扩展OSD
- 安装fabric和ceph-deploy。
- 提前配置ceph.repo (ceph.repo已经写到了deployFile/ceph.repo中,如repo有变动,请修改此文件) ceph.repo:
[ceph]
name=Letv ceph
baseurl=http://s3s.lecloud.com/ceph-jewel/el7/update
enabled=1
gpgcheck=0
type=repo-md
priority=1
- 之后执行:
yum install fabric ceph-deploy -y
git pull [email protected]:cuixiaotian/ceph-seed.git
git checkout centos7-jewel
- 配置到所有节点ssh登陆权限(即SSH白名单),如果没有配置到节点的服务器,那么需要在部署过程中手工输入节点的密码(如果服务器密码一致,只需输入一次).
- 参考conf/nodeProfile.conf.example的格式,创建conf/nodeProfile.conf, 并填充area,mroom, storage,这三者是形成节点hostname的依据。
注意:等于号之间不要有空格,文件尾部不要有空行
- 参考conf/monhosts.example conf/osdhosts.example的格式,创建conf/monhosts和conf/osdhosts, 填充需要部署的monitor hosts和osd hosts。
注意:一行一个IP,文件尾部不要有空行
- 执行:
sh deploy.sh [-D|--diskprofile] [raid0|noraid] [-N|--no-purge]
- 福利: 部署完成之后,会生成一个fabfile.py,这个文件已经配置了集群的一些环境,可以方便的增加其他函数来对集群进行运维操作。
- -D|--diskprofile
必填参数
。如果磁盘做了RAID0,则参数为raid0;否则参数为noraid,磁盘会去做lvm。
- -N|--no-purge
- 如果是干净环境,加上此参数,可不做purge data的操作
- 配置到所有节点ssh登陆权限(即SSH白名单),如果没有配置到节点的服务器,那么需要在部署过程中手工输入节点的密码(如果服务器密码一致,只需输入一次).
- 填写conf目录下的area,mroom和storage。
注意:等于号之间不要有空格,文件尾部不要有空行
- 执行:
sh expend-osd.sh [-c|--confserver] CONFSERVER [-s|--osdserver] OSDSERVER [-D|--diskprofile] [raid0|noraid] [-N|--no-purge] [-H|--hostname MONHOSTNAME]
- 扩充节点后,为了便于后续管理新增加的节点,可以将此节点也添加到fabfile.py中。
- 通常情况下, 新扩展的节点上的osd是不会新增到对应的host上的,因为在新扩展节点上防不胜防的被配置了“osd crush update on start = false”,为了让osd加入到这个host上,只需在ceph.conf 中删除此项配置,然后重启osd即可。在osd起来了之后,在把“osd crush update on start = false”这项配置重新添加上。
- -c|--confserver CONFSERVER
必填参数
。已有集群monitor服务器的ip。
- -s|--osdserver OSDSERVER
必填参数
。要安装osd服务器的ip。
- -D|--diskprofile [raid0|noraid]
必填参数
。如果磁盘做了RAID0,则参数为raid0;否则参数为noraid,磁盘会去做lvm。
- -N|--no-purge
- 如果是干净环境,加上此参数,可不做purge data的操作
- -H|--hostname MONHOSTNAME
- 如果已有集群monitor服务器另有hostname,需添加此参数
/usr/bin/ceph --connect-timeout=25 --cluster=ceph --name mon. --keyring=/var/lib/ceph/mon/ceph-ceph254/keyring auth get client.admin
另外更聪明的方式是,直接通过gatherkeys向monitor要,因为monitor可能还并没有生成client.admin这个key:
ceph-deploy gatherkeys ceph254