- 博客(227)
- 资源 (25)
- 收藏
- 关注
转载 细看Innodb落盘过程
zhua1.概述前面很多大侠都分享过MySQL的InnoDB存储引擎将数据刷新的各种情况。我们这篇文章从InnoDB往下,看看数据从InnoDB的内存到真正写到存储设备的介质上到底有哪些缓冲在起作用。我们通过下图看一下相关的缓冲:从上图中,我们可以看到,数据InnoDB到磁盘需要经过1.InnoDB buffer pool,Redo log buffer。这个是In
2014-10-27 19:03:16 3084
转载 4k对齐
4K对齐什么是4K 对齐?首先先来了解一下什么是叫做“4K 对齐”。其实“4K对齐”相关联的是一个叫做“高级格式化”的分区技术。“高级格式化”是国际硬盘设备与材料协会为新型数据结构格式所采用的名称。这是主要鉴于随着时代发展,硬盘容量不断扩展,使得之前定义的每个扇区512字节不再是那么的合理,于是将每个扇区512字节改为每个扇区4096 字节,也就是现在常说的“4K扇区”。NTF
2014-08-14 09:48:22 1853
转载 SCSI协议和总线
I/O 技术实现在计算机和存储设备之间的数据交换。实现从CPU 到存储系统的I/O通路的一个中间就是SCSI(Small Computer System Interface). 一. I/O 通路 在计算机中,一个或多个CPU 处理在CPU缓存或主存储器(RAM:Random Access Memory)中的数据。 CPU缓存或主存储器是非常快的器件,但是断电就不能保
2014-08-08 10:54:42 2068
转载 HandlerSocket的优势和缺陷阐述
From:http://www.mysqlops.com/2011/10/20/handlersocket-adv.htmlHandlerSocket的优势和特点:1) 支持多种查询模式HandlerSocket目前支持索引查询(主键索引和非主键的普通索引均可),索引范围扫描,LIMIT子句,也即支持增加、删除、修改、查询完整功能,但还不支持无法使用任何索引
2013-08-12 11:20:21 764
转载 HandlerSocket的性能测试
From:http://www.mysqlops.com/2011/10/20/handlersocket-perf.htmlHandlerSocket Oprofile测试报告(MySQL通过SQL执行K/V查询的Oprofile信息)MySQL执行SQL语句,首先要经过SQL解析阶段,调用MYSQLparse() 和MYSQLlex() 进行语法和词法解析;然后进入查询
2013-08-12 11:18:32 869
转载 HandlerSocket的原理
From:http://www.mysqlops.com/2011/10/19/handlersocket-principle.htmlHandlerSocket的原理十月 19, 2011 by Eugene · 8 Comments HandlerSocket的应用场景:MySQL自身的局限性,很多站点都采用了MySQL+Memcached的经典架构,甚至一
2013-08-12 11:16:44 867
原创 mysql union all的一种优化方法
业务中遇到一个语句:类似:(SELECT * FROM xtable WHERE xx=100500137 ORDER BY xid asc limit 10)union all (SELECT * FROM xtable WHERE xx=104546692 ORDER BY xid asc imit 10)union all (SELECT * FROM xtabl
2013-08-09 11:45:58 12583
原创 PHP长连接导致mysql连接数打满
首先说一下问题:PHP使用mysql_pconnect连接到中间代理层,代理层再连接mysql,连接过程中出现代理层到mysql之间的连接持续增长;原因:当PHP发起一个连接到WebServer的时候,PHP的mysql模块会把当前的连接以key=》values的形式保存起来(进程号的MD5),当下次连接的时候就会比较当前进程的IDMD5值和连接池中的valuse对比,一旦匹配上那么就
2013-08-07 00:13:19 10000
原创 一个sql引起的丢表问题
背景:一个已经运行了一段时间的老系统线上存在这种业务逻辑:start transactiondrop tables if.... a_backup;drop tables if.... a_tmp;create table a_tmp ...like a;load .....into a_tmp;rename table a ..a_backup;rename
2013-07-15 22:39:09 912
原创 一个奇葩的sql导致拒绝更新
背景一个业务对外开放接口,开发人员可以调用入口掺入一些值给服务端;问题如题,系统中遇到一个sql UPDATE xxa SET column1='1' WHEREcolumn2='1'/**/or/**/sleep(10)/**/and/**/'1'='1';xxa中的表结构为自增主键ID,column 2上有唯一索引;这个语句的执行结果是什么呢?xxa表的记录
2013-07-15 22:28:27 886
原创 mongdb shard搭建遇到的问题总结
搭建的集群为两个replset 分片,3个configsrv,3个mongos:搭建set和configsrv都没遇到什么问题,在搭建mongos时就遇到一个问题,在网上找了很多资料都没有详细说明;具体错误如下:Mon Jul 8 22:14:35 ERROR: config servers xxx1:8100 and xxx2:8100 differconfig servers x
2013-07-09 09:18:53 1541 2
原创 mysql binlog奇异现象binlog truncated in the middle of event
现象说明:mysql5.1.45在做数据时,我重新将从库挂到主从中同步一段时间后出现如下现象 Connect_Retry: 60 Master_Log_File: mysql-bin.006727 Read_Master_Log_Pos: 1046964355 Relay_Lo
2013-07-03 10:42:32 4747
转载 mongodb 源码解析内存管理
MongoDB源码概述——内存管理和存储引擎数据存储: 之前在介绍Journal的时候有说到为什么MongoDB会先把数据放入内存,而不是直接持久化到数据库存储文件,这与MongoDB对数据库记录文件的存储管理操作有关。MongoDB采用操作系统底层提供的内存文件映射(MMap)的方式来实现对数据库记录文件的访问,MMAP可以把磁盘文件的全部内容直接映射到进程的内存空间,这样文件中的
2013-06-18 09:56:57 1175
原创 磁盘IO调度策略
简介IO调度是决定读或写请求执行的内核部分。 Linux内核有四个选择[noop] anticipatory deadline cfq ,但大多数发行版使用默认的“CFQ”(完全公平队列)调度,它自2.6.18版本后一直是Linux的默认情况下的调度策略。这通常是一个很好的全面调度,并应提供良好的性能,同时共享访问驱动器“完全公平”这是试图在同一时间访问一个驱动器之间的所有不同的进程。在硬盘驱
2013-06-08 10:35:50 5799
原创 mongoDB 系统选择部分小结
硬盘:primary及secondary都选择SSD,备库能选SAS就别选SATA,具体情况看同步的速度,如果同步真跟不上,那还必须上SSD;raid方面,趋向于home分区做radi10,数据分区做raid5;为什么raid5?这个跟业务有关!内存:作为数据库服务器,内存必须得大方点,特别是mongo这种对内存严重依赖的服务器,至少保证热数据和索引常驻内存,推介选择48G或以上;
2013-06-04 12:21:46 1015
转载 MegaCli 监控raid状态
简介MegaCli是一款管理维护硬件RAID软件,可以通过它来了解当前raid卡的所有信息,包括 raid卡的型号,raid的阵列类型,raid 上各磁盘状态,等等。通常,我们对硬盘当前的状态不太好确定,一般通过机房人员巡检来完成,有没有通过软件的方式来检查确定这个问题呢。MegaCli就可以做到,一般通过 MegaCli 的Media Error Count: 0 Other Error C
2013-06-04 11:04:10 10422 3
原创 mysq字段选择
mysql支持很多字段类型,包括数值类型、日期/时间类型和字符串(字符)类型;在使用时需要考虑到存储空间,存储效率;几种列类型描述使用了下述惯例:· M表示最大显示宽度。最大有效显示宽度是255。· D时间类型:datetime(8bytes),timestamp(4bytes)字符类型:VARCHAR(M),L+1个字节,其中L<=
2013-06-03 21:48:09 975
原创 mysql 同步线程出现ERROR 2006 (HY000): MySQL server has gone away
今天线上一个备库的同步线程出现ERROR 2006 (HY000): MySQL server has gone away,感觉很奇葩,如下:mysql> show slave status\GERROR 2006 (HY000): MySQL server has gone awayNo connection. Trying to reconnect...ERROR 2002 (
2013-06-02 21:21:24 5168
原创 percona 实用工具之pt-kill
pt-kill概述从show processlist 中获取满足条件的连接或者从包含show processlist的文件中读取满足条件的连接并打印或者杀掉或者执行其他操作,这个工具在工作中实用性很高,当服务器连接出现异常后第一想到的就是pt-kill,自己写一个脚本也可以,但是功能还是没有pt-kill强大;一般我喜欢将连接本地mysql的必要信息放在一个文件文件中,当需要连接本地m
2013-05-30 22:04:38 4934
原创 linux远程拷数据
简单说明远程拷数据在工作中是经常使用到的场景,其中有的传输是校验数据的有的传输不校验数据,不校验数据的虽然速度快很多,但是容易出错,特别是在拷贝上T的大文件时就经常数据不一致,所以一般在做数据的过程中使用校验数据的方式比较靠谱;工具介绍1、scpscp是校验数据的传输格式,如果没有信任关系就需要用户名密码,常见的几个用法本地传到远程scp user@pass /etc/l
2013-05-17 13:23:35 940
原创 mongo capped collection功能介绍及使用注意事项
简单介绍: 在mongodb中,除了普通的collections,还有一种特殊的collections,叫做capped collections,他有点类似于myql 的ib_logfile, 预先分配大小,插入时以先进先出的方式处理,自动维护集群的大小和顺序,写入时如果不建索引和mysql的日志写入性能差不多,都是顺序写入; 创建方式: db.createCollectio
2013-05-17 10:41:01 1780
原创 mogodb简单扩容
mogodb在使用过程中,扩容的场景并不多,一般需要扩容的情况是,磁盘Io达到瓶颈或者连接并发达到瓶颈,下面讲一下简单的扩容步骤; list1、关掉源机器的mogo登陆mongo执行db.shutdownServer() or kill -2 mongod or kill -15 mongod;2、拷贝将源机器上的mongo目录拷贝到目标机器;放在目标机
2013-05-17 09:51:15 778
转载 shell 中(),(()),[],[[]]区别
1. 首先,尽管很相似,但是从概念上讲,二者是不同层次的东西。"[[",是关键字,许多shell(如ash bsh)并不支持这种方式。ksh, bash(据说从2.02起引入对[[的支持)等支持。"["是一条命令, 与test等价,大多数shell都支持。在现代的大多数sh实现中,"["与"test"是内部(builtin)命令,换句话说执行"test"/"["时不会调用/some/pat
2013-05-02 23:25:52 885
转载 mongodb分布式集群架构
转自:http://freeze.blog.51cto.com/1846439/884925一、关于mongodb MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常
2013-04-16 10:09:19 839
原创 xtrabackup 1.6.3安装出现cc1: error: unrecognized command line option "-fdiagnostics-show-option"
今天没事,就重新下了一个xtrabackup 1.6.3来玩一下,公司用这个工具不多,在这个版本安装时出现一个问题首先这个版本必须要下载 libtar-1.2.11.tar.gz和 mysql-5.1.56.tar.gz 按说明一次下载两个版本到/home/zhanghong/xtrabackup/xtrabackup-1.6.3目录下,再次运行build.sh出现cc1
2012-11-24 21:01:55 5256
原创 shell 关联索引下标是否对字符串有所限制?
#!/bin/shif [[ $# != 1 ]];thenecho $0 basepath;echo ;fipath=$1;declare -a statearray;(find $path -type f -print)| while read line;do#echo "----"echo $line;#echo "----"ftype=`file -b "$
2012-11-18 20:11:31 4517 2
原创 innodb 刷数据
首先innodb 线程分为用户态线程和后台线程,用户态线程主要是用户操作的线程,可以通过show process list 查看,后台线程不能够查看。但是show innodb status可以查看到4个线程I/O thread 0 state: waiting for i/o request (insert buffer thread)I/O thread 1 state: waitin
2012-11-15 17:16:00 915
原创 mysql relay-log.info, master.info
relay-log.info, master.info 这连个文件时在建立复制时产生的,现在主要说明以下问题:1、如果修改删除master.info文件,复制会中断么?不会,如果stop slave,然后start slave还是能正常启动起来,因为mysql已经记住这里面的信息了,但是当你重启mysql时,在start slave,这时重启失败,会提示你change master to
2012-11-13 16:54:16 8047
翻译 innodb log及datafile增删
#### 官方参考####为了添加一个数据文件到表空间中,首先要关闭 MySQL 数据库,编辑 my.cnf 文件,在 innodb_data_file_path 中添加一个新文件,然后再重新启动服务。如果,最后一个文件以关键字 autoextend 来描述,那么编辑 my.cnf 的过程如下所示。必须检查最后一个文件的尺寸,并使它向下接近于 1024 * 1024 bytes (= 1
2012-10-25 15:26:58 655
原创 配置mysql sync_binlog 和innodb_flush_log_at_tx_commit导致主从数据不一致
有两种配置情况可能导致主从数据不一致sync_binlog=1 innodb_flush_log_at_tx_commit=0当commit时数据写到binlog当时并没有写到redolog 时 系统crash。此时从库已经拿到binglog进行数据重做,但是主库重启后会回滚该事务,此时导致主从数据不一致.sync_binlog=1 innodb_flush_log_at_tx
2012-10-21 17:02:37 6642
原创 mysql innodb 刷数据和redo log
两个参数分别控制着innodb 怎么刷数据和redo,这里主要是说明一下根据实际场景配置他们.innodb_flush_log_at_tx_commit 控制着innodb怎么刷日志进行持久化.innodb_flush_method确定数据和日志怎么刷新到磁盘配置两个参数来协调刷数据和日志.目前采用 fadasync 和1 . 的比较多。
2012-10-21 16:47:30 1045
转载 mysql 对cpu core 的依赖关系
mysql 是否对cpu core 的依赖关系曾线性关系提升?答案是否定的,对于mysql 5.1来说,经过学习公司的测试数据发现,当cpu core 小于4时曾线性增长,当大于4时增长开始减缓,达到8时减缓的速度更快,到达32核时几乎处于平缓达到瓶颈.所以对于目前比较稳定的5.1系列版本来说,8核相对是性价比比较高.参考资料:www.dbaoper.com
2012-10-21 16:10:34 983
转载 mysql各个主要版本之间的差异.
一、各版本的常用命令差异 show innodb status\G mysql-5.1 show engines innodb status\G mysql-5.5 关于grant授权 mysql-5.5 的 user@'%'不包含localhost 二、MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要区别 mysql-server-4.1 增加了
2012-10-21 15:35:30 3754
原创 mysql数据库快速冷备命令
time dd if=datadir bs=1024 of=/bakdir这个命令的速度 比scp或者cp命令速度快n倍time有计时作用,dd用于复制,从if读出,写到of ,bs 复制多少个块同时该命令也可以用来测试硬盘的读写速度.
2012-10-19 13:35:43 1014
原创 linux /dev/urandom和/dev/random的区别
Linux 产生随机数的两种方式cat /dev/urandom | od -x | sed 's/\s*//g' |cut -c 8-16 |less cat /dev/random | od -x | sed 's/\s*//g' |cut -c 8-16 |less 上述两种方式都可以产生随机数,但是有区别dev/urandom 和dev/random都是产
2012-10-19 10:20:27 8931
原创 分析慢查询日志
执行mysqldumpslow –h可以查看帮助信息。主要介绍两个参数-s和-t-s 这个是排序参数,可选的有:al: 平均锁定时间ar: 平均返回记录数at: 平均查询时间c: 计数l: 锁定时间r: 返回记录t: 查询时间-t n 显示头n条记录。实例:mysqldumpslow -s c -t 20 host-slow.logmysql
2012-10-11 15:26:08 663
转载 Linux中/proc目录下文件详解
转自:http://www.sudu.cn/info/index.php?op=article&id=302529Linux中/proc目录下文件详解(一)声明:可以自由转载本文,但请务必保留本文的完整性。作者:张子坚email:zhangzijian@163.com说明:本文所涉及示例均在fedora core3下得到。 -------------
2012-10-11 15:17:14 4639
session 学习要点
2011-05-24
php 2.0 CHM 格式帮组文档
2011-05-24
Icarbegie ssd9 Choice 选择题 Icarbegie ssd9
2011-04-14
php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门 学系资源php 入门
2011-03-23
C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案C++ 答案
2011-03-20
SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案SSD4 人机界面答案
2011-03-20
Icarnegie SSD9全部答案 Icarnegie SSD9全部答案 Icarnegie SSD9全部答案 Icarnegie SSD9全部答案 Icarnegie SSD9全部答案
2011-03-09
Icarnegie SSD8全部答案 Icarnegie SSD8全部答案Icarnegie SSD8全部答案Icarnegie SSD8全部答案Icarnegie SSD8全部答案Icarnegie SSD8全部答案Icarnegie SSD8全部答案Icarnegie SSD8全部答案 Icarnegie SSD8全部答案 Icarnegie SSD8全部答案
2011-03-09
ACM题解 ACM题解 ACM题解 ACM题解 ACM题解 ACM题解 ACM题解 ACM题解 ACM题解
2011-03-05
MinGW最新版 MinGW最新版 MinGW最新版 MinGW最新版 MinGW最新版 MinGW最新版 MinGW最新版 MinGW最新版
2011-03-05
QT QT QT QT QT QT QT QT QT QT QT QT QT QT QT QT
2011-03-05
HTML帮助文档htmlHTML帮助文档htmlHTML帮助文档html
2011-03-05
SSD5 exam3+ssd5+exam3+答案+包含+Multiple-Choice+Quiz
2010-12-19
卡耐基课程SSD5答案
2010-11-22
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人