Home php教程 php手册 MySQL生产环境突发故障处理手册

MySQL生产环境突发故障处理手册

Jun 07, 2016 am 11:43 AM

MySQL生产环境突发故障处理,自己博客里的机票文章,具体作者不记得了(感谢原作者),好东西和大家分享,
1. LOAD飙高<br> 一般导致MySQL服务器LOAD突然飙高,可能的五种情况:<br> 1>.全表扫描的SQL语句;<br> 2>.SELECT操作语句的执行计划走错;<br> 3>.存在UPDATE/DELETE 语句没有索引可选择,而导致堵塞其他SQL语句的执行;<br> 4>.存在修改表结构或OPTIMIZE 语句执行;<br> 5>.大数据量的导入 或 导出,尤其数据库的逻辑备份操作;<br> 6>.业务量大到超过服务器处理能力(我们大家都高度关注业务发展,以及公司业务特点,<br>    还有与开发和运营保持良好联系,很难出现未知的业务突然爆发性增长);<br> 要解决LOAD飙高,必须先找到造成飙高的真实原因,请登陆数据库服务器后,执行命令:<br> SHOW PROCESSLIST;(适合MySQL各种版本)<br> 或<br> SELECT * FROM INFORMATION_SCHEMA.PROCESSLIST WHERE COMMAND  ‘sleep’ AND TIME>100;(5.1.x系列及以上版本)<br> 若一直处在执行状态,且执行时间比较久,可以分析下SQL语句执行计划:<br> EXPLAIN SQL-statement;<br> 若执行计划不合理,则可以根据SQL类型选择是否与应用负责人联系。首先,查找造成服务器LOAD飙高的PID,特别是DELETE 或UPDATE等会堵住其他SQL语句的PID,然后进入MySQL命令行工具中,对一些SQL先记录下来,再适情考虑执行:kill sql_pid;<br> 1.1 统计信息更新<br> 单表索引统计信息查看命令:SHOW INDEXES FROM tablename;<br> 若发现其统计信息存在偏差,则可以执行:ANALYZE LOCAL TABLE tablename;<br> 备注:请加上LOCAL 参数,从而使此语句执行时不需要登记到二进制文件中。<br> 1.2 碎片整理和统计信息更新<br> OPTIMIZE 操作等于recreate + analyze 的组合操作,所以会堵塞更新类型SQL语句。对于备机上跑只读类型操作的业务,可以考虑使用此操作命令,对于主服务器不建议使用此命令,为此备机上执行OPTIMIZE 语句,必须这样写:<br> OPTIMIZE LOCAL TABLE tablename;<br> 备注:这样执行将不会记录到二进制日志文件中,从而不会复制到对其有复制关系的主机上。<br> 2. HA切换<br> 2.1 启动备机Heartbeat<br> 若要启动备机上的Heartbeat进程,则必须先保证备机上的mysqld服务已经停止掉,然后再启动备机上的Heartbeat服务,最后再启动mysqld服务。<br> 2.2 VIP服务快速漂移<br> 直接关闭掉VIP所挂载的主服务器上的Heartbeat服务:service heartbeat stop,待切换之前的备机VIP服务挂载成功,再启动被关掉机器的Heartbeat服务,且确保mysqld服务已经处于停止状态,最后再启动mysqld服务。<br> 另外一种强制VIP飘移办法:<br> crm_resource -M -r resource_name -H nodename<br> 其中: resource_name 可以通过命令crm_resource  –L<br> 进行强制VIP漂移后,还需要检查 failcount值,命令与设置值,如下:<br> crm_failcount –U nodename -r resource_name –G<br> 如果failcount大于0,则进行下面的操作:crm_resource -r resource_name -p is_managed -v false (设置资源为非受控)crm_failcount -U nodename  -r resource_name -G –D (重新设置 failcount值)<br> crm_resource -H nodename  -r resource_name –C<br> crm_resource -r resource_name -d is_managed  (设置为受控)<br> 3.复制中断<br>   复制突然中断的可能原因:<br>   1>. 备机无法连接到主服务器,可能是网络问题,也可能是主服务器的mysqld已停止;<br>   2>. 主键冲突;<br>   3>. 主从服务器数据不一致;<br>   4>. 其他原因;<br>   为使复制继续,我们可以进行如下处理:<br>   1>. Stop slave ;<br>   2> start slave;<br>   3> 检查服务是否正常:show slave status\G<br>  若是主健冲突或数据不一致的情况,则需要额外处理:<br> 1>.stop slave;<br> 2> start slave;<br> 3> show slave status\G记录错误的信息,一般会有详细的SQL保存起来<br> 4> stop slave;<br> 5> SET GLOBAL sql_slave_skip_counter=1;<br> 6> start slave ;<br> 7> show slave status\G<br> 8> 检查复制是否恢复正常,若没有循环1>…7>步骤(备注:有些场景,也可以考虑借助脚<br> 本循环的方式解决)<br>  <br> 4.MySQL假死<br> 4.1 假死状态判断<br> MySQL假死状态一般只会响应对内存表、服务器状态和变量的操作,而且SHOW PROCESSLIST;可以看到很多连接线程处于命令解析或处理的各种状态,且SQL语句执行时间较长。此时,为校验是否真处于MysQL假死状态,那么可以到库test中任意执行创建表或更新数据的语句,若回车键后没有响应,则一般可以断定MySQL 是否已经处于假死状态。<br> 4.2 假死状态处理<br> 若使用Heartbeat + Dual Master的数据库架构,VIP所在的数据库服务器出现假死状态,则应该直接关闭service heartbeat stop,从而迫使VIP服务转移到另外一台数据库服务器上。<br> 其次,根据处理MySQL 假死状态的经验,使用mysqladmin –uroot –p shutdown命令关闭mysqld服务也是无法处理的,最快的办法是直接Kill进程:<br> ps -ef | grep mysql | grep -v grep | awk ‘{ print $2 }’| xargs kill -9<br> 然后,把Heartbeat启动成功之后,再启动mysqld服务;对于没有Heartbeat服务的数据库服务器,则直接启动mysqld 服务即可。<br> 5.紧急事件处理的流程<br>   1>.突发紧急事情:<br>         首先,要保持头脑清醒,心态要放平,建议先深呼吸;<br>         其次,仔细检查相关状态、日志等信息,并且保存现场的状态信息,以便后续分析;<br>         最后,确认解决此问题的可行方案,以及判断此方案是否会引入新风险,是否需要其他同事协助;<br>   2>.处理步骤复杂或命令语句多的情况,必须先把相关命令,分步骤在文档中写好;<br>   3>.突发紧急事情的处理,会影响到前端应用服务的事情,应先跟团队领导沟通和确认处理方法,以及影响范围有多大,<br>          影响程度有多严重;<br>   4>.确定紧急处理过程或完毕后,需要那些应用方负责人检查应用是否正常,则应该先联系相关同事;<br>   5>.处理完毕且业务正常之后,优先分析问题和查找是否还有隐患;<br>   6>.发邮件描述整个故障发生、影响范围和程度 、处理过程,以及补填写紧急处理的 ITIL流程单;<br>   7>.回复报警邮件;<br> 备注:<br>      突发事情的解决过程中,无关同事不得围观,需要配合的同事要迅速提供帮助和协调起来,对突发事情解决无帮助的主管及以上级别的人员,一律不得围观,否则以罚款方式处理。<br> 【编注】<br>      突然发现邮箱中竟然还有一份2年前写的东西,应该不是最新的版本,稍作整理分享出来,虽然内容不太丰富,也许对一些技术朋友有借鉴意义,大家也可以互相交换下意见和提供行业案例而逐渐把此主题相关的内容丰富起来。

