|
°Q½×°Ï>>MySQL ?ˆï¿½ï¿???forum_id=49<< |
¡@¥DÃD¡GMYSQL¦A½Õ¾ã
¹ïMYSQL¦A°µ¤@¦¸³]©w½Õ¾ã ¯Á©Ê§â¬ÛÃö°Ñ¼Æ¾ã²z¦b³o¸Ì ³o¬Omysql 4.0ªº°Ñ¼Æ³]©w
´XÓ¸ò®Ä¯à½Õ®Õ¤ñ¸û¦³Ãöªº°Ñ¼Æ¡A§â¤ß±o»P»`¶°¨ìªº¸ê®Æ¾ã²z¦b¤U± ¡]³o¨Ç¼Æ¦r¬OBYTE¡A¦bmy.cnf¤¤¥i¥HÁÙ¥i¥H¤¹³\¥ÎK¸òM¡A¦b«ü¥O¦C®É«hn¥Î*1024¥N´ÀK¡A*1024*1024¥N´ÀM¡^
back_log 50 basedir /usr/local/mysql bdb_cache_size 8388572 <=BDB¦rº¥NªíBDBªºDATABASE¬ÛÃö°Ñ¼Æ¡A¬°§Ú¥u¥ÎMYISAM®æ¦¡©Ò¥H¸õ¹L bdb_home /usr/local/mysql bdb_log_buffer_size 32768 bdb_logdir bdb_max_lock 10000 bdb_shared_data OFF bdb_tmpdir /tmp/ bdb_version Sleepycat Software: ... binlog_cache_size 32768 bulk_insert_buffer_size 8388608 character_set latin1 character_sets latin1 big5 czech euc_kr concurrent_insert ON connect_timeout 5 <=MYSQLD¥Î¨Ó§PÂ_¦¹³s½u¬O§_¦³®Äªº®É¶¡¡A«ØÄ³¹w³]¦pªGºô¸ô½wºC¥i¥H½Õ°ª convert_character_set datadir /usr/local/mysql/data/ default_week_format 0 delay_key_write ON delayed_insert_limit 100 delayed_insert_timeout 300 delayed_queue_size 1000 flush OFF flush_time 0 ft_boolean_syntax + -><()~*:""&| ft_max_word_len 84 ft_min_word_len 4 ft_query_expansion_limit 20 ft_stopword_file (built-in) have_bdb YES have_innodb YES have_isam YES have_openssl YES have_query_cache YES have_raid NO have_symlink DISABLED init_file innodb_additional_mem_pool_size 1048576 <=INNODB®æ¦¡¸ê®Æ®wªº³]©w°Ñ¼Æ¡A¤@¼Ë¸õ¹L innodb_buffer_pool_size 8388608 innodb_data_file_path ibdata1:10M:autoextend innodb_data_home_dir innodb_fast_shutdown ON innodb_file_io_threads 4 innodb_flush_log_at_trx_commit 1 innodb_flush_method innodb_force_recovery 0 innodb_lock_wait_timeout 50 innodb_log_arch_dir innodb_log_archive OFF innodb_log_buffer_size 1048576 innodb_log_file_size 5242880 innodb_log_files_in_group 2 innodb_log_group_home_dir ./ innodb_mirrored_log_groups 1 innodb_thread_concurrency 8 interactive_timeout 28800 <=¥ÎCOMMAND LINE¤è¦¡³s½u®É¡A¨Ò¦p¥ÎMYSQL³s½u¡A¤¹³\ªºIDLE®É¶¡ join_buffer_size 131072 <=¨Ï¥Î¨ìJOIN®É·|¥Î¨ì¡A¼È¦s·j´Mµ²ªG¥Î¦³¤jSELECT®Énµø±¡ªp¼W¥[¡A¦¹¬°THREAD BASE BUFFER¡A´N¬O¨CÓ³s½u³£·|¦h°t¸m³oÓ¤j¤pªº°O¾ÐÅé key_buffer_size 16773120 <=¥D¼È¦s°Ï¤j¤p©Ò¦³THREAD¦@¥Î key_cache_age_threshold 300 key_cache_block_size 1024 <=key cache¤@Óblockªº¤j¤p key_cache_division_limit 100 language /usr/local/mysql/share/... large_files_support ON local_infile ON locked_in_memory OFF log OFF log_bin OFF log_slave_updates OFF log_slow_queries OFF log_update OFF log_warnings 1 long_query_time 10 low_priority_updates OFF lower_case_table_names 0 max_allowed_packet 1047552 max_binlog_cache_size 4294967295 max_binlog_size 1073741824 max_connect_errors 10 max_connections 100 <=¤¹³\³Ì¤j³s½u¼Æ¡A¥¿¦¡Àô¹Òµ´¹ï»·¶W¹L¡Anµø¨t²Î°O¾ÐÅé¤j¤p¼W¥[¡A¹L¦h·|¾ÉP¨t²Î«±±¼ max_delayed_threads 20 max_error_count 64 max_heap_table_size 16777216 max_join_size 4294967295 max_relay_log_size 0 max_sort_length 1024 max_tmp_tables 32 <=¤¹³\ªº¼È®ÉTABLE¼Æ¥Ø max_user_connections 0 max_write_lock_count 4294967295 myisam_max_extra_sort_file_size 268435456 myisam_max_sort_file_size 2147483647 myisam_recover_options force myisam_repair_threads 1 myisam_sort_buffer_size 8388608 net_buffer_length 16384 <=ºô¸ô¼È¦sBUFFER¡A16384¬OTCP³Ì¤j«Ê¥]ªø«× net_read_timeout 30 net_retry_count 10 net_write_timeout 60 open_files_limit 1024 <=¤¹³\MYSQL¶}±Òªº¨t²ÎÀɮ׼ƤW pid_file /usr/local/mysql/name.pid port 3306 protocol_version 10 query_cache_limit 1048576 query_cache_size 0 query_cache_type ON read_buffer_size 131072 <=Ū¨ú¸ê®ÆªºBUFFER¤j¤p¡ATHREAD BASE·|¼vÅTSQL³t²v read_rnd_buffer_size 262144 rpl_recovery_rank 0 server_id 0 skip_external_locking ON skip_networking OFF skip_show_database OFF slave_net_timeout 3600 slow_launch_time 2 socket /tmp/mysql.sock sort_buffer_size 2097116 <=¥Î¨Ó±Æ§ÇªºBUFFER¡A¦pªG¦^¶Ç¤jªºµ²ªG¤S¨Ï¥ÎORDER BY¥[¤j³oÓBUFFER¥i¥H´£¤É³t«× sql_mode table_cache 64 <=¤¹³\¼È¦s¦bCACHE¸ÌªºTABLE¼Æ¶q table_type MYISAM thread_cache_size 3 thread_stack 131072 timezone EEST tmp_table_size 33554432 <=¼È¦s¦b°O¾ÐÅ餤ªº¼È¦sTABLE¤j¤p tmpdir /tmp/:/mnt/hd2/tmp/ tx_isolation READ-COMMITTED version 4.0.4-beta wait_timeout 28800 <=³oÓ³s½uªºTIMEOUT®É¶¡¡A³o¸Ì¦³¦U¤p°ÝÃD©ñ¦b¤U±¸ÑÄÀ
MYSQLªº³]©w°Ñ¦Ò¤å¥ó«Ü¤Ö ®×¨Ò¤]«Ü¤Ö §Ú¦Û¤v¦b¼g³o½gªF¦èªº®ÉÔ¤]ı±o«Ü¦hªF¦è¼g¤£¥X¨Ó ¥u¦n¦b¸ÑÄÀÅܼƤº®e¤§«á¤À´XÓ¥DÃD ²³æ»¡¤@¤U¬Ýªk
GLOBAL MEMORY»P THREAD MEMORY MYSQL¦A°t¸m°O¾ÐÅé®É¤À¦¨¨â¦U¶¥¬q¡A¤@¬O·íSERVER±Ò°Ê®É °t¸mµ¹¾ãÓ¨t²Î¨Ï¥Î¡A¤G¬O·íCLINT³s½u¶i¨Óªº®ÉÔ°t¸mµ¹³æ¤@³s½u¨Ï¥Î¡C «eªÌ³QºÙ¬°GLOBAL«áªÌ³QºÙ¬°THREAD¡A MEMORYªºÁ`¥Î¶q²³æªº»¡´N¬OGLOBAL+(THREAD¼Æ*THREAD MEMORY) ³oÓ¤½¦¡©Òºâ¥X¨Óªº°O¾ÐÅ鮸¯ÓÀ³¸Ón¤p©ó¨t²ÎªºÁ`°O¾ÐÅé¡A¦ý¬O¹ê°È¤W´ú¸Õ®É¡A¨t²Î°O¾ÐÅ餣¨¬´N·|¦^À³TOO MANY CONNECTION¦Ó¼È°±¦^À³¡C¦ý¬O¡A·½·½¤£µ´ªºREQUEST«Ü®e©öÅý¨t²Î¦º·í¡C³q±`USED CONNECTION·|¤j¶q¼W¥[¡A¬O¦]¬°TABLE LOCK¡A¾ÉP·sªºQUERY³Q¼È¦s¡A´î§CTABLE LOCKªº®É¶¡»P¦¸¼Æ¡A¤~¬O¸Ñ¨M°ÝÃD¤§¹D¡C ¦ý¬OTABLE LOCK¤@¯ë¬O¦]¬°SQL¬d¸ß¼gªº¤£¦n¡A½Õ¾ãSQL»yªk¶O¤éÃm®É¡A±Ï«æªº¿ìªk¥i¥HÁYµuwait_timeoutªº®É¶¡¡C ¦ý¬O³o·|¼W¥[CPU LOADING¡An¤£Â_TEST¥H¨D¨ú¥¿Å¡C
TMP TABLE»PTABLE CACHE ·í¤@Ó¬d¸ß©Ò®ø¯Óªº°O¾ÐÅé¶W¹L°t¸mªºBUFFER®É©ÎªÌ¤@¨Ç¨ä¥Lì¦]¡AMYSQL·|¶}±Ò¼È¦sTABLE¡A¼È¦sTABLE¥ý©ñ¦b°O¾ÐÅ餤¡A°O¾ÐÅ餣¨¬¦A§Q¥ÎDISK¡A¥Îªk´N¹³¬OL1¡BL2¡BL3 CACHE¡Ctable_cacheªº°Ñ¼Æ©w¸q¤F¯à°÷CACHE¦h¤ÖÓTABLE ¡Atmp_table_size©w¸q¤F¶}¦b°O¾ÐÅ餤ªº¼È®ÉTABLE¦³¦h¤j¡A¤]´N¬O»¡¡A³o¬OÓ¥þ°ìªº°O¾ÐÅé°t¸m¡CTMP TABLE¶W¹L³oÓ¤j¤p¡A´N·|³Q¼g¨ìµwºÐ¤W¡C n¤ñ¹ï³oӰѼƬO§_¤Ó¤jn¤ñ¸ûSHOW STATUS¤¤ªº open_tables¸òopened_tables¡A«eªÌ¬O¥Ø«e©Ò¶}±ÒªºTABLE¼Æ¡A«áªÌ¬O´¿¸g¶}±ÒªºTABLE¼Æ¡A¦pªG«áªÌ¤ñ«eªÌ¤j«Ü¦h¡Aªí¥ÜTABLE CACHE¤Ó¤p¡C¥i¥H¸Õ¸Õ©ñ¤j¡C
wait_timeout ³oӰѼƬO¥Ñglobal wait_timeout ©Î¬Ointeractive_timeouÄ~©Ó¤U¨Óªº¡C ¦Ó¥B¦bCOMMAND LINE®ÉµLªk¬Ý¨ìGLOBAL WAIT¡ÈTIMEOUT ¡A³oÓÈ·|Ä~©Ó¦Ûinteractive_timeout
½Õ¾ãMYSQL¡A¯S§O¬O½u¤WªºMYSQL¡A±on«Ü¦³@¤ßªº¤£Â_¹Á¸Õ¡Cª¾¹D¨CÓÅܼƪº·N¸q¡AµM«á´N¬On§ï¤@¤U¡A´ú¤@¤U¡C ¦ý¬O¡A¨t²Î½Õ¾ã¤]¬O¦³·¥¡ASQLªº½Õ¾ã¤~¬O¹ý©³¸Ñ¨M¤§¹D¡C
MySQLªº°õ¦æ±¡ªp¥i¥H±q¤TÓ¦a¤èÆ[¹î LOGÀÉ¡Bshow status;(SQL command)¡Bshow variables;
·íµMÁÙ¦³show table status; ¦ý¬O¡A³o³q±`³£¬O¤p°ÝÃD ¤j°ÝÃD·|¥X²{¦bshow variables;©Ò¥X²{ªº°Ñ¼Æ¤¤ show status;«h¬OÆ[¹î¥Ø«eªºSERVERª¬ºA ·|¦C¥X«Üªø¤@¬qÅܼƸԲӤº®e½Ð°Ñ¦ÒMYSQL¤â¥U©Î¥t¤@¥»¬ÛÃö®ÑÄy ³o¸Ì¥u¦C¥X´XÓÆ[¹î«ü¼Ð Max_used_connection => «Ø¥ß³s½uªº³Ì¤j¼Æ¥Ø¡A ³oӼƦrn¸òshow variables;ªºMax_connection°Ñ¼Æ¹ï·Ó¡A ¦pªG¨Ï¥Îªº³s½u¼Æ¥Ø¤w¸g¨ì¹F³Ì¤j¡A¥i¥H¦Ò¼{©ñ¼e ¦ý¬O¨C¤@Óconnection·|¦h®ø¯Ó°O¾ÐÅé °O¾ÐÅ骺®ø¯Ó¼Æ¶q²©öpºâ¤è¦¡¬O¡G key_buffer + (sort_buffer + read_buffer) * max_connection ·íµM³o¥u¬O²³æºâªk¡A¬Ù²¤¤£¤Ö¤ñ¸û¤pªº¶µ¥Ø ¦ý¬O¡A³oÓµ¥¬Oºâ¥X¨ÓªºÈ½Ð«O«ù¤£n¶W¹L¹ê»Ú°O¾ÐÅé ¤£µM¡AMySQL·|¦³hang¦íªº¦MÀI
key_blocks_used¨Ï¥ÎªºKEY BUFFER¥HBLOCKpºâ¡]1024-byte¡^ »Pkey_bufferªº³]©w¬Û¤ñ¸û¥i¥H¾A«×¼W´î
Open_tables»POpened_tables ¥Ø«e©Ò¶}±Òªºtable»P´¿¸g¶}±ÒªºTABLE=>§¹¬üªº±¡ªp¤U¨âªÌÀ³¸Ó¬Û¦P¡AYOpened¶W¥X¤Ó¡A½Ð©ñ¤jtable_cache
Table_locks_immediate»PTable_locks_waited ³o²Õ¼Æ¦rÁô§t¤FSQLªº®Ä²v¡A§¹¬ü±¡ªp¬Owaited=0¡C ¦ý¬O¡A¤£¤Ó¥i¯à¡C ¦pªGwaitedªº¼Æ¦r«Ü°ª¬Æ¦Ü¤ñimmediateÁÙ°ª¡A´N·t¥Ü¤FSQL¼gªº¤£¦n
Thread_connected»PThreads_created created°ª¤Ó¦h´Nªí¥ÜCPU³£¦b·s¼WThread¡A¸ÕµÛÁYµuTime out®É¶¡
½Õ¾ã°Ñ¼Æ³Ì±`¥Îªº¤è¦¡¬O§ó§ïmy.cnf¡]³q±`¦b/etc¤U¡^ ¦ý¬On«·s±Ò°ÊMYSQL¤~·|¦³®Ä ¦pªG¬O¦b¶]±oDB¡A¦Ó¥B¤£¯àrestart ¡]´N¹³§Ú¤@¼Ë ¢I¢I¡^ ¨º´N¥u¯à¥Îset«ü¥O set global °Ñ¼Æ=È ¡]¤£¯à¥Î¤å¦r 1M = 1*1024*1024¡^ set global¬Oªí¥Ü®M¥Î¦b©Ò¦³ªºThread¤W set ·|§@¥Î¦b²{¦æªºThread¤W ¡]¦ý¬O§Ú¨S¿ìªk§ó§ïTIME OUT®É¶¡¡A¥L·|¦Û¤v¸õ¦^¥h¡AÁÙ¤£ª¾¹D¬°¤°»ò¡^
¤@¯ë¤ñ¸û±`§ó°Êªº·|¬Ologªº¥Ø¿ý»Pmax_connectÁÙ¦³ key_buffer ¦bºN¯Áªº®ÉÔ¡A°O±o¤@¦¸½Õ¾ã¤@ӰѼƴN¦n ¨Ã¯d¤U쥻ªº³]©wÀÉ¡A¥H¨¾¸U¤@¡C |
|
|
|
|
|
|