超越MySQL:三个流行MySQL分支的对比(摘录)

Posted on

超越MySQL:三个流行MySQL分支的对比(摘录) - Speeddsy的专栏 - 博客频道 - CSDN.NET

您还未登录!|登录|注册|帮助

Speeddsy的专栏

我的博客我说行!

超越MySQL:三个流行MySQL分支的对比(摘录)

分类: 数据库 2012-06-16 16:32 178人阅读 评论(0) 收藏 举报 mysql引擎产品server存储扩展

三个流行MySQL分支:Drizzle、MariaDB和Percona Server(包括XtraDB引擎)

XtraDB

XtraDB是一款独立的产品,但它仍被认为是MySQL的一个分支。XtraDB实际上是基于MySQL的数据库的一个存储引擎。XtraDB被认为是已成为MySQL一部分的标准MyISAM和InnoDB的一个额外存储引擎。

XtraDB分支有另一个目标,即成为InnoDB存储引擎的简单替代,这样用户就可以轻松地切换其存储引擎,无需更改任何现有的应用程序代码。XtraDB必须能够向后兼容InnoDB,以提供它们想要添加的所有新功能和改进。它们实现了此目标。

XtraDB的速度有多快?我找到的一个性能测试表明:与内置的MySQL 5.1 InnoDB 引擎相比,它每分钟可处理2.7倍的事务。(请参见参考资料)。速度显然是一个不可以忽略的因素,在考虑替代产品时更是如此。

Percona

与内置的MySQL存储引擎相比,XtraDB提供了一些极大的改进,但它不是一款独立产品,也无法轻松放入现有MySQL安装。因此,如果您想使用这款新引擎,则必须使用提供它的产品。采用Percona Server的一个很好的理由是,利用XtraDB引擎来尽可能地减少代码更改。

下面是Percona Server的声明,该声明来自它们自己的网站:

  • 可扩展性:处理更多事务;在强大的服务器上进行扩展
  • 性能:使用了XtraDB的Percona Server速度非常快
  • 可靠性:避免损坏,提供崩溃安全(crash-safe)复制
  • 管理:在线备份,在线表格导入/导出
  • 诊断:高级分析和检测
  • 灵活性:可变的页面大小,改进的缓冲池管理

Percona Server的一个缺点是他们自己管理代码,不接受外部开发人员的贡献,以这种方式确保他们对产品中所包含功能的控制。

MariaDB

另一款提供了XtraDB存储引擎的产品是MariaDB产品。它与Percona产品非常类似,但是提供了更多底层代码更改,试图提供比标准MySQL更多的性能改进

MariaDB提供了MySQL提供的标准存储引擎,即MyISAM和InnoDB。因此,实际上,可以将它视为MySQL的扩展集,它不仅提供MySQL提供的所有功能,还提供其他功能。MariaDB还声称自己是MySQL的替代,因此从MySQL切换到MariaDB时,无需更改任何基本代码即可安装它。

Drizzle

本文介绍的最后一款产品是Drizzle。与之前介绍的两款产品不同,Drizzle与MySQL有很大差别,甚至声称它们不是MySQL的替代产品。他们期望对MySQL进行一些重大更改,想要提供一种出色的解决方案来解决高可用性问题,即使这意味着要更改我们已经习惯了的MySQL的各个方面。

是不是所有人都应该使用Drizzle呢?等等,正如Drizzle反复指出的那样,它与MySQL不兼容。因此,如果您现在使用的是MySQL平台,那么需要重写大量代码,才能使Drizzle在您的环境中正常工作

尽管需要额外的工作才能让它运行,但它并不像Percona或MariaDB那样快速且易于使用。我之所以介绍Drizzle,是因为尽管目前它可能不是您的选择,但几年之后,它很可能会成为一些人的选择。因为本文的目标是提高您对未来使用的工具的认识,所以这是向您介绍此产品的好机会。许多领先的DB专家相信Drizzle将成为未来5年内高可用性数据库安装的选择。 分享到:

/* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场 TOP

个人资料

Speeddsy

  • 访问:2619次
  • 积分:58分
  • 排名:千里之外

  • 原创:1篇

  • 转载:13篇
  • 译文:0篇
  • 评论:2条

文章分类

文章搜索

阅读排行

评论排行

最新评论

随便啦: 请问这篇文章怎么转载啊。。。

greateryang: 好用,此文章推荐寻找此方法的同志都看看

公司简介|招贤纳士|广告服务|银行汇款帐号|联系方式|版权声明|法律顾问|问题报告京 ICP 证 070598 号北京创新乐知信息技术有限公司 版权所有世纪乐知(北京)网络技术有限公司 提供技术支持江苏乐知网络技术有限公司 提供商务支持 联系邮箱:webmaster(at)csdn.netCopyright © 1999-2012, CSDN.NET, All Rights Reserved GongshangLogo

MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码

Posted on

MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码 - Love in coding_ - 博客园

Love in coding...

Free and Susan

MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码

0.安装MySQL服务

1.[不同端口登录]

通过开始菜单-> 程序-> MySQL-> MySQL Command Line Client 通过输入密码Enter password://////进行登录 该MySQL服务端口已定

或者

通过运行命令->C:\Program Files\MySQL\MySQL Server 5.2\bin> 然后利用mysql进行登录 C:\Program Files\MySQL\MySQL Server 5.2\bin>mysql -uroot -h127.0.0.1 -P3307 -p Enter password:////// 亦可选择登录远程MySQL

2.[执行SQL文件]

创建测试数据库及数据表 mysql> source c:/test/test.sql;

test.sql文件内容: create database IF NOT EXISTS testdb;

use testdb;

create table testtable (testName varchar(10));

3.[创建用户]

mysql> create user testuser identified by 'testpass';

4.[赋予权限]

mysql> grant all privileges on testdb./* to 'testuser'@'%' identified by 'testpass';

5.修改root密码

如果已登录 1)use mysql 2)update user set password=password('你的密码') where user='root'; 3)flush privileges;

如果没登录,你想进数据库而没有密码

先关掉服务 然后以safe模式进入 mysqld_safe --skip-grant-tables & 这个窗口不要关,这样进数据库就不用密码,进去后 做 “如果已登录”的 步骤 0

0 0

(请您对文章做出评价)

«上一篇:婚姻 一辈子的幸福厮守 请不要多拿彩礼和父母说事 »下一篇:[书目20090805]钻石成功法则 - 陈安之

posted on 2009-07-25 18:02 freeliver54 阅读(406) 评论(0) 编辑 收藏 网摘 所属分类: Oracle/MySQL

注册用户登录后才能发表评论,请登录注册

网站导航: 博客园首页 IT新闻 个人主页 闪存 程序员招聘 社区 博问 网摘 IT新闻: · 豆瓣网推出手机版 提供书影音资讯搜索服 · 美国将推3D频道 6月直播世界杯 · 用iPhone遥控无人直升机 · IT职业仍然是美国最好的工作之一 · 马化腾:“全民公敌”偶像

China-pub 计算机图书网上专卖店!6.5万品种2-8折! China-Pub 计算机绝版图书按需印刷服务 链接:切换模板

相关搜索: Oracle/MySQL 在知识库中查看: MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码

Powered by: 博客园 Copyright © freeliver54

导航

统计

  • 随笔 - 714
  • 文章 - 0
  • 评论 - 1245
  • 引用 - 157

公告

每一天都有新的开始 每一天都是新的开始 愿我们 善始善终 持之以恒 不管前方 是希望还是迷茫 我们都只有一个信念 让我们的爱 伴我们终生

我的主页 个人资料 我的闪存 发短消息

搜索

随笔分类

随笔档案

友情链接

积分与排名

  • 积分 - 584146
  • 排名 - 57

最新评论

阅读排行榜

评论排行榜

60天内阅读排行

*

MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码

Posted on

MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码

Love in coding...

Free and Susan

MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码

0.安装MySQL服务

1.[不同端口登录]

通过开始菜单-> 程序-> MySQL-> MySQL Command Line Client 通过输入密码Enter password://////进行登录 该MySQL服务端口已定

或者

通过运行命令->C:\Program Files\MySQL\MySQL Server 5.2\bin> 然后利用mysql进行登录 C:\Program Files\MySQL\MySQL Server 5.2\bin>mysql -uroot -h127.0.0.1 -P3307 -p Enter password:////// 亦可选择登录远程MySQL

2.[执行SQL文件]

创建测试数据库及数据表 mysql> source c:/test/test.sql;

test.sql文件内容: create database IF NOT EXISTS testdb;

use testdb;

create table testtable (testName varchar(10));

3.[创建用户]

mysql> create user testuser identified by 'testpass';

4.[赋予权限]

mysql> grant all privileges on testdb./* to 'testuser'@'%' identified by 'testpass';

5.修改root密码

如果已登录 1)use mysql 2)update user set password=password('你的密码') where user='root'; 3)flush privileges;

如果没登录,你想进数据库而没有密码

先关掉服务 然后以safe模式进入 mysqld_safe --skip-grant-tables & 这个窗口不要关,这样进数据库就不用密码,进去后 做 “如果已登录”的 步骤 0

0 0

(请您对文章做出评价)

«上一篇:婚姻 一辈子的幸福厮守 请不要多拿彩礼和父母说事 »下一篇:[书目20090805]钻石成功法则 - 陈安之

posted on 2009-07-25 18:02 freeliver54 阅读(407) 评论(0) 编辑 收藏 网摘 所属分类: Oracle/MySQL

注册用户登录后才能发表评论,请登录注册

网站导航: 博客园首页 IT新闻 个人主页 闪存 程序员招聘 社区 博问 网摘 IT新闻: · 盛大文学的下一步 · 豆瓣网推出手机版 提供书影音资讯搜索服 · 美国将推3D频道 6月直播世界杯 · 用iPhone遥控无人直升机 · IT职业仍然是美国最好的工作之一

China-pub 计算机图书网上专卖店!6.5万品种2-8折! China-Pub 计算机绝版图书按需印刷服务 链接:切换模板

相关搜索: Oracle/MySQL 在知识库中查看: MySQL命令行 不同端口登录 执行SQL文件 创建用户 赋予权限 修改root密码

Powered by: 博客园 Copyright © freeliver54

导航

统计

  • 随笔 - 714
  • 文章 - 0
  • 评论 - 1245
  • 引用 - 157

公告

每一天都有新的开始 每一天都是新的开始 愿我们 善始善终 持之以恒 不管前方 是希望还是迷茫 我们都只有一个信念 让我们的爱 伴我们终生

我的主页 个人资料 我的闪存 发短消息

搜索

随笔分类

随笔档案

友情链接

积分与排名

  • 积分 - 584146
  • 排名 - 57

最新评论

阅读排行榜

评论排行榜

60天内阅读排行

*

MySQL报错:The MySQL server is running with the

Posted on

MySQL报错:The MySQL server is running with the --skip-grant-tables option so it cannot execute this

_安静

MySQL报错:The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

解决办法:

mysql> set global read_only=0; (关掉新主库的只读属性)

flush privileges;

set global read_only=1;(读写属相)

flush privileges;

Cannot execute statement: impossible to write to binary log since BINLOG_FORMAT = STATEMENT and at least one table uses a storage engine limited to row-based logging. InnoDB is limited to row-logging when transaction isolation level is READ COMMITTED or READ UNCOMMITTED.

mysql> SET SESSION binlog_format = 'ROW'; mysql> SET GLOBAL binlog_format = 'ROW';

MYSQL5.1复制参数binlogformat

MySQL 5.1 中,在复制方面的改进即便引进了新的复制技巧:基于行的复制。简言之,这种新技巧即便关怀表中发生改变的登记,而非过去的照抄 binlog 形式。从 MySQL 5.1.12 开始,能够用以下三种形式来告终:基于SQL语句的复制(statement-based replication, SBR),基于行的复制(row-based replication, RBR),混杂形式复制(mixed-based replication, MBR)。相应地,binlog的款式也有三种:STATEMENT,ROW,MIXED。MBR 形式中,SBR 形式是默认的。 在运行时能够动态低改换binlog的款式,除非以下几种情形:

  1. 存储过程可能引发器其中
  2. 启用了NDB
  3. 目前会话试用 RBR 形式,并且已敞开了临时表 万一binlog批准了 MIXED 形式,那么在以下几种情形下会积极将binlog的形式由 SBR 形式改成 RBR 形式。
  4. 当DML语句更新一个NDB表时
  5. 当函数中包括 UUID() 时
  6. 2个及以上包括 AUTO_INCREMENT 字段的表被更新时
  7. 行任何 INSERT DELAYED 语句时
  8. 用 UDF 时
  9. 视图中定然要求利用 RBR 时,例如创立视图是利用了 UUID() 函数 设定主从复制形式的措施极其容易,凡是在过去设定复制搭配的基础上,再加一个参数: binlog_format="STATEMENT" /#binlog_format="ROW" /#binlog_format="MIXED" 当然了,也能够在运行时动态修正binlog的款式。例如 mysql> SET SESSION binlog_format = 'STATEMENT'; mysql> SET SESSION binlog_format = 'ROW'; mysql> SET SESSION binlog_format = 'MIXED'; mysql> SET GLOBAL binlog_format = 'STATEMENT'; mysql> SET GLOBAL binlog_format = 'ROW'; mysql> SET GLOBAL binlog_format = 'MIXED'; 目前来比拟以下 SBR 和 RBR 2中形式各自的优缺点 SBR 的优点:
  10. 历史悠久,技巧成熟
  11. binlog文件较小
  12. binlog中包括了所有数据库改动消息,能够据此来核实数据库的平安等情形
  13. binlog能够用于实时的还原,而不但仅用于复制
  14. 主从版本能够不一样,从服务器版本能够比主服务器版本高 SBR 的缺点:
  15. 不是所有的UPDATE语句都能被复制,尤其是包括不确定垄断的时候。
  16. 调用具有不确定因素的 UDF 时复制也可能出问题
  17. 利用以下函数的语句也无法被复制: / LOAD_FILE() / UUID() / USER() / FOUND_ROWS() /* SYSDATE() (除非启用时启用了 --sysdate-is-now 选项)
  18. INSERT ... SELECT 会发生比 RBR 更多的行级锁
  19. 复制必需举行全表扫描(WHERE 语句中没利于用到索引)的 UPDATE 时,必需比 RBR 哀求更多的行级锁
  20. 对于有 AUTO_INCREMENT 字段的 InnoDB表而言,INSERT 语句会阻塞其他 INSERT 语句
  21. 对于一些混杂的语句,在从服务器上的耗资源情形会更严重,而 RBR 形式下,只会对那个发生改变的登记发生波及
  22. 存储函数(不是存储过程)在被调用的同时也会厉行顺次 NOW() 函数,这个能够说是坏事也可能是好事
  23. 确定了的 UDF 也必需在从服务器上厉行
  24. 数据表定然几乎和主服务器坚持统一才行,否则可能会导致复制出错
  25. 厉行混杂语句万一出错的话,会花费更多资源 RBR 的优点:
  26. 任何情形都能够被复制,这对复制来说是最平安可靠的
  27. 和其他大多数数据库系统的复制技巧一样
  28. 多数情形下,从服务器上的表万一有主键的话,复制就会快了许多
  29. 复制以下几种语句时的行锁更少: / INSERT ... SELECT / 包括 AUTO_INCREMENT 字段的 INSERT /* 未曾附带条件可能并未曾修正许多登记的 UPDATE 或 DELETE 语句
  30. 厉行 INSERT,UPDATE,DELETE 语句时锁更少
  31. 从服务器上批准多线程来厉行复制成为可能 RBR 的缺点:
  32. binlog 大了许多
  33. 混杂的回滚时 binlog 中会包括许多的数据
  34. 主服务器上厉行 UPDATE 语句时,所有发生改变的登记都会写到 binlog 中,而 SBR 只会写顺次,这会导致频繁发生 binlog 的并发写问题
  35. UDF 发生的大 BLOB 值会导致复制变慢
  36. 无法从 binlog 中看到都复制了写什么语句
  37. 当在非事务表上厉行一段堆积的SQL语句时,良好批准 SBR 形式,否则很轻率导致主从服务器的数据不统一情形发生 另外,针对系统库 mysql 里面的表发生改变时的处理法定如下:
  38. 万一是批准 INSERT,UPDATE,DELETE 直接垄断表的情形,则日志款式依据 binlog_format 的设定而登记
  39. 万一是批准 GRANT,REVOKE,SET PASSWORD 等管教语句来做的话,那么无论如何都批准 SBR 形式登记 注:批准 RBR 形式后,能处理许多本来揭示的主键重复问题例如Pro Publica,SunlightFoundation和维基解密,开始添补鞭策媒体滑坡留下的空白。

MYSQL5.5MySQL 5.5 中对于二进制日志 (binlog) 有 3 种不同的格式可选:Mixed,Statement,Row,默认格式是 Statement。总结一下这三种格式日志的优缺点。

MySQL Replication 复制可以是基于一条语句 (Statement Level) ,也可以是基于一条记录 (Row Level),可以在 MySQL 的配置参数中设定这个复制级别,不同复制级别的设置会影响到 Master 端的 bin-log 日志格式。

1. Row 日志中会记录成每一行数据被修改的形式,然后在 slave 端再对相同的数据进行修改。

优点: 在 row 模式下,bin-log 中可以不记录执行的 SQL 语句的上下文相关的信息,仅仅只需要记录那一条记录被修改了,修改成什么样了。所以 row 的日志内容会非常清楚的记录下每一行数据修改的细节,非常容易理解。而且不会出现某些特定情况下的存储过程或 function ,以及 trigger 的调用和触发无法被正确复制的问题。

缺点:在 row 模式下,所有的执行的语句当记录到日志中的时候,都将以每行记录的修改来记录,这样可能会产生大量的日志内容,比如有这样一条 update 语句: 1 UPDATE product SET owner_member_id = 'b' WHERE owner_member_id = 'a'

执 行之后,日志中记录的不是这条 update 语句所对应的事件 (MySQL 以事件的形式来记录 bin-log 日志) ,而是这条语句所更新的每一条记录的变化情况,这样就记录成很多条记录被更新的很多个事件。自然,bin-log 日志的量就会很大。尤其是当执行 alter table 之类的语句的时候,产生的日志量是惊人的。因为 MySQL 对于 alter table 之类的表结构变更语句的处理方式是整个表的每一条记录都需要变动,实际上就是重建了整个表。那么该表的每一条记录都会被记录到日志中。

2. Statement 每一条会修改数据的 SQL 都会记录到 master 的 bin-log 中。slave 在复制的时候 SQL 进程会解析成和原来 master 端执行过的相同的 SQL 再次执行。

优点:在 statement 模式下,首先就是解决了 row 模式的缺点,不需要记录每一行数据的变化,减少了 bin-log 日志量,节省 I/O 以及存储资源,提高性能。因为他只需要记录在 master 上所执行的语句的细节,以及执行语句时候的上下文的信息。

缺点: 在 statement 模式下,由于他是记录的执行语句,所以,为了让这些语句在 slave 端也能正确执行,那么他还必须记录每条语句在执行的时候的一些相关信息,也就是上下文信息,以保证所有语句在 slave 端杯执行的时候能够得到和在 master 端执行时候相同的结果。另外就是,由于 MySQL 现在发展比较快,很多的新功能不断的加入,使 MySQL 的复制遇到了不小的挑战,自然复制的时候涉及到越复杂的内容,bug 也就越容易出现。在 statement 中,目前已经发现的就有不少情况会造成 MySQL 的复制出现问题,主要是修改数据的时候使用了某些特定的函数或者功能的时候会出现,比如:sleep() 函数在有些版本中就不能被正确复制,在存储过程中使用了 last_insert_id() 函数,可能会使 slave 和 master 上得到不一致的 id 等等。由于 row 是基于每一行来记录的变化,所以不会出现类似的问题。

3. Mixed 从 官方文档中看到,之前的 MySQL 一直都只有基于 statement 的复制模式,直到 5.1.5 版本的 MySQL 才开始支持 row 复制。从 5.0 开始,MySQL 的复制已经解决了大量老版本中出现的无法正确复制的问题。但是由于存储过程的出现,给 MySQL Replication 又带来了更大的新挑战。另外,看到官方文档说,从 5.1.8 版本开始,MySQL 提供了除 Statement 和 Row 之外的第三种复制模式:Mixed,实际上就是前两种模式的结合。在 Mixed 模式下,MySQL 会根据执行的每一条具体的 SQL 语句来区分对待记录的日志形式,也就是在 statement 和 row 之间选择一种。新版本中的 statment 还是和以前一样,仅仅记录执行的语句。而新版本的 MySQL 中对 row 模式也被做了优化,并不是所有的修改都会以 row 模式来记录,比如遇到表结构变更的时候就会以 statement 模式来记录,如果 SQL 语句确实就是 update 或者 delete 等修改数据的语句,那么还是会记录所有行的变更。

其他参考信息

除以下几种情况外,在运行时可以动态改变 binlog 的格式: . 存储流程或者触发器中间; . 启用了 NDB; . 当前会话使用 row 模式,并且已打开了临时表;

如果 binlog 采用了 Mixed 模式,那么在以下几种情况下会自动将 binlog 的模式由 statement 模式变为 row 模式: . 当 DML 语句更新一个 NDB 表时; . 当函数中包含 UUID() 时; . 2 个及以上包含 AUTO_INCREMENT 字段的表被更新时; . 执行 INSERT DELAYED 语句时; . 用 UDF 时; . 视图中必须要求运用 row 时,例如建立视图时使用了 UUID() 函数;

设定主从复制模式: 1 2 3 4 log-bin=mysql-bin /#binlog_format="STATEMENT" /#binlog_format="ROW" binlog_format="MIXED"

也可以在运行时动态修改 binlog 的格式。例如

1 2 3 4 5 6 mysql> SET SESSION binlog_format = 'STATEMENT'; mysql> SET SESSION binlog_format = 'ROW'; mysql> SET SESSION binlog_format = 'MIXED'; mysql> SET GLOBAL binlog_format = 'STATEMENT'; mysql> SET GLOBAL binlog_format = 'ROW'; mysql> SET GLOBAL binlog_format = 'MIXED';

两种模式的对比Statement 优点 历史悠久,技术成熟; 产生的 binlog 文件较小; binlog 中包含了所有数据库修改信息,可以据此来审核数据库的安全等情况; binlog 可以用于实时的还原,而不仅仅用于复制; 主从版本可以不一样,从服务器版本可以比主服务器版本高;

Statement 缺点: 不是所有的 UPDATE 语句都能被复制,尤其是包含不确定操作的时候; 调用具有不确定因素的 UDF 时复制也可能出现问题; 运用以下函数的语句也不能被复制: / LOAD_FILE() / UUID() / USER() / FOUND_ROWS() /* SYSDATE() (除非启动时启用了 –sysdate-is-now 选项) INSERT … SELECT 会产生比 RBR 更多的行级锁; 复制须要执行全表扫描 (WHERE 语句中没有运用到索引) 的 UPDATE 时,须要比 row 请求更多的行级锁; 对于有 AUTO_INCREMENT 字段的 InnoDB 表而言,INSERT 语句会阻塞其他 INSERT 语句; 对于一些复杂的语句,在从服务器上的耗资源情况会更严重,而 row 模式下,只会对那个发生变化的记录产生影响; 存储函数(不是存储流程 )在被调用的同时也会执行一次 NOW() 函数,这个可以说是坏事也可能是好事; 确定了的 UDF 也须要在从服务器上执行; 数据表必须几乎和主服务器保持一致才行,否则可能会导致复制出错; 执行复杂语句如果出错的话,会消耗更多资源;

Row 优点 任何情况都可以被复制,这对复制来说是最安全可靠的; 和其他大多数数据库系统的复制技能一样; 多数情况下,从服务器上的表如果有主键的话,复制就会快了很多; 复制以下几种语句时的行锁更少: / INSERT … SELECT / 包含 AUTO_INCREMENT 字段的 INSERT /* 没有附带条件或者并没有修改很多记录的 UPDATE 或 DELETE 语句 执行 INSERT,UPDATE,DELETE 语句时锁更少; 从服务器上采用多线程来执行复制成为可能;

Row 缺点 生成的 binlog 日志体积大了很多; 复杂的回滚时 binlog 中会包含大量的数据; 主服务器上执行 UPDATE 语句时,所有发生变化的记录都会写到 binlog 中,而 statement 只会写一次,这会导致频繁发生 binlog 的写并发请求; UDF 产生的大 BLOB 值会导致复制变慢; 不能从 binlog 中看到都复制了写什么语句(加密过的); 当在非事务表上执行一段堆积的 SQL 语句时,最好采用 statement 模式,否则很容易导致主从服务器的数据不一致情况发生; 另外,针对系统库 MySQL 里面的表发生变化时的处理准则如下: 如果是采用 INSERT,UPDATE,DELETE 直接操作表的情况,则日志格式根据 binlog_format 的设定而记录; 如果是采用 GRANT,REVOKE,SET PASSWORD 等管理语句来做的话,那么无论如何都要使用 statement 模式记录; 使用 statement 模式后,能处理很多原先出现的主键重复问题;

分类: mysql

绿色通道: 好文要顶 关注我 收藏该文与我联系 _安静 关注 - 5 粉丝 - 8

+加关注

0

0 (请您对文章做出评价)

« 上一篇:vs2005下配置OGRE » 下一篇:Cubic Spline三次样条曲线

posted on 2013-03-01 19:37 _安静 阅读(641) 评论(0) 编辑 收藏

刷新评论刷新页面返回顶部

注册用户登录后才能发表评论,请 登录注册访问网站首页。 博客园首页博问新闻闪存程序员招聘知识库

最新IT新闻: · 烧钱不断的Ubuntu——一个理想主义者的故事 · 配4100万像素摄像头 Hyetis Crossbow智能手表 · 金正恩都说好的朝鲜手机是国产山寨? · 3D视差效果:23张iOS 7壁纸免费下载 · 免费!广告屏蔽插件Adblock正式发布IE版 » 更多新闻...

最新知识库文章: · 我现在是这样编程的 · 如何做到 jQuery-free? · 如何成为一位优秀的创业CEO · 十年前的Java企业应用开发世界 · 专注做好一件事 » 更多知识库文章... 历史上的今天: 2012-03-01 Eclipse中web-inf和meta-inf文件夹的信息 2012-03-01 在Eclipse中创建WEB工程步骤

公告

昵称:_安静 园龄:1年8个月 粉丝:8 关注:5

+加关注

导航

统计

  • 随笔 - 63
  • 文章 - 0
  • 评论 - 2
  • 引用 - 0

    搜索

常用链接

我的标签

随笔分类(46)

随笔档案(63)

mysql下载

最新评论

阅读排行榜

评论排行榜

推荐排行榜

Powered by: 博客园 Copyright © _安静

MySQL 运维笔记(一)—— 终止高负载SQL

Posted on

MySQL 运维笔记(一)—— 终止高负载SQL

数据库表体积大了,负载高了,难免一个sql出去耗时延长。半个月前,一个凌晨定时任务跑了8小时,突然手足无措。最后找DBA协助,直接干掉了这个sql进程。 其实,这并不复杂。 首先,找出占用CPU时间过长的SQL Sql代码 复制代码 收藏代码

  1. show processlist;

show processlist;

假定最后一条sql处于Query状态,且Time时间过长,就锁定它的ID,直接干掉即可。

然后,杀死进程:

Sql代码 复制代码 收藏代码

  1. kill QUERY 4487855;

kill QUERY 4487855;

这就大功告成了!

参考

KILL [CONNECTION | QUERY] thread_id