返回顶部
首页 > 资讯 > 精选 >如何运用结构化思维进行故障处理
  • 765
分享到

如何运用结构化思维进行故障处理

2023-06-04 23:06:54 765人浏览 安东尼
摘要

近期收到朋友赠送的一本书—《深入浅出MySQL》。闲暇之余,阅读了部分章节,书中针对故障处理一节,给我印象颇深。书中提炼出的一些方法论,正是我之前在团队中推广的方法。其目的是为了将故障应急操作标准化,进而提升处理效率。推而广之,这其实是一种

近期收到朋友赠送的一本书—《深入浅出MySQL》。闲暇之余,阅读了部分章节,书中针对故障处理一节,给我印象颇深。书中提炼出的一些方法论,正是我之前在团队中推广的方法。其目的是为了将故障应急操作标准化,进而提升处理效率。推而广之,这其实是一种结构化思维在具体工作中的体现。而这种思想在某具体工作、乃至个人、团队发展等,均可发挥重要作用。特写下此文。

一、故障处理流程

1.1 示例:数据库故障处理

下面是来自网易的一些经验,整理自《深入浅出Mysql》一书。

1.1.1 事前:故障处理原则

1)沟通第一

数据库出现故障时,务必和运维开发、产品等其他团队保持高效沟通。DBA在遇到故障时,一定不要忘了沟通的重要性,即使时间紧迫,简要的沟通往往也能带来事半功倍的效果。从长远来看,也有利于培养和其他人、其他团队之间的合作和信任关系。

2)关注人为

人为故障占有不小的比例。要通过及时沟通并查看历史记录,确认操作是否有误、要和其他团队沟通是否有特殊操作。当然,解决人为故障最好的方法还是将数据库运维自动化、标准化、规范化。

3)快速恢复

在处理故障的时候,要明确的一个思路是要优先恢复服务,确保服务的最大可用性,其他的不一定要优先考虑。

4)三思后行

有些故障处理方式,可能对数据库造成难以恢复的影响,务必慎重,并尽量做好备份。对于操作本身不熟悉带来额外的问题,要尽量避免。认真考虑命令可能带来的后果,避免对系统造成二次伤害。

5)服务分级

平时应当对服务、应用、数据库做好分级,一旦出现大面积故障,可以按照服务的优先级来恢复核心业务。

1.1.2 事中:故障处理流程

1)故障发现

  • OS指标

    • 负载
    • CPU使用率
    • 磁盘空间
    • io使用率
    • SWAP使用情况
  • DB指标

    • 数据库存活
    • 连接数
    • sql
    • 主从延迟

2)故障定位

  • 检查操作

    • 程序发布
    • 在线表变更
    • 在线数据修改
    • 后台任务、数据统计
    • 数据库参数调整
    • 其他误操作
  • 检查OS

    • 系统进程
    • CPU
    • 内存、SWAP
    • IO
    • 系统日志
  • 检查DB

    • 连接
    • 慢查询
    • 等待
    • QPS
    • 错误日志
1.1.3 事后:故障解决方法

1)慢SQL

  • 选择条件上没有索引或者索引效率低。
  • 有索引,但没有用到索引,或者选择了错误的索引。
  • 过滤条件不强,结果集太大。

2)SQL执行频率高

  • 恶意攻击
  • 缓存失效
  • 应用实现逻辑不合理
  • 业务量突增

3)锁冲突

4)硬件问题

  • RaiD卡缓存问题
  • 硬件损坏

5)参数不合理

2 示例:GP数据库异常处理(我的经验) 

下面是我在之前单位总结的,针对GP的异常处理流程。图中的【】部分对应具体的处理步骤(对应脚本或操作文档)。

如何运用结构化思维进行故障处理

从上述两个示例可以看出,这是一种"统筹式"的工作方式,而非"应急式"的。它强调的是在出现故障后,按照规划好的原则、步骤进行分析排查,找出核心问题;然后针对既有问题,再按照已有的相关预案进行处理。同时在处理过程中,注意规避风险及沟通协调,以期达到故障的快速解决。 显然这种方式,代表着一种对工作的前瞻力,防患于未然;避免了那种忙于救火,使工作永远处于被动之中。上述其实就是一种"结构化思维"的体现。

二、结构化思维