AD:真正免费,域名+虚机+企业邮箱=0元

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Learn about introductory code examples for Python programming Learn about introductory code examples for Python programming Jan 04, 2024 am 10:50 AM

Learn about Python programming with introductory code examples Python is an easy-to-learn, yet powerful programming language. For beginners, it is very important to understand the introductory code examples of Python programming. This article will provide you with some concrete code examples to help you get started quickly. Print HelloWorldprint("HelloWorld") This is the simplest code example in Python. The print() function is used to output the specified content

PHP variables in action: 10 real-life examples of use PHP variables in action: 10 real-life examples of use Feb 19, 2024 pm 03:00 PM

PHP variables store values ​​during program runtime and are crucial for building dynamic and interactive WEB applications. This article takes an in-depth look at PHP variables and shows them in action with 10 real-life examples. 1. Store user input $username=$_POST["username"];$passWord=$_POST["password"]; This example extracts the username and password from the form submission and stores them in variables for further processing. 2. Set the configuration value $database_host="localhost";$database_username="username";$database_pa

From beginner to proficient: Code implementation of commonly used data structures in Go language From beginner to proficient: Code implementation of commonly used data structures in Go language Mar 04, 2024 pm 03:09 PM

Title: From Beginner to Mastery: Code Implementation of Commonly Used Data Structures in Go Language Data structures play a vital role in programming and are the basis of programming. In the Go language, there are many commonly used data structures, and mastering the implementation of these data structures is crucial to becoming a good programmer. This article will introduce the commonly used data structures in the Go language and give corresponding code examples to help readers from getting started to becoming proficient in these data structures. 1. Array Array is a basic data structure, a group of the same type

