为什么关不掉所有的OSD
前言
碰到一个cepher问了一个问题:
为什么我的OSD关闭到最后有92个OSD无法关闭,总共的OSD有300个左右
想起来在很久以前帮人处理过一次问题,当时环境是遇上了一个BUG,需要升级到新版本进行解决,然后当时我来做操作,升级以后,发现osd无法启动,进程在,状态无法更新,当时又回滚回去,就可以了,当时好像是K版本升级到J版本,想起来之前看过这个版本里面有数据结构的变化,需要把osd全部停掉以后才能升级,然后就stop掉所有osd,当时发现有的osd还是无法stop,然后就手动去标记了,然后顺利升级
今天这个现象应该跟当时是一个问题,然后搜索了一番参数以后,最后定位在确实是参数进行了控制
实践
我的一个8个osd的单机环境,对所有OSD进行stop以后就是这个状态,还有2个状态无法改变
[root@lab8106 ~]# ceph -s
cluster 49ee8a7f-fb7c-4239-a4b7-acf0bc37430d
health HEALTH_ERR
295 pgs are stuck inactive for more than 300 seconds
295 pgs stale
295 pgs stuck stale
too many PGs per OSD (400 > max 300)
monmap e1: 1 mons at {lab8106=192.168.8.106:6789/0}
election epoch 3, quorum 0 lab8106
osdmap e77: 8 osds: 2 up, 2 in; 178 remapped pgs
flags sortbitwise,require_jewel_osds
pgmap v296: 400 pgs, 1 pools, 0 bytes data, 0 objects
76440 kB used, 548 GB / 548 GB avail
295 stale+active+clean
105 active+clean
看下这组参数:
mon_osd_min_up_ratio = 0.3
mon_osd_min_in_ratio = 0.3
我们修改成0 后再测试
mon_osd_min_up_ratio = 0
mon_osd_min_in_ratio = 0
停止进程
systemctl stop ceph-osd.target
查看状态
[root@lab8106 ~]# ceph -s
cluster 49ee8a7f-fb7c-4239-a4b7-acf0bc37430d
health HEALTH_ERR
48 pgs are stuck inactive for more than 300 seconds
85 pgs degraded
15 pgs peering
400 pgs stale
48 pgs stuck inactive
48 pgs stuck unclean
85 pgs undersized
8/8 in osds are down
monmap e1: 1 mons at {lab8106=192.168.8.106:6789/0}
election epoch 4, quorum 0 lab8106
osdmap e86: 8 osds: 0 up, 8 in
flags sortbitwise,require_jewel_osds
pgmap v310: 400 pgs, 1 pools, 0 bytes data, 0 objects
286 MB used, 2193 GB / 2194 GB avail
300 stale+active+clean
85 stale+undersized+degraded+peered
15 stale+peering
可以看到状态已经可以正常全部关闭了
分析
这里不清楚官方做这个的理由,个人推断是这样的,默认的副本为3,那么在集群有三分之二的OSD都挂掉了以后,再出现OSD挂掉的情况下,这个集群其实就是一个废掉的状态的集群,而这个时候,还去触发down和out,对于环境来说已经是无效的操作了,触发的迁移也属于无效的迁移了,这个时候保持一个最终的可用的osdmap状态,对于整个环境的恢复也有一个基准点
在Luminous版本中已经把这个参数改成
mon_osd min_up_ratio = 0.3
mon_osd_min_in_ratio = 0.75
来降低其他异常情况引起的down,来避免过量的迁移
总结
本篇就是一个参数的实践
变更记录
Why | Who | When |
---|---|---|
创建 | 武汉-运维-磨渣 | 2017-08-21 |
为什么关不掉所有的OSD的更多相关文章
- 关不掉.vbs
创建: 1.在桌面新建一个 关不掉.txt 文本文档 2.打开输入一下内容 do msgbox"信不信你关不掉我" msgbox"哈哈,你相信了吧" msgbo ...
- 关不掉的小姐姐程序python tkinter实现 学习---打包教程
首先,我们先准备两个.py文件,还要图片文件 代码//是我自己手写的,copy时记得删掉,不然有可能错误,比如中英文啥的 当然 一些语法的无问题就百度,都能给你答案 第一个.py ...
- 用 Python 制作关不掉的端午安康弹窗
端午节又称端阳节.龙舟节.重午节.龙节.正阳节.天中节等,端午节源自天象崇拜,由上古时代祭龙演变而来,因传说战国时期的楚国诗人屈原在五月五日跳汨罗江自尽,后来人们亦将端午节作为纪念屈原的节日,在端午节 ...
- sql-lib闯关1-10关
闯关之前我们需要搭建所需环境SQLi-Labs SQLi-Labs是一个专业的SQL注入练习平台,该平台包含了以下在测试场景中常见的注入类型: 1.报错注入(联合查询) 1)字符型 ...
- 关于我用python表白成功这件事【表白成功】
520,并非情人所属, 我们可以表白万物, 不管什么时候, 这都是一个特别的日子, 今天,我要表白所有, 心里有我的人! 在这个充满幸福的日子里, 我要把最美好的祝福, 送给心里有我的每一个人: 祝愿 ...
- 工作中遇到的一个多线程下导致RCW无法释放的问题
最近有个同事在调用一个类库中的方法时遇到了一个问题,异常信息如下: 尝试释放正在使用的RCW,活动线程或其他线程上正在使用该 RCW,释放正在使用的 RCW 的尝试会导致损坏或数据丢失. 该方法中对w ...
- 关闭firefox的plugincheck
每次打开firefox都弹出这个SB页面: https://www.mozilla.org/en-US/plugincheck/ 关不掉, 很是烦人. 经过地番google,找到了答案: about: ...
- Windows下将nginx安装为服务运行
今天看到nginx这个小服务器软件正式版更新到了1.4.2,想玩下它.这个服务器软件虽小,但功能强大,是开源软件,有着良好的性能,被很多个人.企业,甚至大型企业所使用! 由于是在Windows下,所以 ...
- 用代码控制鼠标键盘(C#语言)
前些时间想做一个鼠标点击器,用到了这些知识. 下面整理记录一下. ps.感谢各位大神 下面直接上代码 1.鼠标的控制 class MouseMove { #region MouseEvent [Sys ...
随机推荐
- JAVA Schedule的Cron表达式
spring中用到的定时任务,一般用到的有Timer()和Schedule Cron表达式一般是程序的定时任务中所要起的..我们用的springboot中的@Schedule中,启动类中添加enabl ...
- 扫描仪扫描文件处理-Photoshop批处理弹出色阶设置框解决
为什么我录制动作明明设置的有色阶,最后批处理的时候仍然弹出了色阶设置框? 出现问题原因可能是你在录入设置色阶动作的时候,是彩色图片或者灰阶中的一种,而批处理的时候遇到了另外一种色彩模式.所以动作中 ...
- Shell Scripting 笔记
Shell Scripting Tutorial Variables in the Bourne shell do not have to be declared, as they do in lan ...
- 图解git,用手绘图带你理解git中分支的原理和应用
大家好,今天我们来聊git当中一个非常非常重要的特性,就是branch. git branch可以说是git当中最重要的概念了,甚至没有之一.因为git最重要的使用场景就是协同开发,大家一起在一个项目 ...
- windows.h和WinSock2.h出现重定义API
有两种常用的解决方法:1.把WinSock2.h写在windows.h之前 2.使用宏定义#define WIN32_LEAN_AND_MEAN
- 枚举的使用(限foton)
使用: /** * 服务真实性标签 * * @param realRepairs * 真实维修单数 * @param totalRepairs * 总单数 * @return */ public st ...
- 第 1 篇:Vue.js 很高兴认识你
作者:HelloGitHub--追梦人物 Hello Vue 既然是学习编程,那就遵循一下那个古老的传统仪式. 首先我们新建一个 todos.html 文件,用任何一个你喜欢的文本编辑器或者 IDE ...
- MySQL连接报错(错误:1130)
1. 原因 显示这个错误是因为没有连接到该机器MySQL数据库的权限,这是在一开始安装MySQL是默认设置的. 在数据库mysql下有一张名为`user`的表,其中的字段user下的root的值默认为 ...
- 【Luogu】P1306 斐波那契公约数 题解
原题链接 嗯...很多人应该是冲着这个标题来的 (斐波那契的魅力) 1.分析题面 点开题目,浏览一遍题目,嗯?这么简单?还是蓝题? 再看看数据范围,感受出题人深深的好意... \(n,m \leq 1 ...
- shp文件转dwg并创建文本标注
不得不说,ArcGIS 和 CAD 之间的兼容性非常差,shapefile文件和dwg文件之间互相转换会丢失各种属性,但是很多时候他们之间的转换对我们来说是刚需.通常我们都是通过第三方软件(如FME) ...