2.1 什么是"结构化思维"?

  • 思考的时候没有逻辑,大多数时候不知道从哪里下手。
  • 讲话时没有条理,费很多口舌却很难把事说清楚。
  • 处理问题时效率低,东捡西漏,忙得团团转效果却不佳。
  • 当你面临上述窘境时,正是可以考虑训练自己的结构化思维来解决。

结构化思维:是指一个人在面对工作任务或者难题时能从多个侧面进行思考,深刻分析导致问题出现的原因,系统制定行动方案,并采取恰当的手段使工作得以高效率开展,取得高绩效。当你这样做事的时候,你就拥有了结构化思维,这将对你的职场晋升起到巨大的帮助作用。思维决定发展,思维层面不同导致结果不同。简言之,结构化思维指从整体思考到局部,是一种层级分明的思考模式。就是借用一些思维框架来辅助思考,将碎片化的信息进行系统化的思考和处理,从而扩大思维的层次,更全面地思考。

如何运用结构化思维进行故障处理

2.2 结构化思维方法

如何进行结构化思考呢,也是有方法论的,总的来说是有两个步骤,首先是“建立中心”,然后再进行“分解”。

1)建立中心

建立中心也就是要定义清楚要解决的问题,要明确目标,也是一种以终为始的思考方式。也就是说,首先要搞清楚why,然后再进行how。建立中心有两种方式:自上而下、自下而上。后面我们会详细说明。

建立中心通常不会是一次成型的,随着对问题理解的变化,对中心的抽象也会进行相应的调整。不同的抽象层次其面对的问题宽度是不一样的。具体要用哪个层次的抽象作为“中心”,要视具体情况而定。抽象层次越高,要解决的问题域就越宽,外延越大。比如面对“系统 bug 多”的问题,向上抽象是“提升代码质量”,向下抽象是“加强测试”,都可以作为中心,选择哪个为中心取决于你当前要解决的问题是什么。

2)结构化分解

使用结构化的思维对问题进行分解。分解策略就是常见的四种逻辑顺序,即演绎顺序、时间顺序、空间顺序和程度顺序。

3)逻辑顺序

下面配图为XMind工具的对应图例。

  • 演绎(因果)顺序

“大前提、小前提、结论”的演绎推理方式就是演绎顺序。比如,经典三段论:所有人都要死,苏格拉底是人,苏格拉底要死。

如何运用结构化思维进行故障处理

  • 时间(步骤)顺序

“第一、第二、第三”,“首先、然后、再者”等,很多的时间顺序同时也是因果顺序。

如何运用结构化思维进行故障处理

  • 空间(结构)顺序

前端后端、数据”,“波士顿、纽约、华盛顿”,化整为零(将整体分解为部分)等都是空间顺序。在做空间分解的时候,要注意满足 MECE(Mutually Exclusive Collectively Exhaustive,相互独立,完全穷尽)原则。

如何运用结构化思维进行故障处理

  • 程度(重要性)顺序

比如“最重要、次重要、不重要”等。

2.3 "自上而下"的思考

自上而下的思考,适用于问题比较明确的情况,我们只需要找到问题的核心要素即可,然后进行展开即可。这就是一个非常典型的总分结构化思维的思考方式。先总结,后发散。用这种方式思考,有助于形成、整理和构造思维导图,从而促进大脑自然有序地思考,从而让你更全面地去分析一个问题。下面介绍几种常见的自上而下的思考模型:

1)STAR法则

  • Situation 背景 
  • Target 目标 
  • Action 行动
  • Result 结果

如何运用结构化思维进行故障处理

2)SWOT 分析方法

  • Strengths 优势
  • Weaknesses 劣势
  • Opportunities 机会
  • Threats威胁

如何运用结构化思维进行故障处理

3)问题解决

分析问题>找到原因>设置目标>提出解决方案>实施

如何运用结构化思维进行故障处理

2.4 "自下而上"的思考

对于问题不够明确的情况,需要对多种杂乱的内容,进行分类、剪枝、归纳汇总成一个中心。根据《金字塔原理》“任何事情都可以归纳出中心论点,中心论点可由三至七个论据支撑,每个一级论点可以衍生出其他的分论点。”如此发散开来,就可以形成以下的金字塔结构思考方式。

