mysql mysql解锁被锁定的表表 后 能写吗

MySQL5.6 更改字段属性仍旧会锁全表,注意这个坑!
MySQL5.6 更改字段属性仍旧会锁全表,注意这个坑!
如图:650) this.width=650;" src="/uploads02/u02/8f/7a/8f7ad1d4d22f599c06e080.jpg" title="5.6.jpg" alt="wKioL1Mav9-R97v9AAQjF-CtN9g034.jpg" />如果开发让修改表字段属性,建议用pt-online-schema-change。MySQL5.6的在线DDL会锁全表。注意这个坑。另外,增加、删除字段或索引不会锁全表,删除主键会锁全表。本文出自 “贺春?D的技术专栏” 博客,请务必保留此出处http://hcymysql./0546
感谢关注 Ithao123精品文库频道,是专门为互联网人打造的学习交流平台,全面满足互联网人工作与学习需求,更多互联网资讯尽在 IThao123!
Laravel是一套简洁、优雅的PHP Web开发框架(PHP Web Framework)。它可以让你从面条一样杂乱的代码中解脱出来;它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁、富于表达力。
Hadoop是一个由Apache基金会所开发的分布式系统基础架构。
用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。
Hadoop实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS。HDFS有高容错性的特点,并且设计用来部署在低廉的(low-cost)硬件上;而且它提供高吞吐量(high throughput)来访问应用程序的数据,适合那些有着超大数据集(large data set)的应用程序。HDFS放宽了(relax)POSIX的要求,可以以流的形式访问(streaming access)文件系统中的数据。
Hadoop的框架最核心的设计就是:HDFS和MapReduce。HDFS为海量的数据提供了存储,则MapReduce为海量的数据提供了计算。
产品设计是互联网产品经理的核心能力,一个好的产品经理一定在产品设计方面有扎实的功底,本专题将从互联网产品设计的几个方面谈谈产品设计
PHP(外文名:PHP: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言。语法吸收了C语言、Java和Perl的特点,利于学习,使用广泛,主要适用于Web开发领域。PHP 独特的语法混合了C、Java、Perl以及PHP自创的语法。它可以比CGI或者Perl更快速地执行动态网页。用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML(标准通用标记语言下的一个应用)文档中去执行,执行效率比完全生成HTML标记的CGI要高许多;PHP还可以执行编译后代码,编译可以达到加密和优化代码运行,使代码运行更快。
IThao123周刊scpman 的BLOG
用户名:scpman
文章数:38
访问量:6111
注册日期:
阅读量:5863
阅读量:12276
阅读量:379379
阅读量:1071833
51CTO推荐博文
&mysql&show processlist;
出来哗啦啦好几屏幕的, 没有一千也有几百条, 查询语句把表锁住了, 赶紧找出第一个Locked的thread_id, 在mysql的shell里面执行.
mysql&kill thread_id;
kill掉第一个锁表的进程, 依然没有改善. 既然不改善, 咱们就想办法将所有锁表的进程kill掉吧, 简单的脚本如下.
#!/bin/bash
mysql -u root -e &show processlist& | grep -i &Locked& && locked_log.txt
for line in `cat locked_log.txt | awk '{print $1}'`
echo &kill $line;& && kill_thread_id.sql
现在kill_thread_id.sql的内容像这个样子
好了, 我们在mysql的shell中执行, 就可以把所有锁表的进程杀死了.
mysql&source kill_thread_id.sql
当然了, 也可以一行搞定
for id in `mysqladmin processlist | grep -i locked | awk '{print $1}'`
本文出自 “” 博客,请务必保留此出处
了这篇文章
类别:┆阅读(0)┆评论(0)帐号:密码:下次自动登录{url:/nForum/slist.json?uid=guest&root=list-section}{url:/nForum/nlist.json?uid=guest&root=list-section}
贴数:28&分页:走很远的路是为了休息我的心灵发信人: meffee (走很远的路是为了休息我的心灵), 信区: Database
标&&题: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 12:11:13 2012), 站内 && mysql无论何种数据引擎,有可能做到select语句不锁定表吗?
需求是日志表需要做实时分析,同时又会有不停的业务库表的
更新复制过来,希望select最新的日志记录,同时对复制影响
最小... && --
春观夜樱,夏望繁星,秋赏满月,冬会初雪... &&&& ※ 来源:·水木社区 newsmth.net·[FROM: 219.234.141.*]
梦醒时分发信人: Knightmare (梦醒时分), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 12:16:13 2012), 站内 && 任何关系数据库在做任何操作前,都肯定加锁的。
你可能想加个低等级的锁吧
【 在 meffee (走很远的路是为了休息我的心灵) 的大作中提到: 】
: 标&&题: mysql数据表有可能select不锁定表吗?
: 发信站: 水木社区 (Thu Apr 12 12:11:13 2012), 站内
: mysql无论何种数据引擎,有可能做到select语句不锁定表吗?
: 需求是日志表需要做实时分析,同时又会有不停的业务库表的
: 更新复制过来,希望select最新的日志记录,同时对复制影响
: 春观夜樱,夏望繁星,秋赏满月,冬会初雪...
: ※ 来源:·水木社区 newsmth.net·[FROM: 219.234.141.*]
&&&& -- && ※ 来源:·水木社区 newsmth.net·[FROM: 123.114.169.*]
走很远的路是为了休息我的心灵发信人: meffee (走很远的路是为了休息我的心灵), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 13:18:05 2012), 站内 && 对,日志是不会修改的,复制过程只会不停的insert
因此如果select加行级锁,理论可以避免影响复制过程?
MyISAM数据引擎,只支持Table lock,看来只能是改用
InnoDB才可以,如果用InnoDB,可以解决吗? && 【 在 Knightmare (梦醒时分) 的大作中提到: 】
: 任何关系数据库在做任何操作前,都肯定加锁的。
: 你可能想加个低等级的锁吧
品尝过小茜的食物后... && 玄马(-_-b)&& :“乱马,咱们继续修行吧!”
乱马(-_-bb)&&:“是!”
小茜(-_-bbb) :“... ...” &&&& ※ 来源:·水木社区 newsmth.net·[FROM: 219.234.141.*]
梦醒时分发信人: Knightmare (梦醒时分), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 13:19:58 2012), 站内 && 换innoDB可以解决你这个问题
不过查询速度会下降接近10倍左右。
【 在 meffee (走很远的路是为了休息我的心灵) 的大作中提到: 】
: 标&&题: Re: mysql数据表有可能select不锁定表吗?
: 发信站: 水木社区 (Thu Apr 12 13:18:05 2012), 站内
: 对,日志是不会修改的,复制过程只会不停的insert
: 因此如果select加行级锁,理论可以避免影响复制过程?
: MyISAM数据引擎,只支持Table lock,看来只能是改用
: InnoDB才可以,如果用InnoDB,可以解决吗?
: 【 在 Knightmare (梦醒时分) 的大作中提到: 】
: : 任何关系数据库在做任何操作前,都肯定加锁的。
: : 你可能想加个低等级的锁吧
: 品尝过小茜的食物后...
: 玄马(-_-b)&& :“乱马,咱们继续修行吧!”
: 乱马(-_-bb)&&:“是!”
: 小茜(-_-bbb) :“... ...”
: ※ 来源:·水木社区 newsmth.net·[FROM: 219.234.141.*]
&&&& -- && ※ 来源:·水木社区 newsmth.net·[FROM: 123.114.169.*]
邦卡猫发信人: cugbcat (邦卡猫), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 13:58:58 2012), 站内 && 到slave上去select
【 在 meffee (走很远的路是为了休息我的心灵) 的大作中提到: 】
: mysql无论何种数据引擎,有可能做到select语句不锁定表吗?
: 需求是日志表需要做实时分析,同时又会有不停的业务库表的
: 更新复制过来,希望select最新的日志记录,同时对复制影响
: ...................
&& -- && ※ 来源:·水木社区 ·[FROM: 61.135.172.*]
走很远的路是为了休息我的心灵发信人: meffee (走很远的路是为了休息我的心灵), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 15:06:13 2012), 站内 && 其实这个日志库已经是slave了,业务库实时复制过来的 && 【 在 cugbcat (邦卡猫) 的大作中提到: 】
: 到slave上去select
品尝过小茜的食物后... && 玄马(-_-b)&& :“乱马,咱们继续修行吧!”
乱马(-_-bb)&&:“是!”
小茜(-_-bbb) :“... ...” &&&& ※ 来源:·水木社区 newsmth.net·[FROM: 219.234.141.*]
我的月份又来了发信人: JulyClyde (我的月份过去了), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 16:07:50 2012), 站内 && 没事,加内存
【 在 Knightmare (梦醒时分) 的大作中提到: 】
: 换innoDB可以解决你这个问题
: 不过查询速度会下降接近10倍左右。
浅谈“开发背景”&&&&&&&&&&&&&&&&&&&&&&&&
优秀Linux发行版应该具备的基本素质&&&&&&&& &&&& ※ 来源:·水木社区 newsmth.net·[FROM: 119.253.36.*]
奥路菲发信人: Orpherus (奥路菲), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 20:21:07 2012), 站内 && oracle大骗子 官方测试成绩inneodb比myisam还强 && 【 在 Knightmare (梦醒时分) 的大作中提到: 】
: 换innoDB可以解决你这个问题
: 不过查询速度会下降接近10倍左右。
&&&& -- && ※ 来源:·水木社区 newsmth.net·[FROM: 180.155.239.*]
邦卡猫发信人: cugbcat (邦卡猫), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Thu Apr 12 20:45:54 2012), 站内 && 那还怕啥?slave上写入慢不会影响master的写入速度啊。。
【 在 meffee (走很远的路是为了休息我的心灵) 的大作中提到: 】
: 其实这个日志库已经是slave了,业务库实时复制过来的
&& -- && ※ 来源:·水木社区 ·[FROM: 61.135.172.*]
我的月份又来了发信人: JulyClyde (我的月份过去了), 信区: Database
标&&题: Re: mysql数据表有可能select不锁定表吗?
发信站: 水木社区 (Fri Apr 13 12:27:49 2012), 站内 && 多加点内存就差不多了
【 在 Orpherus (奥路菲) 的大作中提到: 】
: oracle大骗子 官方测试成绩inneodb比myisam还强
&&&& -- &&&& ╱╲&&&&&&&&&&&&&&&&&&&&█ 冷咖啡离开了杯垫&&&&&&&&&&&&&&&&&&&&&&&& && ◣ &&&& ╰╯&&&&&&&&&&&&&&&&&&&&█ 我忍住的情绪在很后面&&&&&&&&&&&&&&&&&&&& &&&&
&&&&&&&&&&&&&&ξ&&&&&&&&&&&& █ 拼命想挽回的从前&&&&&&&&&&&&&&&&&&&&&&&& &&&&
&&&&&&&&&&&&&&█D&&&&&&&&&&&&█ 在我脸上依旧清晰可见&&&&&&&&&&&&&&&&&&&& &&&&
&&&&┳━━━━━┳&&&&&&&& ●█&&&&&&&&&&&&&&&&——周杰伦《不能说的秘密》&&&&
&&&&┃&&&&&&&&&&┃&&&&&& ︵■█&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
&&&& ※ 来源:·水木社区 newsmth.net·[FROM: 119.253.36.*]
文章数:28&分页:29628人阅读
一、我的处理过程
1、查进程,主要是查找被锁表的那个进程的ID
SHOW PROCESSLIST;
2、kill掉锁表的进程ID
KILL & 10866;//后面的数字即时进程的ID
网上找了些资料,了解了一下,先分享一下:
二、mysql的锁表问题
SHOW PROCESSLIST查看数据库中表的状态,是否被锁;
kill id & //杀掉被锁的表
===================================================
set autocommit=0;
select * from t1 &where uid=’xxxx’ for update & &//在有索引(例如uid)的情况下是行锁,否则是表锁
insert into t1 values(1,’xxxxx’);
=====================================================
lock tables t1 write|
insert into t1 values(2,’xxxxx’); //只有insert
2 《轻松掌握MySQL数据库锁机制的相关原理》
MySQL 5.1支持对MyISAM和MEMORY表进行表级锁定,对BDB表进行页级锁定,对InnoDB 表进行行级锁定。在许多情况下,可以根据培训猜测应用程序使用哪类锁定类型最好,但一般很难说出某个给出的锁类型就比另一个好。一切取决于应用程序,应用程序的不同部分可能需要不同的锁类型。为了确定是否想要使用行级锁定的存储引擎,应看看应用程序做什么并且混合使用什么样的选择和更新语句。例如,大多数Web应用程序执行许多选择,而很少进行删除,只对关键字的值进行更新,并且只插入少量具体的表。基本MySQL MyISAM设置已经调节得很好。
在MySQL中对于使用表级锁定的存储引擎,表锁定时不会死锁的。这通过总是在一个查询开始时立即请求所有必要的锁定并且总是以同样的顺序锁定表来管理。
对WRITE,MySQL使用的表锁定方法原理如下:
◆ 如果在表上没有锁,在它上面放一个写锁。
◆否则,把锁定请求放在写锁定队列中。
对READ,MySQL使用的锁定方法原理如下:
◆如果在表上没有写锁定,把一个读锁定放在它上面。
◆否则,把锁请求放在读锁定队列中。
当一个锁定被释放时,锁定可被写锁定队列中的线程得到,然后是读锁定队列中的线程。
这意味着,如果你在一个表上有许多更新,SELECT语句将等待直到没有更多的更新。
如果INSERT 语句不冲突,可以自由为MyISAM 表混合并行的INSERT 和SELECT 语句而不需要锁定。
InnoDB 使用行锁定,BDB 使用页锁定。对于这两种存储引擎,都可能存在死锁。这是因为,在SQL语句处理期间,InnoDB 自动获得行锁定,BDB 获得页锁定,而不是在事务启动时获得。
行级锁定的优点:
· 当在许多线程中访问不同的行时只存在少量锁定冲突。
· 回滚时只有少量的更改。
· 可以长时间锁定单一的行。
行级锁定的缺点:
· 比页级或表级锁定占用更多的内存。
· 当在表的大部分中使用时,比页级或表级锁定速度慢,因为你必须获取更多的锁。
· 如果你在大部分数据上经常进行 GROUP BY 操作或者必须经常扫描整个表,比其它锁定明显慢很多。
· 用高级别锁定,通过支持不同的类型锁定,你也可以很容易地调节应用程序,因为其锁成本小于行级锁定。
在以下情况下,表锁定优先于页级或行级锁定:
· 表的大部分语句用于读取。
· 对严格的关键字进行读取和更新,你可以更新或删除可以用单一的读取的关键字来提取的一行:
o UPDATE tbl_name SET column = value WHERE unique_key_col = key_
o DELETE FROM tbl_name WHERE unique_key_col = key_
· SELECT 结合并行的INSERT 语句,并且只有很少的UPDATE或 DELETE 语句。
· 在整个表上有许多扫描或 GROUP BY 操作,没有任何写操作。
不同于行级或页级锁定的选项:
· 版本(例如,为并行的插入在MySQL中使用的技术),其中可以一个写操作,同时有许多读取操作。这明数据库或表支持数据依赖的不同视图,取决于访问何时开始。其它共同的术语是“时间跟踪”、“写复制”或者“按需复制”。
· 按需复制在许多情况下优先于页级或行级锁定。然而,在最坏的情况下,它可能比使用常规锁定使用多的内存。
· 除了行级锁定外,你可以使用应用程序级锁定,例如在MySQL中使用GET_LOCK()和RELEASE_LOCK()。这些是建议性锁定,它们只能在运行良好的应用程序中工作。
为达到最高锁定速度,除InnoDB 和BDB 之外,对所有存储引擎,MySQL使用表锁定(而不是页、行或者列锁定)。对于InnoDB 和BDB 表,如果你用LOCK TABLES显式锁定表,MySQL只使用表锁定;如果你不使用LOCK TABLES,因为 InnoDB 使用自动行级锁定而BDB 使用页级锁定来保证事务隔离。
但是对于大表,对于大多数应用程序,表锁定比行锁定更好,但存在部分缺陷。表锁定使许多线程同时从一个表中进行读取操作,但如果一个线程想要对表进行写操作,它必须首先获得独占访问。更新期间,所有其它想要访问该表的线程必须等待直到更新完成。
表更新通常情况认为比表检索更重要,因此给予它们更高的优先级。这应确保更新一个表的活动不能“饿死”,即使该表上有很繁重的SELECT 活动。
表锁定在这种情况下会造成问题,例如当线程正等待,因为硬盘已满并且在线程可以处理之前必须有空闲空间。在这种情况下,所有想要访问出现问题的表的线程也被设置成等待状态,直到有更多的硬盘空间可用。
表锁定在下面的情况下也存在问题:
· 一个客户发出长时间运行的查询。
· 然后,另一个客户对同一个表进行更新。该客户必须等待直到SELECT完成。
· 另一个客户对同一个表上发出了另一个 SELECT 语句。因为UPDATE比 SELECT 优先级高,该SELECT 语句等待UPDATE完成,并且等待第1个 SELECT 完成。
下面描述了一些方法来避免或减少表锁定造成的竞争:
· 试图使 SELECT 语句运行得更快。可能必须创建一些摘要(summary)表做到这点。
· 用–low-priority-updates启动mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的第2个SELECT语句将在UPDATE语句前执行,而不需要等候第1个 SELECT 完成。
· 可以使用SET_UPDATES=1语句指定具体连接中的所有更新应使用低优先级。
· 可以用LOW_PRIORITY属性给与一个特定的INSERT、UPDATE或DELETE语句较低优先级。
· 可以用HIGH_PRIORITY属性给与一个特定的SELECT语句较高优先级。
· 为max_write_lock_count系统变量指定一个低值来启动mysqld来强制MySQL在具体数量的插入完成后临时提高所有等待一个表的SELECT 语句的优先级。这样允许在一定数量的WRITE锁定后给出READ锁定。
· 如果你有关于INSERT结合SELECT的问题,切换到使用新的MyISAM表,因为它们支持并发的SELECT和INSERT。
· 如果你对同一个表混合插入和删除,INSERT DELAYED将会有很大的帮助。
· 如果你对同一个表混合使用 SELECT 和DELETE 语句出现问题,DELETE 的LIMIT 选项可以有所帮助。
· 对 SELECT 语句使用SQL_BUFFER_RESULT可以帮助使表锁定时间变短。
· 可以更改mysys/thr_lock.c中的锁代码以使用单一的队列。在这种情况下,写锁定和读锁定将具有相同的优先级,对一些应用程序会有帮助。
这里是一些MySQL中表锁定相关的技巧:
· 如果不混合更新与需要在同一个表中检查许多行的选择,可以进行并行操作。
· 可以使用 LOCK TABLES 来提高速度,因为在一个锁定中进行许多更新比没有锁定的更新要快得多。将表中的内容切分为几个表也可以有所帮助。
· 如果在MySQL中表锁定时遇到速度问题,可以将表转换为 InnoDB 或BDB 表来提高性能
你对人生迷茫吗? 那就背起行囊,起步远行吧
本篇转自:/daxian2012/archive//mysql.html
三、锁表的机制
为了给高并发情况下的mysql进行更好的优化,有必要了解一下mysql查询更新时的锁表机制。
MySQL有三种锁的级别:页级、表级、行级。
MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level
locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。
MySQL这3种锁的特性可大致归纳如下:
表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。
行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。
二、MyISAM表锁
MyISAM存储引擎只支持表锁,是现在用得最多的存储引擎。
1、查询表级锁争用情况
可以通过检查table_locks_waited和table_locks_immediate状态变量来分析系统上的表锁定争夺:
mysql& show status like ‘table%’;
+———————–+———-+
| Variable_name | Value |
+———————–+———-+
| Table_locks_immediate |
| Table_locks_waited | 305089 |
+———————–+———-+
2 rows in set (0.00 sec)Table_locks_waited的值比较高,说明存在着较严重的表级锁争用情况。
2、MySQL表级锁的锁模式
MySQL的表级锁有两种模式:表共享读锁(Table Read Lock)和表独占写锁(Table Write
Lock)。MyISAM在执行查询语句(SELECT)前,会自动给涉及的所有表加读锁,在执行更新操作(UPDATE、DELETE、INSERT等)前,会自动给涉及的表加写锁。
所以对MyISAM表进行操作,会有以下情况:
a、对MyISAM表的读操作(加读锁),不会阻塞其他进程对同一表的读请求,但会阻塞对同一表的写请求。只有当读锁释放后,才会执行其它进程的写操作。
b、对MyISAM表的写操作(加写锁),会阻塞其他进程对同一表的读和写操作,只有当写锁释放后,才会执行其它进程的读写操作。
下面通过例子来进行验证以上观点。数据表gz_phone里有二百多万数据,字段id,phone,ua,day。现在同时用多个客户端同时对该表进行操作分析。
a、当我用客户端1进行一个比较长时间的读操作时,分别用客户端2进行读和写操作:
mysql&select count(*) from gz_
75508 rows in set (3 min 15.87 sec) client2:
select id,phone from gz_phone limit 1000,10;
+——+——-+
| id | phone |
+——+——-+
| 1001 | 2222 |
| 1002 | 2222 |
| 1003 | 2222 |
| 1004 | 2222 |
| 1005 | 2222 |
| 1006 | 2222 |
| 1007 | 2222 |
| 1008 | 2222 |
| 1009 | 2222 |
| 1010 | 2222 |
+——+——-+
10 rows in set (0.01 sec)
mysql& update gz_phone set phone=’′where id=1001;
Query OK, 0 rows affected (2 min 57.88 sec)
Rows matched: 1 Changed: 0 Warnings: 0
说明当数据表有一个读锁时,其它进程的查询操作可以马上执行,但更新操作需等待读锁释放后才会执行。
b、当用客户端1进行一个较长时间的更新操作时,用客户端2,3分别进行读写操作:
mysql& update gz_phone set phone=’′;
Query OK, 1671823 rows affected (3 min 4.03 sec)
Rows matched: 2212070 Changed: 1671823 Warnings: 0 client2:
mysql& select id,phone,ua,day from gz_phone limit 10;
+—-+——-+——————-+————+
| id | phone | ua | day |
+—-+——-+——————-+————+
| 1 | 2222 | SonyEricssonK310c |
| 2 | 2222 | SonyEricssonK750c |
| 3 | 2222 | MAUI WAP Browser |
| 4 | 2222 | Nokia3108 |
| 5 | 2222 | LENOVO-I750 |
| 6 | 2222 | BIRD_D636 |
| 7 | 2222 | SonyEricssonS500c |
| 8 | 2222 | SAMSUNG-SGH-E258 |
| 9 | 2222 | NokiaN73-1 |
| 10 | 2222 | Nokia2610 |
+—-+——-+——————-+————+
10 rows in set (2 min 58.56 sec) client3:
mysql& update gz_phone set phone=’55555′where id=1;
Query OK, 1 row affected (3 min 50.16 sec)
Rows matched: 1 Changed: 1 Warnings: 0
说明当数据表有一个写锁时,其它进程的读写操作都需等待读锁释放后才会执行。
3、并发插入
原则上数据表有一个读锁时,其它进程无法对此表进行更新操作,但在一定条件下,MyISAM表也支持查询和插入操作的并发进行。
MyISAM存储引擎有一个系统变量concurrent_insert,专门用以控制其并发插入的行为,其值分别可以为0、1或2。
a、当concurrent_insert设置为0时,不允许并发插入。
b、当concurrent_insert设置为1时,如果MyISAM表中没有空洞(即表的中间没有被删除的行),MyISAM允许在一个进程读表的同时,另一个进程从表尾插入记录。这也是MySQL的默认设置。
c、当concurrent_insert设置为2时,无论MyISAM表中有没有空洞,都允许在表尾并发插入记录。
4、MyISAM的锁调度
由于MySQL认为写请求一般比读请求要重要,所以如果有读写请求同时进行的话,MYSQL将会优先执行写操作。这样MyISAM表在进行大量的更新操作时(特别是更新的字段中存在索引的情况下),会造成查询操作很难获得读锁,从而导致查询阻塞。
我们可以通过一些设置来调节MyISAM的调度行为:
a、通过指定启动参数low-priority-updates,使MyISAM引擎默认给予读请求以优先的权利。
b、通过执行命令SET LOW_PRIORITY_UPDATES=1,使该连接发出的更新请求优先级降低。
c、通过指定INSERT、UPDATE、DELETE语句的LOW_PRIORITY属性,降低该语句的优先级。
上面3种方法都是要么更新优先,要么查询优先的方法。这里要说明的就是,不要盲目的给mysql设置为读优先,因为一些需要长时间运行的查询操作,也会使写进程“饿死”。只有根据你的实际情况,来决定设置哪种操作优先。这些方法还是没有从根本上同时解决查询和更新的问题。
在一个有大数据量高并发表的mysql里,我们还可采用另一种策略来进行优化,那就是通过mysql主从(读写)分离来实现负载均衡,这样可避免优先哪一种操作从而可能导致另一种操作的堵塞。下面将用一个篇幅来说明mysql的读写分离技术
本篇转自:/database/824.html
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:120432次
积分:1527
积分:1527
排名:千里之外
原创:72篇
转载:35篇
(2)(1)(1)(2)(1)(2)(3)(2)(4)(4)(3)(3)(1)(1)(5)(8)(3)(3)(30)(27)(2)

我要回帖

更多关于 mysql 查看表锁定状态 的文章

 

随机推荐