June 25, 2010
Mysql InnoDB和MyISAM的区别
"InnoDB和MyISAM是在使用MySQL最常用的两个表类型,各有优缺点,视具体应用而定。基本的差别为:MyISAM类型不支持事务处理等 高级处 理,而InnoDB类型支持。MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持已 经外部键等高级数据库功能。\nMyIASM是IASM表的新版本,有如下扩展:\n1、二进制层次的可移植性。\n2、NULL列索引。\n3、对变长行比ISAM表有更少的碎片。\n4、支持大文件。\n5、更好的索引压缩。\n6、更好的键码统计分布。\n7、更好和更快的auto_increment处理。\nInnoDB 是 MySQL 上第一个提供外键约束的引擎,除了提供事务处理外,InnoDB 还支持行锁,提供和 Oracle 一样的一致性的不加锁读取,能增加并发读的用户数量并提高性能,不会增加锁的数量。\nInnoDB 的设计目标是处理大容量数据时最大化性能,它的 CPU 利用率是其他所有基于磁盘的关系数据库引擎中最有效率的。\nInnoDB 是一套放在 MySQL 后台的完整数据库系统,InnoDB 有它自己的缓冲池, …"
June 24, 2010
FreeBSD portupgrade升级你的FreeBSD软件
"portupgrade 是一个软件,用于快捷便利地升级软件,安装办法:\n#cd /usr/ports/sysutils/portupgrade\n#make install clean\n然后用cvsup更新ports树,最后运行:\n#portupgrade -r pkg_name 升级单个软件和与其相关的,其中 pkg_name 是 pkg_info 中显示的名字\nportupgrade -ar 就会自动更新全部了。\n如果加上 P 参数,则先看是否有已经编译好的 pkg 下载,直接从 pkg 升级,省去自己编译。\n下载站点可以通过修改 /usr/local/etc/pkgtools.conf 更改。\nportupgrade -arR 升级所有已经安装的软件,并且检查依赖关系。"
June 24, 2010
Five Minutes程延辉 介绍开心农场架构
"Five Minutes 公司程延辉(小名康天) 介绍开心农场架构,social game的技术挑战,支持千万级DAU的social game技术架构。这是一个对于开发者来说,非常精彩,非常有实用性指导的一次演讲,详细介绍了很多技术内幕。\n\u0026raquo;猛击这里下载演讲ppt\u0026laquo;\nFive Minutes 公司的著名social game 开心农场,目前非常受用户欢迎,包括国外的Facebook,国内的开心网都是如此,是全球最大的social game,台下热烈掌声。呵呵。开心农场这个游戏从介绍看,相当成功,最早是08年9月在xiaonei上线,而后在51等平台推广,包括Facebook。现在已经有1570万游戏用户了,其中包括50万的Facebook用户。\n开心农场架构主要难点:1。如何存储大规模的用户数据千万级2。如果应对大量访问每天数亿请求量3。如果应对数据的频繁修改,每秒数万次数据修改。\n解决的方式\n优化:\n1。负载均衡,web服务器平行扩展。\n2。服务器性能优化。\n3。异步处理,缓存数据接口,Linux内核参数优化,挖掘PHP的效率,用fastcgi模式运行php, …"
June 24, 2010
UPDATE 时主键冲突引发的思考
"假设有一个表,结构如下:\nmysql\u0026gt; CREATE TABLE `a` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `id2` int(10) unsigned NOT NULL DEFAULT \u0026#39;0\u0026#39;, PRIMARY KEY (`id`) ) ENGINE=MyISAM; 该表中只有6条记录,如下:\nmysql\u0026gt; select * from a; +----+---------+ | id | city_id | +----+---------+ | 2 | 2 | | 3 | 3 | | 5 | 5 | | 4 | 4 | | 6 | 6 | | 7 | 7 | +----+---------+ 注意上面id的显示顺序,由于没有指定排序字段,myisam表引擎是随机显示记录列表的。 现在想要把id字段分别-1,执行以下语句,得到报错: mysql\u0026gt; update a set id=id-1; ERROR 1062 (23000): Duplicate entry \u0026#39;4\u0026#39; …"
June 20, 2010
开源数据库 Sharding 技术 (Share Nothing)
"注:此文首发于 《程序员》杂志 2008 年 7 月刊。\n从 Shard 到 Sharding “Shard” 这个词英文的意思是”碎片”,而作为数据库相关的技术用语,似乎最早见于大型多人在线角色扮演游戏(MMORPG)中。”Sharding” 姑且称之为”分片”。\nSharding 不是一门新技术,而是一个相对简朴的软件理念。如您所知,MySQL 5 之后才有了数据表分区功能,那么在此之前,很多 MySQL 的潜在用户都对 MySQL 的扩展性有所顾虑,而是否具备分区功能就成了衡量一个数据库可扩展性与否的一个关键指标(当然不是唯一指标)。数据库扩展性是一个永恒的话题,MySQL 的推广者经常会被问到:如在单一数据库上处理应用数据捉襟见肘而需要进行分区化之类的处理,是如何办到的呢? 答案是:Sharding。\nSharding 不是一个某个特定数据库软件附属的功能,而是在具体技术细节之上的抽象处理,是水平扩展(Scale Out,亦或横向扩展、向外扩展)的解决方案,其主要目的是为突破单节点数据库服务器的 I/O 能力限制,解决数据库扩展性问题。\n事关数据库扩展性 说起数据库扩展性,这是 …"
June 20, 2010
闲谈 Web 图片服务器
"现在很多中小网站(尤其是 Web 2.0 站点) 都允许用户上传图片,如果前期没有很好的规划,那么随着图片文件的增多,无论是管理还是性能上都带来很多问题。就自己的一点理解,抛砖引玉,以期能引出更具价值的信息。\n事关图片的存储 把图片存储到什么介质上? 如果有足够的资金购买专用的图片服务器硬件或者 NAS 设备,那么简单的很;如果有能力自己开发单独存储图片的文件系统,那么也不用接着往下看了。\n如果上述条件不具备,只想在普通的硬盘上存储,首先还是要考虑一下物理硬盘的实际处理能力。是 7200 转的还是 15000 转的,实际表现差别就很大。是选择 ReiserFS 还是 Ext3 ,怎么也要测试一下吧? 创建文件系统的时候 Inode 问题也要加以考虑,选择合适大小的 inode size ,在空间和速度上做取舍,同时防患于未然,注意单个文件系统下文件个数别达到极限。\n独立,独立的服务器 无论从管理上,还是从性能上看,只要有可能,尽量部署独立的图片服务器。这几乎成为常识了(不过在我做过面向 Web 的项目之前就这个问题也被人笑话过)。具备独立的图片服务器或者服务器集群后,在 Web 服务器 …"
June 20, 2010
小规模低性能低流量网站设计原则
"到处都是什么大规模啊,高流量啊,高性能之类的网站架构设计,这类文章一是满足人们好奇心,但看过之后也就看过了,实际收益可能并不大;另外一个副作用是容易让人心潮澎湃,没学走先学跑,在很多条件仍不具备的情况下,过度设计、过度扩展(高德纳大爷也说过,”过早优化是万恶之源”),所以,这里反弹琵琶,讨论一下小规模、低性能、低流量的网站该如何搞法。\n如果站点起步阶段可能就是一台机器(或是一台虚拟机,比如 JobsDigg.com ),这个时候,去关注什么数据拆分啊,负载均衡啊,都是没影子的事情。很多大站点的经验绝不能照搬,辩证的参考才是硬道理。\n拥抱熟知的技术 动手构建站点的时候,不要到处去问别人该用什么,什么熟悉用什么,如果用自己不擅长的技术手段来写网站,等你写完,黄花菜可能都凉了。所以,有现成的软件组件可用,就不要自己重新发明轮子。人家说 Python 牛,但自己只懂 PHP ,那就 PHP 好了,如果熟悉 .net ?,那也不错。用烂技术不是丢人的事情,把好技术用烂才丢人。\n架构层次清晰化 起步的阶段应该清楚的确定下来架构的层次。如果都搅和在一起,业务一旦扩增开来,如果原有的一堆东西拆不开就是 …"
June 17, 2010
lighttpd配置DiscuzX伪静态规则详细图文教程
"VPS下lighttpd配置DiscuzX伪静态规则\n第一步:进入Kloxo VPS控制面板点击域名选项. 第二步:进入域名选项后,选中你所要配置lighttpd的DiscuzX伪静态规则的域名, 这里所需要配置的域名为找iPad论坛 www.cn0393.com , 点击它,进入站点选项列表. 第三步:点击lighttpd地址重写规则按纽,进入lighttpd配置界面. 第四步:把由找ipad论坛提供的lighttpd的DiscuzX伪静态规则文件粘贴进空白框中. 第五步:然后点击Update按纽,应用并使lighttpd生效. 注:lighttpd会自动重启可以不用像IIS那样需要手工重启。 第六步:进入DiscuzX管理中心,点击–》全局–》优化设置–》URL静态化 把箭头所指的勾全选中–》点提交 最后一步,就是更新一下缓存就OK了,超简单。哥你懂的,就不截图了。自已看效果吧!"
June 11, 2010
php 静态类和方法
"\u0026lt;?php\u0026lt;br /\u0026gt; /*\u0026lt;br /\u0026gt; //静态属性 或静态方法不需要所在类被实例化就可以使用\u0026lt;br /\u0026gt; //使用方法:类名::静态方法名(静态属性名)\u0026lt;br /\u0026gt; //例子:static.php\u0026lt;br /\u0026gt; */\u0026lt;br /\u0026gt; class Math\u0026lt;br /\u0026gt; {\u0026lt;br /\u0026gt; public static $PI=3.14; //定义静态属性\n//public $PI=3.14; //静态方法不能调用非静态的属性\n`//定义一个静态方法,求两个数中的最大值\n静态方法和属性-深入PHP面向对象.模式与实践\nPHP静态变量介绍\n来源:\u0026lt;a href=\u0026quot;http://blog.chinaunix.net/u1/51625/showart_406076.html\u0026quot; target=\u0026quot;_blank\u0026quot;\u0026gt;http://blog.chinaunix.net/u1/51625/showart_406076.html\u0026lt;/a\u0026gt;"
June 11, 2010
PHP生成静态页面类
"class Shtml\n{\nvar $Templet;\nvar $DataSource;\nvar $Dir;\nvar $fileName;\nvar $mod;\nvar $handle;\nfunction Shtml($fileName=””)\n{\n$this-\u0026gt;fileName=$fileName;\n$this-\u0026gt;mod=”wb”;\n$this-\u0026gt;handle=false;\n$this-\u0026gt;Templet = “”;\n$this-\u0026gt;DataSource = array();\n$this-\u0026gt;Dir = “”;\n}\n/// \u0026lt;描述\u0026gt;\n/// 绑定数据源,参数为一数组。\n///\nfunction BindData($arr)\n{\n$this-\u0026gt;DataSource = $arr;\n}\n/// \u0026lt;描述\u0026gt;\n/// 设置文件存放路径。\n///\nfunction SetDir($dir)\n{\n$this-\u0026gt;Dir = $dir;\n}\nfunction SetFileName($fileName)\n{\nreturn …"