如何运用结构化思维进行故障处理

但是在还没有掌握这种结构化思维方式时,直接用这种思考方式是有一定难度的。这时候我们就可以采用自下而上的思考方式去找结构。

  • 尽可能列出所有思考的要点
  • 找出关系,进行分类
  • 总结概括要点,提炼观点
  • 观点补充,完善思路

总结下就是:先发散,后总结。用这种方式思考,不仅更容易找到逻辑结构,也更容易培养你的结构化思维。举个例子,当我们面临职业发展选择时,如何总结提炼出自己的决策。

如何运用结构化思维进行故障处理

2.5 增强 — 扩展性思维

扩展性思维的核心目标是提升思维的广度,可以有三种扩展方向:

  • 举一反三:解决同类型的N个问题

这种思维方式的特征是举一反三,触类旁通,相当于产生批处理的效果,可以大大提升解决问题的效率,避免重复处理。

  • 寻求可能性:拓展解决问题的不同手段

拓展思维常见的手段是:是否能够换更多的理解方式,或者更多的解法。

  • 深挖根源:挖掘问题深层次原因

这种思维方式是要突破现有问题的表面化解决,而是需要深挖原因,探究根本问题。只有这样才能从根本上解决问题。

2.6 示例:我的一次故障经历(深挖原因)

如何运用结构化思维进行故障处理

写在最后

思维方式有很多种,你可以在实际工作中,尝试使用上面的方法。坚持一段时间后,你会发现想问题时更有逻辑性,说话也更有条理更有说服力。不仅如此,你还可以用这种结构化的思维,去搭建和构造自己的思维体系。

作者:韩锋

首发于作者个人公号《韩锋频道》。

来源:宜信技术学院

--结束END--

本文标题: 如何运用结构化思维进行故障处理

