文章目录
实验所用虚拟机均为Centos 7.6系统,8G内存,16核CPU:
Ceph-admin: 用作ntp server和ceph本地源
Ceph-1: ceph-deploy、mon1、osd3
Ceph-2: mon1、osd3
Ceph-3: mon1、osd3
集群扩容
添加osd
使用ceph-deploy工具
见文章中的"添加磁盘"
手动添加
参考文章:https://cloud.tencent.com/developer/article/1664651
在新osd主机上创建osd,并创建数据目录
命令格式:ceph osd create [{uuid} [{id}]]
如果未指定 UUID, OSD 启动时会自动生成一个。
一般来说,不建议指定 {id} 。因为 ID 是按照数组分配的,跳过一些依然会浪费内存;尤其是跳过太多、或者集群很大时,会更明显。若未指定 {id} ,将用最小可用数字。
格式化磁盘,并将其挂载到刚才创建的数据目录下
将新的osd添加到crushmap中:
为新osd创建bucket。
再将对应的host移到root下,然后把OSD移到对应的host下面,注意添加OSD时的weight是该OSD的实际大小
c
[root@ceph-1 ~]# ceph osd crush add-bucket root-240G root
added bucket root-240G type root to crush map
[root@ceph-1 ~]# ceph osd crush add-bucket ceph-2-240G host
added bucket ceph-2-240G type host to crush map
[root@ceph-1 ~]# ceph osd crush move ceph-2-240G root=root-240G
moved item id -11 name 'ceph-2-240G' to location {root=root-240G} in crush map
[root@ceph-1 ~]#
[root@ceph-1 ~]# ceph osd crush add osd.12 0.24 host=ceph-2-240G
add item id 12 name 'osd.12' weight 0.24 at location {host=ceph-2-240G} to crush map
[root@ceph-1 ~]#
然后开启osd.12服务
状态出错
然后上网搜索,将osd服务的启动间隔设置为1分钟
重新加载服务配置
root@ceph-2 \~\]# systemctl daemon-reload 还是不能正常启动 查看日志: ```c [root@ceph-2 ~]# cd /var/log/ceph [root@ceph-2 ceph]# cat ceph-osd.12.log ```  应该是目录 /var/lib/ceph/osd/ceph-12 权限有问题 修改目录权限: ```c [root@ceph-2 ceph]# chown -R ceph:ceph /var/lib/ceph/osd/ceph-12 ```  启动成功。  ## 添加节点 在此实验中,将ceph-admin节点作为新节点加入ceph集群 由于在之前的实验中,ceph-admin节点作为ntp时间同步服务器,ceph-1节点、ceph-2节点和ceph-3节点作为ntp客户端向ceph-admin节点同步时间。因此,这里就不用再设置时间同步了、 在ceph-admin节点首先安装ceph ### 新节点前期准备 前期准备包括关闭火墙、添加域名解析、安装ceph、配置时间同步。具体可以参考[文章](https://blog.csdn.net/qq_43604376/article/details/131939933?spm=1001.2014.3001.5502)。 #### 新节点安装ceph,出现版本冲突 在节点执行 yum install ceph ceph-radosgw -y 报错如下: 提示已经安装了10.2.5版本 目前再安装10.2.2版本,造成了冲突   ```c 先卸载已经安装的 10.2.5版本 yum remove ceph-common-10.2.5-4.el7.x86_64 -y yum remove librados2-10.2.5-4.el7.x86_64 -y yum remove librbd1-10.2.5-4.el7.x86_64 -y ``` 阿里云镜像:`http://mirrors.aliyun.com/ceph/rpm-jewel/el7/x86_64/`, 先将10.2.11版本的所有相关包都下载,然后直接安装下载好的rpm包. 直接 `yum install *`,即可安装完成 或者 vim /etc/yum.repos.d/ceph.repo ```c [root@ceph-admin yum.repos.d]# cat ceph.repo [ceph] name=ceph baseurl=http://mirrors.aliyun.com/ceph/rpm-jewel/el7/x86_64/ gpgcheck=0 priority =1 [ceph-noarch] name=cephnoarch baseurl=http://mirrors.aliyun.com/ceph/rpm-jewel/el7/noarch/ gpgcheck=0 priority =1 [ceph-source] name=Ceph source packages baseurl=http://mirrors.aliyun.com/ceph/rpm-jewel/el7/SRPMS gpgcheck=0 priority=1 #然后安装ceph [root@ceph-admin yum.repos.d]# yum -y install ceph ceph-radosgw ``` 安装完成   ### ceph-deploy增加节点 列出ceph-admin节点上的磁盘 ```c [root@ceph-1 cluster]# ceph-deploy disk list ceph-admin ``` ```c [root@ceph-1 cluster]# ceph-deploy osd prepare ceph-admin:/dev/vdb ``` ```c [root@ceph-1 cluster]# ceph-deploy osd activate ceph-admin:/dev/vdb1 ``` 此时看ceph-admin节点  查看此时的 osd tree  可以新创建一个host,名为ceph-admin-240G ,将其移入root-240G。然后讲新增的osd.14加入host ceph-admin-240G中。 ```c [root@ceph-1 cluster]# ceph osd crush add-bucket ceph-admin-240G host added bucket ceph-admin-240G type host to crush map [root@ceph-1 cluster]# ceph osd crush move ceph-admin-240G root=root-240G moved item id -13 name 'ceph-admin-240G' to location {root=root-240G} in crush map [root@ceph-1 cluster]# ceph osd crush add osd.14 0.24 host=ceph-admin-240G add item id 14 name 'osd.14' weight 0.24 at location {host=ceph-admin-240G} to crush map ```  # 集群缩容 ## 删除osd 参考[文章](https://blog.csdn.net/qq_43604376/article/details/131983267?spm=1001.2014.3001.5502)中的"删除磁盘" **需要注意的是,在删除osd磁盘之前,需要先将osd的权重设置为0.待集群恢复平衡之后,再继续操作**。删除osd的完整步骤为: ```c ceph osd crush reweight osd.x 0.0 ... 等待平衡结束.... ceph osd out osd.x systemctl stop [email protected] #在待删除的osd所在节点上执行 ceph osd crush remove osd.x ceph auth del osd.x ceph osd rm osd.X ``` ## 删除节点 参考文章:https://blog.csdn.net/nasooo/article/details/117947537 使用以下命令,在ceph-1(monitor)节点上,添加ceph-admin节点的新磁盘 ```c ceph-deploy disk list ceph-admin ceph-deploy disk zap ceph-admin:/dev/vdc ceph-deploy disk prepare ceph-admin:/dev/vdc ceph-deploy disk activate ceph-admin:/dev/vdc1 ceph osd crush move ceph-admin-800G root=root-800G ceph osd crush add osd.15 0.8 host=ceph-admin-800G ``` 此时 ceph-admin 节点上有2块 osd 分别为osd.14 和 osd.15 。 下面演示如何删除节点ceph-admin:  ceph-admin节点停止ceph-osd服务 ```c [root@ceph-admin ~]# systemctl stop ceph-osd.target ``` 此时,ceph-admin节点上的osd状态均为down  在monitor节点删除ceph-admin节点上的所有osd ```c [root@ceph-1 cluster]# ceph osd rm 14 removed osd.14 [root@ceph-1 cluster]# ceph osd rm 15 removed osd.15 ```  从 crush map 中删除ceph-admin节点上的所有osd ```c [root@ceph-1 cluster]# ceph osd crush remove osd.14 removed item id 14 name 'osd.14' from crush map [root@ceph-1 cluster]# ceph osd crush remove osd.15 removed item id 15 name 'osd.15' from crush map [root@ceph-1 cluster]# ``` 删除ceph-admin节点上的所有osd 的认证信息 ```c [root@ceph-1 cluster]# ceph auth del osd.14 updated [root@ceph-1 cluster]# ceph auth del osd.15 updated [root@ceph-1 cluster]# ```  从 crush map 中删除节点 ceph-admin ```c [root@ceph-1 cluster]# ceph osd crush remove ceph-admin-240G removed item id -13 name 'ceph-admin-240G' from crush map [root@ceph-1 cluster]# ceph osd crush remove ceph-admin-800G removed item id -14 name 'ceph-admin-800G' from crush map ``` 取消ceph-admin节点上的所有osd的挂载  # 添加monitor节点 下面添加一个新的monitor节点,所有monitor节点的ceph版本需要一致。 待添加的monitor节点为 ceph-admin ceph-admin节点已经安装了ceph 10.2.2版本,且已经关闭火墙,域名解析、免密认证、时间同步服务已经配置好。 目前集群中有三个monitor节点,分别为ceph-1 、ceph-2 、ceph-3 在配置文件ceph.conf 中,添加ceph-admin  添加ceph-admin 节点 ```c [root@ceph-1 cluster]# ceph-deploy mon create ceph-admin 应该也可以使用命令:ceph-deploy mon add ceph-admin ``` 向ceph-admin 分发密钥 ```c [root@ceph-1 cluster]# ceph-deploy admin ceph-admin ``` 推送配置 ```c [root@ceph-1 cluster]# ceph-deploy --overwrite-conf config push ceph-1 ceph-2 ceph-3 ceph-admin ``` 添加完成  可以在该monitor上添加osd ```c [root@ceph-1 cluster]# ceph-deploy disk list ceph-admin [root@ceph-1 cluster]# ceph-deploy zap ceph-admin:/dev/vdc [root@ceph-1 cluster]# ceph-deploy disk zap ceph-admin:/dev/vdc [root@ceph-1 cluster]# ceph-deploy disk prepare ceph-admin:/dev/vdc [root@ceph-1 cluster]# ceph-deploy disk activate ceph-admin:/dev/vdc1 ```  # 删除monitor节点 删除monitor节点 ceph-admin 先删除节点上的osd  ```c [root@ceph-admin ~]# systemctl stop [email protected] [root@ceph-admin ~]# systemctl disable [email protected] Removed symlink /etc/systemd/system/ceph-osd.target.wants/[email protected]. [root@ceph-admin ~]# [root@ceph-admin ~]# ceph osd crush remove osd.14 device 'osd.14' does not appear in the crush map [root@ceph-admin ~]# ceph auth del osd.14 updated [root@ceph-admin ~]# ceph osd rm osd.14 removed osd.14 [root@ceph-admin ~]# ``` 删除ceph-admin节点: ```c ceph mon remove ceph-admin ```  修改配置文件 删除 ceph-admin的主机名和IP地址 将更改后的配置文件推送到monitor节点 ```c [root@ceph-1 cluster]# ceph-deploy --overwrite-conf admin ceph-1 ceph-2 ceph-3 ``` 完成  # 使用ceph-deploy卸载集群 参考文章:https://blog.csdn.net/a13568hki/article/details/119459832 首先安装ceph-deploy工具 ```c yum -y install ceph-deploy ``` ```c hostname=`hostname` ceph-deploy purge $hostname ceph-deploy purgedata $hostname ceph-deploy forgetkeys # osd 卸载命令 dmsetup status #查询所有ceph osd 或者vgscan + vgremove 加查询出来的id dmsetup remove_all #删除所有查询的内容 ```