MySQL关闭过程详解和安全关闭MySQL的方法

www.hongkevip.com    时间: -- :    阅读:     整理: 红客VIP
分享到:
红客VIP(http://www.hongkevip.com):MySQL关闭过程详解和安全关闭MySQL的方法 本文分析了mysqld进程关闭的过程,以及如何安全、缓和地关闭MySQL实例,对这个过程不甚清楚的同学可以参考下。 关闭过程: 、发起shutdown,发出SIGTERM信号 、有必要的话,新建一个关闭线程(shutdown thread) 如果是客户端发起的关闭,则会新建一个专用的关闭线程 如果是直接收到 SIGTERM 信号进行关闭的话,专门负责信号处理的线程就会负责关闭工作,或者新建一个独立的线程负责这个事 当无法创建独立的关闭线程时(例如内存不足),MySQL Server会发出类似下面的告警信息: Error: Can't create thread to kill server 、MySQL Server不再响应新的连接请求 关闭TCP/IP网络监听,关闭Unix Socket等渠道 、逐渐关闭当前的连接、事务 空闲连接,将立刻被终止; 当前还有事务、SQL活动的连接,会将其标识为 killed,并按期检查其状态,以便下次检查时将其关闭;(参考 KILL 语法) 当前有活跃事务的,该事物会被回滚,如果该事务中还修改了非事务表,,则已经修改的数据无法回滚,可能只会完成部分变换; 如果是Master/Slave复制场景里的Master,则对复制线程的处理过程和普通线程也是一样的; 如果是Master/Slave复制场景里的Slave,则会依次关闭IO、SQL线程,如果这2个线程当前是活跃的,则也会加上 killed 标识,然后再关闭; Slave办事器上,SQL线程是允许直接停止当前的SQL操作的(为了避免复制问题),然后再关闭该线程; 在MySQl 5.0.80及以前的版本里,如果SQL线程当时正好执行一个事务到中间,该事务会回滚;从5..81开始,则会等待所有的操作结束,除非用户发起KILL操作。 当Slave的SQL线程对非事务表执行操作时被强制 KILL了,可能会导致Master、Slave数据不一致; 、MySQL Server进程关闭所有线程,关闭所有存储引擎; 刷新所有表cache,关闭所有打开的表; 每个存储引擎各自负责相关的关闭操作,例如MyISAM会刷新所有等待写入的操作;InnoDB会将buffer pool刷新到磁盘中(从MySQL 5.0.5开始,如果innodb_fast_shutdown不设置为 的话),把当前的LSN记录到表空间中,然后关闭所有的内部线程。 、MySQL Server进程退出 关于KILL指令 从5.0开始,KILL 支持指定 CONNECTION | QUERY两种可选项: @KILL CONNECTION和本来的一样,停止回滚事务,关闭该线程连接,释放相关资源; @KILL QUERY则只停止线程当前提交执行的操作,其他的保持不变; 提交KILL操作后,该线程上会设置一个特殊的 kill标识表记标帜位。通常需要一段时间后才能真正关闭线程,因为kill标识表记标帜位只在特定的情况下才检查: 、执行SELECT查询时,在ORDER BY或GROUP BY循环中,每次读完一些行记录块后会检查 kill标识表记标帜位,如果发现存在,该语句会终止; 、执行ALTER TABLE时,在从原始表中每读取一些行记录块后会检查 kill 标识表记标帜位,如果发现存在,该语句会终止,删除临时表; 、执行UPDATE和DELETE时,每读取一些行记录块并且更新或删除后会检查 kill 标识表记标帜位,如果发现存在,该语句会终止,回滚事务,若是在非事务表上的操作,则已发生变换的数据不会回滚; 、GET_LOCK() 函数返回NULL; 、INSERT DELAY线程会迅速内存中的新增记录,然后终止; 、如果当前线程持有表级锁,则会释放,并终止; 、如果线程的写操作调用在等待释放磁盘空间,则会直接抛出“磁盘空间满”错误,然后终止; 、当MyISAM表在执行REPAIR TABLE 或 OPTIMIZE TABLE 时被 KILL的话,会导致该表损坏不成用,指导再次修复完成。 安全关闭MySQL几点建议 想要安全关闭 mysqld 办事进程,建议按照下面的步骤来进行: 、用具有SUPER、ALL等最高权限的账号连接MySQL,最好是用 unix socket 方式连接; 、在5.0及以上版本,设置innodb_fast_shutdown = ,允许快速关闭InnoDB(不进行full purge、insert buffer merge),如果是为了升级或者降级MySQL版本,则不要设置; 、设置innodb_max_dirty_pages_pct = ,让InnoDB把所有脏页都刷新到磁盘中去; 、设置max_connections和max_user_connections为1,也就最后除了本身当前的连接外,不允许再有新的连接创建; 、关闭所有不活跃的线程,也就是状态为Sleep 且 Time 大于 的线程ID; 、执行 SHOW PROCESSLIST 确认是否还有活跃的线程,尤其是会产生表锁的线程,例如有大数据集的SELECT,或者大范围的UPDATE,或者执行DDL,都是要特别谨慎的;

MySQL关闭过程详解和安全关闭MySQL的方法的更多相关文章

  1. DBA_Oracle Startup / Shutdown启动和关闭过程详解(概念)

    2014-08-07 Created By BaoXinjian

  2. Mysql加锁过程详解(8)-理解innodb的锁(record,gap,Next-Key lock)

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  3. Mysql加锁过程详解(9)-innodb下的记录锁,间隙锁,next-key锁

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  4. Mysql加锁过程详解(1)-基本知识

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  5. Mysql加锁过程详解(2)-关于mysql 幻读理解

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  6. Mysql加锁过程详解(3)-关于mysql 幻读理解

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  7. Mysql加锁过程详解(4)-select for update/lock in share mode 对事务并发性影响

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  8. Mysql加锁过程详解(5)-innodb 多版本并发控制原理详解

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  9. Mysql加锁过程详解(6)-数据库隔离级别(1)

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

随机推荐

  1. angular的编辑器tinymce

    angular的插件的确挺少的, 编辑器更是少, ui-tinymce是angular-ui推荐的一款编辑器(GIT: https://github.com/angular-ui/ui-tinymce ...

  2. UIScrollView和UIPageController

    实现代码: // // ViewController.m // UIpageControl // // Created by dllo on 16/3/10. // Copyright © 2016年 ...

  3. Nginx 实现AJAX跨域请求

    在工作中遇到跨域请求的问题: AJAX从一个域请求另一个域会有跨域的问题.那么如何在nginx上实现ajax跨域请求呢?要在nginx上启用跨域请求,需要添加add_header Access-Con ...

  4. Oracle使用JDBC进行增删改查

    数据库和表 create table USERS(  USERNAME VARCHAR2(20) not null,  PASSWORD VARCHAR2(20))alter table USERS  ...

  5. Java 编辑tips

    1.      windows 安装 jdk配置环境 1) 下载jdk,正常安装结束,保存安装路径. 2)我的电脑—〉右键属性—〉高级系统设置—〉环境变量—〉添加系统变量 新建两个变量 JAVAHOM ...

  6. BZOJ-3282 Tree Link-Cut-Tree(似乎树链剖分亦可)

    蛋蛋用链剖A的,我写的LCT 3282: Tree Time Limit: 30 Sec Memory Limit: 512 MB Submit: 1241 Solved: 542 [Submit][ ...

  7. TypeError: 'module' object is not callable cp fromhttp://blog.csdn.net/huang9012/article/details/17417133

    程序代码  class Person:      #constructor      def __init__(self,name,sex):           self.Name = name   ...

  8. jquery ajax 应用返回类型是html json

    jquery ajax 例子:    function JudgeUserName()        {            $.ajax({            type:"GET&q ...

  9. JSP表单处理

    当需要通过从浏览器获取一些信息,在许多情况下,最终给到Web服务器后台程序.浏览器使用两种方法将这些信息传递给Web服务器.这些方法是GET方法和POST方法. GET 方法: GET方法将追加到页面 ...

  10. Ubuntu 中软件的安装、卸载以及查看的方法总结

    Ubuntu 中软件的安装.卸载以及查看的方法总结 博客分类: Linux UbuntuDebian配置管理CacheF#  说明:由于图形化界面方法(如Add/Remove... 和Synaptic ...