本文链接: https://lsjlt.com/news/240342.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何运用结构化思维进行故障处理
    近期收到朋友赠送的一本书—《深入浅出MySQL》。闲暇之余,阅读了部分章节,书中针对故障处理一节,给我印象颇深。书中提炼出的一些方法论,正是我之前在团队中推广的方法。其目的是为了将故障应急操作标准化,进而提升处理效率。推而广之,这其实是一种...
    99+
    2023-06-04
  • 如何进行DB2表结构批量处理
    这期内容当中小编将会给大家带来有关如何进行DB2表结构批量处理,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、查询所有列SELECT   &...
    99+
    2024-04-02
  • 如何进行Oracle 运维命令整理
    本篇文章为大家展示了如何进行Oracle 运维命令整理,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、oracle建库与删库命令(1)oracle11g建库(一般习惯配置gdbname与sid名一...
    99+
    2023-06-28
  • 虚拟化故障怎么办?虚拟化如何运维?
     此次疫情防控,信息及时共享、实时追踪,管控体系的全覆盖和云计算紧密相关。如果运营中的任何一座数据中心出现细微的差错都将会影响上亿人的互联网使用。在这场激烈的战斗中,有那么一群人,在背后默默守护着信息的传输,他们就是---数据中心...
    99+
    2023-06-04
  • Graylog如何处理结构化和非结构化日志数据
    Graylog是一种开源的日志管理平台,可以处理结构化和非结构化日志数据。Graylog支持多种日志输入源,包括Syslog、GEL...
    99+
    2024-04-02
  • 如何使用Inception进行MySQL自动化运维平台建设
    本篇文章给大家分享的是有关如何使用Inception进行MySQL自动化运维平台建设,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。MySQL自...
    99+
    2024-04-02
  • 如何在C++中处理非结构化数据和半结构化数据?
    在 c++++ 中处理非结构化数据涉及数据预处理、特征提取和模型训练。处理半结构化数据包括数据解析、提取和转换。具体步骤如下:非结构化数据:数据预处理:清除噪声和归一化。特征提取:从数据...
    99+
    2024-05-16
    非结构化数据 半结构化数据 c++
  • MySQL 8.0.11 innodb cluster运维管理中如何进行备份
    本篇文章为大家展示了MySQL 8.0.11 innodb cluster运维管理中如何进行备份,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。MySQL 8.0.1...
    99+
    2024-04-02
  • 网站内部结构的优化究竟该如何进行
    这篇文章给大家介绍网站内部结构的优化究竟该如何进行,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 网站结构如何优化涉及以下六个部分: 1、栏目设计 分析:网站栏目的设计,在前面市场调查和竞争对手分析时,就已经...
    99+
    2023-06-12
  • pycharm运行结果窗口不见了如何处理
    如果PyCharm的运行结果窗口不见了,可以按照以下步骤进行处理:1. 确保运行结果窗口没有被最小化或者隐藏起来。尝试点击窗口底部的...
    99+
    2023-09-15
    pycharm
  • Angular如何结合Git Commit进行版本处理
    这篇文章主要介绍Angular如何结合Git Commit进行版本处理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!上图是页面上展示的测试环境/开发环境版本信息。后面有介绍上图表示的...
    99+
    2024-04-02
  • 运用数据结构优化 PHP 函数处理数据的效率
    利用数据结构优化php函数处理数据的效率:选择合适的数据结构:数组、哈希表、链表、堆栈、队列优化数组排序:使用二叉树优化冒泡排序优化哈希表查找:利用哈希表自身特性优化查找复杂度优化链表插...
    99+
    2024-04-11
    效率 php 键值对 冒泡排序
  • 微服务架构中如何处理非结构化数据的处理和存储?
    随着互联网技术的不断发展,越来越多的企业开始采用微服务架构来提高业务的效率和灵活性。在微服务架构中,微服务之间采用轻量级的通信协议进行交互,而非结构化数据的处理和存储成为了一个重要的问题。本文将介绍在微服务架构中如何处理非结构化数据的处理和...
    99+
    2023-05-17
    存储 微服务架构 非结构化数据处理
  • 如何进行PHP的国际化和本地化处理?
    随着互联网的不断发展,全球市场的需求越来越重要,而PHP作为一门广泛应用于Web应用开发的编程语言,也越来越需要进行国际化和本地化处理,以适应不同国家和地区的用户需求。本文将介绍PHP的国际化和本地化处理的基础知识和实现方法。一、国际化和本...
    99+
    2023-05-14
    PHP 国际化 本地化
  • 如何利用运维面板进行数据库一键安装和管理?
    数据库的管理维护工具非常多,除了系统自带的命令行管理工具之外,还有许多其他的管理工具,MySQL是一个非常流行的小型关系型数据库管理系统,2008年1月16号被Sun公司收购。目前MySQL被广泛地应用在Internet上的中小型 网站中。...
    99+
    2020-09-09
    如何利用运维面板进行数据库一键安装和管理?
  • 如何进行CSS预处理语言的模块化
    这篇文章给大家介绍如何进行CSS预处理语言的模块化,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。编写css是前端工作中,一项普通而又频繁的劳动,由于css并不是一门语言,所以在程序设计...
    99+
    2024-04-02
  • 微服务架构中如何处理服务的故障处理和恢复?
    随着互联网和云计算技术的飞速发展,越来越多的企业开始采用微服务架构来构建分布式系统,以实现更高的可伸缩性、可扩展性和可靠性。但是,微服务架构中服务的故障处理和恢复也是一个重大挑战,因为微服务架构中的服务是高度分布式和松散耦合的。因此,了解微...
    99+
    2023-05-17
    恢复 微服务架构 故障处理
  • 如何使用PHP进行视频处理?
    随着网络技术的飞速发展,视频已经成为人们日常生活中不可或缺的一部分。在这个数字时代,如何使用PHP进行视频处理已经成为了一个热门话题,本文将介绍PHP的一些基本功能和工具,以帮助大家更好地处理视频。一、认识PHPPHP是一种高级程序设计语言...
    99+
    2023-05-22
    PHP 视频处理 多媒体应用
  • 使用Rest如何对API进行处理
    这篇文章给大家介绍使用Rest如何对API进行处理,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、项目目标动静分离的架构,即客户端和服务器端的分离,客户端可以是IOS、android或者静态的页面。需要服务器端提供w...
    99+
    2023-05-31
    rest api
  • 如何进行C语言结构体的定义和使用
    本篇文章为大家展示了如何进行C语言结构体的定义和使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.1: 结构体用来干嘛生活中我们会遇到很多的表格,就比如你的学习成绩表,有姓名 ,学号,各科的成绩...
    99+
    2023-06-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作