Submitted by gouki on 2008, November 25, 6:03 PM
Author:丹臣 posted on Taobao.com
mysql数据库里,对一个已创建的表进行DDL操作,比如说添加一个字段。在做测试时,发现ddl操作的时间特别的长。oracle里,通常情况下只是 修改数据字典就可以了,操作时间非常的短,阻塞DML的时间也比较短。mysql数据库对表进行ddl操作跟oracle数据库有很大的不同,它先要把原 表拷贝一份到临时表,这期间不阻塞select,阻塞所有的更改操作(update,delete,insert),对临时表ddl操作完成,删除原表, 重命名临时表。
如果一张比较大的表进行ddl变更,比如说40G,那拷贝的时间让人无法忍受,并且阻塞所有的DML操作,让业务无法继续。
以下是测试过程:
mysql> desc t1;
+-------------------+------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------------------+------------------+------+-----+---------+-------+
| id | int(11) | YES | MUL | NULL | |
| nick | varchar(32) | YES | | NULL | |
| email | varchar(32) | YES | | NULL | |
| gmt_create | datetime | YES | | NULL | |
| gmt_modified | datetime | YES | | NULL | |
+-------------------+------------------+------+-----+---------+-------+
mysql> select count(*) from t1;
+----------+
| count(*) |
+----------+
| 2228017 |
+----------+
1 row in set (1.78 sec)
现在对它进行表结构变更,增加一列:
mysql> alter table t1 add(tel varchar(20));
Query OK, 2304923 rows affected (41.03 sec)
Records: 2304923 Duplicates: 0 Warnings: 0
在上述表结构变更过程中,启动另外一个会话,进行select查询操作和一个更新操作:
mysql> select count(*) from t1;
+---------------+
| count(*) |
+---------------+
| 2304923 |
+---------------+
1 row in set (2.10 sec)
mysql> select * from t1 limit 10;
+------+-------+------------------------+----------------------------+----------------------------+
| id | nick | email | gmt_create | gmt_modified |
+------+-------+------------------------+----------------------------+----------------------------+
| 0 | nick0 | nick0@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 1 | nick1 | nick1@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 2 | nick2 | nick2@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 3 | nick3 | nick3@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 4 | nick4 | nick4@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 5 | nick5 | nick5@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 6 | nick6 | nick6@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 7 | nick7 | nick7@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 8 | nick8 | nick8@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
| 9 | nick9 | nick9@taobao.com | 2008-03-14 00:00:00 | 2008-03-14 00:00:00 |
+------+-------+------------------------+----------------------------+----------------------------+
10 rows in set (0.00 sec)
mysql> update t1 set nick='test_nick' where id=1;
Query OK, 4 rows affected (43.89 sec) --这里是阻塞的时间
Rows matched: 4 Changed: 4 Warnings: 0
通过以上实验可以看出,对表进行ddl操作时,mysql并不阻塞select查询,但会严重阻塞dml操作。另外,如果你要对表进行ddl操作,由于有一个拷贝操作,你要计算好你的可用空间够不够?如果你的系统经常要进行表结构变更,那么你将不得不要考虑此问题!
--EOF--
膘叔:说实话,一般对于表的操作往往都是在夜深人静的时候,虽然select并不影响,但为避免在更新表结构的时候更新数据,这还是必须的。。。以防万一啊
Tags: mysql, database, 修改, 表结构, taobao dba
Baby | 评论:0
| 阅读:25477
Submitted by gouki on 2008, November 25, 9:07 AM
以前用JS操作XML都是用DOM的方式,现在有了这个插件,操作起来会更方便了直接采用对象。。。
来源:http://www.94this.com.cn/article/258.htm
这个插件应该是比较方便的一个插件了,它能把xml字符串或xml文件转化为json对象,比如把
XML/HTML代码
- <xml>
- <message>Hello world</message>
- </xml>
转化为
JavaScript代码
- {
- message: 'Hello world';
- }
这样我们操作起来就很方便了,因为用javascript操作json比操作xml要方便好多。
基本的使用:
JavaScript代码
- var xml = '<xml><message>Hello world</message></xml>';
- var json = $.xml2json(xml);
- alert(json.message);
当然它也能通过直接把xml文件转化为json:
JavaScript代码
- $.get('data/hello.xml', function(xml){
- var json = $.xml2json(xml);
- alert(json.message);
- });
好了,看看基本的演示吧!(膘叔:演示地址仍然是亮亮的网站)
这个插件还有一个扩展的用法:
基本的是把
XML/HTML代码
- <?xml version="1.0" encoding="utf-8"?>
- <animals>
- <dog color='Black'>
- <name>Rufus</name>
- <breed>labrador</breed>
- </dog>
- <dog breed='whippet'>
- Adopted
- <name>Marty</name>
- </dog>
- <cat color="White">
- <name>Matilda</name>
- </cat>
- </animals>
转化为
JavaScript代码
- {
- dog:[
- { name:'Rufus', breed:'labrador', color:'Black' },
- { text:'Adopted', name:'Marty', breed:'whippet' }
- ],
- cat:{ name:'Matilda', color:'White'}
- }
扩展的作用是把每个节点转化为数组的形式,即
JavaScript代码
- {
- dog:[
- { name:['Rufus'], breed:['labrador'], color:'Black' },
- { text:'Adopted', name:['Marty'], breed:'whippet' }
- ],
- cat:[
- { name:'Matilda', color:'White'}
- ]
- }
这个使用也简单,就多了一个参数:
JavaScript代码
- $.get('data/animals.xml', function(xml){
- var animals = $.xml2json(xml, true);
- alert(animals.dog[1].name[0].text +'/'+ animals.dog[1].text);
- });
最后,看看所有用法的
演示(
此演示官方提供)吧!
Javascript | 评论:0
| 阅读:23105
Submitted by gouki on 2008, November 24, 11:24 PM
李一男2003年在港湾给开发人员培训时的语录:
【1】好好规划自己的路,不要跟着感觉走!根据个人的理想决策安排,绝大部分人并不指望成为什么院士或教授,而是希望活得滋润一些,爽一些。那么, 就需要慎重安排自己的轨迹。从哪个行业入手,逐渐对该行业深入了解,不要频繁跳槽,特别是不要为了一点工资而转移阵地,从长远看,这点钱根本不算什么,当 你对一个行业有那么几年的体会,以后钱根本不是问题。频繁地动荡不是上策,最后你对哪个行业都没有摸透,永远是新手!
【2】可以做技术,切不可沉湎于技术。千万不可一门心思钻研技术!给自己很大压力,如果你的心思全部放在这上面,那么注定你将成为孔乙己一类的人物!适可而止为之,因为技术只不过是你今后前途的支柱之一,而且还不是最大的支柱,除非你只愿意到老还是个工程师!
【3】不要去做技术高手,只去做综合素质高手!在企业里混,我们时常瞧不起某人,说他“什么都不懂,凭啥拿那么多钱,凭啥升官!”这是普遍的典型的 工程师的迂腐之言。8051很牛吗?人家能上去必然有他的本事,而且是你没有的本事。你想想,老板搞经营那么多年,难道见识不如你这个新兵?人家或许善于 管理,善于领会老板意图,善于部门协调等等。因此务必培养自己多方面的能力,包括管理,亲和力,察言观色能力,攻关能力等,要成为综合素质的高手,则前途 无量,否则只能躲在角落看示波器!技术以外的技能才是更重要的本事!!从古到今,美国日本,一律如此!
【4】多交社会三教九流的朋友!不要只和工程师交往,认为有共同语言,其实更重要的是和其他类人物交往,如果你希望有朝一日当老板或高层管理,那么 你整日面对的就是这些人。了解他们的经历,思维习惯,爱好,学习他们处理问题的模式,了解社会各个角落的现象和问题,这是以后发展的巨大的本钱,没有这些 以后就会笨手笨脚,跌跌撞撞,遇到重重困难,交不少学费,成功的概率大大降低!
【5】知识涉猎不一定专,但一定要广!多看看其他方面的书,金融,财会,进出口,税务,法律等等,为以后做一些积累,以后的用处会更大!会少交许多学费!!
【6】抓住时机向技术管理或市场销售方面的转变!要想有前途就不能一直搞开发,适当时候要转变为管理或销售,前途会更大,以前搞技术也没有白搞,以 后还用得着。搞管理可以培养自己的领导能力,搞销售可以培养自己的市场概念和思维,同时为自己以后发展积累庞大的人 脉!应该说这才是前途的真正支柱。。?
【7】逐渐克服自己的心里弱点和性格缺陷!多疑,敏感,天真(贬义,并不可爱),犹豫不决,胆怯,多虑,脸皮太薄,心不够黑,教条式思维。。。这些 工程师普遍存在的性格弱点必须改变!很难吗?只在床上想一想当然不可能,去帮朋友守一个月地摊,包准有效果,去实践,而不要只想!不克服这些缺点,一切不 可能,甚至连项目经理都当不好--尽管你可能技术不错!
【8】工作的同时要为以后做准备!建立自己的工作环境!及早为自己配置一个工作环境,装备电脑,示波器(可以买个二手的),仿真器,编程器等,业余 可以接点活,一方面接触市场,培养市场感觉,同时也积累资金,更重要的是准备自己的产品,咱搞技术的没有钱,只有技术,技术的代表不是学历和证书,而是产 品,拿出象样的产品,就可技术转让或与人合作搞企业!先把东西准备好,等待机会,否则,有了机会也抓不住!
【9】要学会善于推销自己!不仅要能干,还要能说,能写,善于利用一切机会推销自己,树立自己的品牌形象,很必要!要创造条件让别人了解自己,不然 老板怎么知道你能干?外面的投资人怎么相信你?提早把自己推销出去,机会自然会来找你!搞个个人主页是个好注意!!特别是培养自己在行业的名气,有了名 气,高薪机会自不在话下,更重要的是有合作的机会...
原文來自:http://www.sanotes.net/html/y2008/229.html
突然輸出的就全是繁體字了。。感慨一下。
2003年的話到現在仍然有用啊。在這個寒冬里面,這些話,我們繼續溫習一下
Tags: 培訓, 語錄
Misc | 评论:0
| 阅读:17937
Submitted by gouki on 2008, November 23, 9:40 AM
Tags: 生病, 更新
Misc | 评论:3
| 阅读:21081
Submitted by gouki on 2008, November 22, 7:37 PM
为linux添加ssh访问是必然的,否则那就真的成了桌面了。
在网上找了很多资料,实在太多了。而且很多资料都己经过期,例如:http://bbs.net130.com/showthread.php?t=174784,贴子里的地址,是404,无法打开的。
在ubuntu下面,应该是可以通过 新立得软件安装器进行安装 的,但还是没有怎么配置。
于是我在终端下运行 :apt-get install ssh,哇。直接可以安装了。
然后用filezilla打开,嗯,可以访问ssh了。22端口了打开了。呵呵
apt-get确实是一个很好的东西。。不过,这也需要源里面添加了才行。(随便说说。我是新手,不对不要骂我)
安装软件一定要是root权限,你可以先运行su,切换到root下,再运行 。否则会说你没有权限的。
Tags: ubuntu, ssh, openssh, linux, remote
Ideas | 评论:0
| 阅读:26105