Go language programming examples: code examples in web development Go language programming examples: code examples in web development Mar 04, 2024 pm 04:54 PM

"Go Language Programming Examples: Code Examples in Web Development" With the rapid development of the Internet, Web development has become an indispensable part of various industries. As a programming language with powerful functions and superior performance, Go language is increasingly favored by developers in web development. This article will introduce how to use Go language for Web development through specific code examples, so that readers can better understand and use Go language to build their own Web applications. 1. Simple HTTP Server First, let’s start with a

Java implements simple bubble sort code Java implements simple bubble sort code Jan 30, 2024 am 09:34 AM

The simplest code example of Java bubble sort Bubble sort is a common sorting algorithm. Its basic idea is to gradually adjust the sequence to be sorted into an ordered sequence through the comparison and exchange of adjacent elements. Here is a simple Java code example that demonstrates how to implement bubble sort: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

How to use PHP to write inventory management function code in the inventory management system How to use PHP to write inventory management function code in the inventory management system Aug 06, 2023 pm 04:49 PM

How to use PHP to write the inventory management function code in the inventory management system. Inventory management is an indispensable part of many enterprises. For companies with multiple warehouses, the inventory management function is particularly important. By properly managing and tracking inventory, companies can allocate inventory between different warehouses, optimize operating costs, and improve collaboration efficiency. This article will introduce how to use PHP to write code for inventory warehouse management functions, and provide you with relevant code examples. 1. Establish the database before starting to write the code for the inventory warehouse management function.

Huawei Cloud Edge Computing Interconnection Guide: Java code examples to quickly implement interfaces Huawei Cloud Edge Computing Interconnection Guide: Java code examples to quickly implement interfaces Jul 05, 2023 pm 09:57 PM

Huawei Cloud Edge Computing Interconnection Guide: Java Code Samples to Quickly Implement Interfaces With the rapid development of IoT technology and the rise of edge computing, more and more enterprises are beginning to pay attention to the application of edge computing. Huawei Cloud provides edge computing services, providing enterprises with highly reliable computing resources and a convenient development environment, making edge computing applications easier to implement. This article will introduce how to quickly implement the Huawei Cloud edge computing interface through Java code. First, we need to prepare the development environment. Make sure you have the Java Development Kit installed (

Guidance and Examples: Learn to implement the selection sort algorithm in Java Guidance and Examples: Learn to implement the selection sort algorithm in Java Feb 18, 2024 am 10:52 AM

Java Selection Sorting Method Code Writing Guide and Examples Selection sorting is a simple and intuitive sorting algorithm. The idea is to select the smallest (or largest) element from the unsorted elements each time and exchange it until all elements are sorted. This article will provide a code writing guide for selection sorting, and attach specific Java sample code. Algorithm Principle The basic principle of selection sort is to divide the array to be sorted into two parts, sorted and unsorted. Each time, the smallest (or largest) element is selected from the unsorted part and placed at the end of the sorted part. Repeat the above

See all articles