[ÔÓ¼Ç] ÐÂÄêÎïÓï&¹ØÓÚMysqlÒýÇæÐÔÄܲâÊÔ
æµµÄ2009ÖÕÓÚ¹ýÈ¥£¬Ò²ÖÕÓÚ°ÑÈËÉú´óÊÂæÍêÁË£¬»Øµ½Õý³£µÄ¹¤×÷Éú»îÖÐÀ´¡£2010¶ÔÎÒÀ´ËµÓ¦¸ÃÊdzäÂúÐÂÆÚÍûµÄÒ»Ä꣬ÐÂµÄÆõ»ú¾ÍÔÚÑÛǰ£¬¼ÓÓÍŬÁ¦°É~
ÁíÍâ×¼±¸12¸öÔÂÖ®ºóÔÙÀ´×ܽáһϽñÄêµÄÖØ´óʼǣ¬ºÇºÇ~
˳±ã¿´µ½Ò»¸öMysqlµÄ²âÊÔÎÄÕ£¬¸Ð¾õ»¹ÂúÓвο¼¼ÛÖµµÄ£¬ÓÚÊǼǼÏÂÀ´ÒÔ±ã²Î¿¼¡£
ÒÔÏÂÊÇÒ»¸öMySQLÖÐMyISAMÒýÇæÓëInnoDBÒýÇæÐÔÄܼòµ¥ÐÔÄܲâÊÔ£º
[Ó²¼þÅäÖÃ]
CPU : AMD2500+ (1.8G)
ÄÚ´æ: 1G/ÏÖ´ú
Ó²ÅÌ: 80G/IDE
[Èí¼þÅäÖÃ]
OS : Windows XP SP2
SE : PHP5.2.1
DB : MySQL5.0.37
ÔÚȱʡÅäÖõÄÇé¿öϽøÐвåÈëÊý¾Ý²âÊÔ£º
[²åÈëÊý¾Ý-1] (innodb_flush_log_at_trx_commit=1)
MyISAM 1W£º3/s
InnoDB 1W£º219/s
MyISAM 10W£º29/s
InnoDB 10W£º2092/s
MyISAM 100W£º287/s
InnoDB 100W£ºÃ»¸Ò²âÊÔ
[²åÈëÊý¾Ý-2] (innodb_flush_log_at_trx_commit=0)
MyISAM 1W£º3/s
InnoDB 1W£º3/s
MyISAM 10W£º30/s
InnoDB 10W£º29/s
MyISAM 100W£º273/s
InnoDB 100W£º423/s
[²åÈëÊý¾Ý3] (innodb_buffer_pool_size=1024M)
InnoDB 1W£º3/s
InnoDB 10W£º33/s
InnoDB 100W£º607/s
[²åÈëÊý¾Ý4] (innodb_buffer_pool_size=256M, innodb_flush_log_at_trx_commit=1, set autocommit=0)
InnoDB 1W£º3/s
InnoDB 10W£º26/s
InnoDB 100W£º379/s
¡¾²âÊÔ½áÂÛ¡¿
¿ÉÒÔ¿´³öÔÚMySQL 5.0ÀïÃæ£¬MyISAMºÍInnoDB´æ´¢ÒýÇæÐÔÄܲî±ð²¢²»ÊǺܴó£¬Õë¶ÔInnoDBÀ´Ëµ£¬Ó°ÏìÐÔÄܵÄÖ÷ÒªÊÇ innodb_flush_log_at_trx_commit Õâ¸öÑ¡ÏÈç¹ûÉèÖÃΪ1µÄ»°£¬ÄÇôÿ´Î²åÈëÊý¾ÝµÄʱºò¶¼»á×Ô¶¯Ìá½»£¬µ¼ÖÂÐÔÄܼ±¾çϽµ£¬Ó¦¸ÃÊǸúË¢ÐÂÈÕÖ¾ÓйØÏµ£¬ÉèÖÃΪ0ЧÂÊÄܹ»¿´µ½Ã÷ÏÔÌáÉý£¬µ±È»£¬Í¬ÑùÄã¿ÉÒÔSQLÖÐÌá½»¡°SET AUTOCOMMIT = 0¡±À´ÉèÖôﵽºÃµÄÐÔÄÜ¡£ÁíÍ⣬»¹Ìý˵ͨ¹ýÉèÖÃinnodb_buffer_pool_sizeÄܹ»ÌáÉýInnoDBµÄÐÔÄÜ£¬µ«ÊÇÎÒ²âÊÔ·¢ÏÖûÓÐÌØ±ðÃ÷ÏÔµÄÌáÉý¡£
»ù±¾ÉÏÎÒÃÇ¿ÉÒÔ¿¼ÂÇʹÓÃInnoDBÀ´Ìæ´úÎÒÃǵÄMyISAMÒýÇæÁË£¬ÒòΪInnoDB×ÔÉíºÜ¶àÁ¼ºÃµÄÌØµã£¬±ÈÈçÊÂÎñÖ§³Ö¡¢´æ´¢¹ý³Ì¡¢ÊÓͼ¡¢Ðм¶Ëø¶¨µÈµÈ£¬ÔÚ²¢·¢ºÜ¶àµÄÇé¿öÏ£¬ÏàÐÅInnoDBµÄ±íÏֿ϶¨Òª±ÈMyISAMÇ¿ºÜ¶à£¬µ±È»£¬ÏàÓ¦µÄÔÚmy.cnfÖеÄÅäÖÃÒ²ÊDZȽϹؼüµÄ£¬Á¼ºÃµÄÅäÖã¬Äܹ»ÓÐЧµÄ¼ÓËÙÄãµÄÓ¦Óá£
Èç¹û²»ÊǺܸ´ÔÓµÄWebÓ¦Ó㬷ǹؼüÓ¦Ó㬻¹ÊÇ¿ÉÒÔ¼ÌÐø¿¼ÂÇMyISAMµÄ£¬Õâ¸ö¾ßÌåÇé¿ö¿ÉÒÔ×Ô¼ºÕå×á£
¡¾½áÂÛ·ÖÎö¡¿
InnoDBºÍMyISAMÊÇÔÚʹÓÃMySQL×î³£ÓõÄÁ½¸ö±íÀàÐÍ£¬¸÷ÓÐÓÅȱµã£¬ÊÓ¾ßÌåÓ¦Óöø¶¨¡£»ù±¾µÄ²î±ðΪ£ºMyISAMÀàÐͲ»Ö§³ÖÊÂÎñ´¦ÀíµÈ¸ß¼
Ïà¹ØÎĵµ£º
н¨backup.bat
ÉèÖÃmysqldumpÈ«¾Ö»·¾³±äÁ¿»òʹÓÃʱдÈë¾ø¶Ô·¾¶
@echo off
set date0=%date:~0,10%
set time0=%time:~0,8%
set time1=%time:~0,2%
set time2=%time:~3,2%
set time3=%time:~6,2%
echo %time0%
echo %time1%
echo %time2%
echo %time3%
mysqldump -u<Óû§> -p<ÃÜÂë> -h <ip ......
ÎÒÔڵǼMySQLºóµÄÃüÁîÐÐÊÇÕâ¸öÑù×ӵģº
warmbupt@pchuang:/windows/MyCode/SS$ mysql -u root -ppassw0rd
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 37
Server version: 5.1.37-1ubuntu5.1 (Ubuntu)
Type 'help;' or '\h' for help. Type '\c' to clear the curr ......
ÄÚ´æ±íʹÓùþϣɢÁÐË÷Òý°ÑÊý¾Ý±£´æÔÚÄÚ´æÖУ¬Òò´Ë¾ßÓм«¿ìµÄËÙ¶È£¬Êʺϻº´æÖÐСÐÍÊý¾Ý¿â£¬µ«ÊÇʹÓÃÉÏÊܵ½Ò»Ð©ÏÞÖÆ£¬ÒÔÏÂÊÇÀ¶²ÝʹÓõÄһЩ¸ÐÊÜ¡£
1¡¢heap¶ÔËùÓÐÓû§µÄÁ¬½ÓÊǿɼûµÄ£¬ÕâʹµÃËü·Ç³£ÊʺÏ×ö»º´æ¡£
2¡¢½öÊʺÏʹÓõij¡ºÏ¡£heap²»ÔÊÐíʹÓÃxxxTEXTºÍxxxBLOBÊý¾ÝÀàÐÍ£»Ö»ÔÊÐíʹÓÃ=ºÍ<=>²Ù×÷·ûÀ´ËÑË÷¼Ç¼£¨²» ......
½ñÌìµÄѧϰÄÚÈÝÊÇsqliteºÍPDO mysql¡£
ÓÃ×Ô¼ºµÄ»°ËµËµÁ½¸ö¶«Î÷°É£º
sqliteËãÊÇÒ»ÖÖ²»ÏµÍ³µÄÊý¾Ý¿â´æ´¢·½Ê½£¬ËüµÄ´æ·Å¸ñʽÊÇÒ»¸ö.dbºó׺µÄÎļþ£¬ÔÚphpÖÐËü´æ·ÅÔÚµ±Ç°µÄĿ¼Ï£¬Ã²ËƲ»ÓÃÓû§ÃûÃÜÂ룬°²È«ÐԽϵͣ¬È´±È½Ï·½±ã¡£PHP5ÖÐ×Ô´øµÄһЩϵͳº¯Êý£¬¶¼ÊÇÒÔsqlite_¿ªÍ·µÄ¡£
PDOÈ«³ÆPHP Data Object£¬¹ËÃû˼Òå¾ÍÊÇPHPµÄÒ ......