2013-08-13 3 views
0

mySQL innoDB 엔진에 문제가 있습니다.
"select * from posts"같은 SQL 문은 오랜 시간이 걸립니다.
이 내 MySQL을 구성한다 :mysql innoDB 성능

[mysql] 

# CLIENT # 
port       = 3306 
socket       = /var/lib/mysqld/mysqld.sock 

[mysqld_safe] 
socket   = /var/run/mysqld/mysqld.sock 
nice   = 0 

[mysqld] 

# GENERAL # 
user       = mysql 
#default_storage_engine   = InnoDB 
pid-file  = /var/run/mysqld/mysqld.pid 
socket   = /var/run/mysqld/mysqld.sock 
port   = 3306 
basedir   = /usr 
tmpdir   = /tmp 
lc-messages-dir = /usr/share/mysql 

bind-address   = 127.0.0.1 

# MyISAM # 
key_buffer_size    = 32M 
myisam_recover     = FORCE,BACKUP 

# SAFETY # 
max_allowed_packet    = 16M 
max_connect_errors    = 1000000 

# DATA STORAGE # 
datadir      = /var/lib/mysql/ 

# BINARY LOGGING # 
log_bin      = /var/lib/mysql/mysql-bin 
expire_logs_days    = 14 
sync_binlog     = 1 

# CACHES AND LIMITS # 
tmp_table_size     = 64M 
max_heap_table_size   = 64M 
query_cache_type    = 0 
query_cache_size    = 0 
max_connections    = 500 
thread_cache_size    = 50 
open_files_limit    = 65535 
table_definition_cache   = 1024 
table_open_cache    = 2048 
read_rnd_buffer_size   = 1M 
query_cache_type    = 1 

# INNODB # 
innodb_flush_method   = O_DIRECT 
innodb_log_files_in_group  = 2 
innodb_log_file_size   = 256M 
innodb_flush_log_at_trx_commit = 1 
innodb_file_per_table   = 1 
innodb_buffer_pool_size  = 4G 

# LOGGING # 
log_error      = /var/lib/mysql/mysql-error.log 
log_queries_not_using_indexes = 1 
slow_query_log     = 1 
slow_query_log_file   = /var/lib/mysql/mysql-slow.log 

은 SQL 문은 내가 부하 평균 ~ 2.0
할당 된 코어는 대부분 0.0 % 사용되어있어 실행되는 동안 ..

말해 iostat의 :

avg-cpu: %user %nice %system %iowait %steal %idle 
      0.39 0.00 0.26 5.15 0.04 94.16 

Device:   tps kB_read/s kB_wrtn/s kB_read kB_wrtn 
xvdap2   152.80  139.39  5550.51  567593 22601276 
xvdap1   0.04   0.21   0.00  836   0 

성능 향상을위한 아이디어가 있습니까?

Hardware (XEN guest) 
processor  : 0 
vendor_id  : GenuineIntel 
cpu family  : 6 
model   : 30 
model name  : Intel(R) Xeon(R) CPU   X3440 @ 2.53GHz 
stepping  : 5 
cpu MHz   : 2527.052 
cache size  : 8192 KB 
fpu    : yes 
fpu_exception : yes 
cpuid level  : 11 
wp    : yes 
flags   : fpu de tsc msr pae cx8 sep cmov pat clflush mmx fxsr sse sse2 ss ht syscall nx lm constant_tsc rep_good aperfmperf pni ssse3 cx16 sse4_1 sse4_2 popcnt hypervisor lahf_lm 
bogomips  : 5054.10 
clflush size : 64 
cache_alignment : 64 
address sizes : 36 bits physical, 48 bits virtual 
power management: 

processor  : 1 
vendor_id  : GenuineIntel 
cpu family  : 6 
model   : 30 
model name  : Intel(R) Xeon(R) CPU   X3440 @ 2.53GHz 
stepping  : 5 
cpu MHz   : 2527.052 
cache size  : 8192 KB 
fpu    : yes 
fpu_exception : yes 
cpuid level  : 11 
wp    : yes 
flags   : fpu de tsc msr pae cx8 sep cmov pat clflush mmx fxsr sse sse2 ss ht syscall nx lm constant_tsc rep_good aperfmperf pni ssse3 cx16 sse4_1 sse4_2 popcnt hypervisor lahf_lm 
bogomips  : 5054.10 
clflush size : 64 
cache_alignment : 64 
address sizes : 36 bits physical, 48 bits virtual 
power management: 

processor  : 2 
vendor_id  : GenuineIntel 
cpu family  : 6 
model   : 30 
model name  : Intel(R) Xeon(R) CPU   X3440 @ 2.53GHz 
stepping  : 5 
cpu MHz   : 2527.052 
cache size  : 8192 KB 
fpu    : yes 
fpu_exception : yes 
cpuid level  : 11 
wp    : yes 
flags   : fpu de tsc msr pae cx8 sep cmov pat clflush mmx fxsr sse sse2 ss ht syscall nx lm constant_tsc rep_good aperfmperf pni ssse3 cx16 sse4_1 sse4_2 popcnt hypervisor lahf_lm 
bogomips  : 5054.10 
clflush size : 64 
cache_alignment : 64 
address sizes : 36 bits physical, 48 bits virtual 
power management: 

processor  : 3 
vendor_id  : GenuineIntel 
cpu family  : 6 
model   : 30 
model name  : Intel(R) Xeon(R) CPU   X3440 @ 2.53GHz 
stepping  : 5 
cpu MHz   : 2527.052 
cache size  : 8192 KB 
fpu    : yes 
fpu_exception : yes 
cpuid level  : 11 
wp    : yes 
flags   : fpu de tsc msr pae cx8 sep cmov pat clflush mmx fxsr sse sse2 ss ht syscall nx lm constant_tsc rep_good aperfmperf pni ssse3 cx16 sse4_1 sse4_2 popcnt hypervisor lahf_lm 
bogomips  : 5054.10 
clflush size : 64 
cache_alignment : 64 
address sizes : 36 bits physical, 48 bits virtual 
power management: 

processor  : 4 
vendor_id  : GenuineIntel 
cpu family  : 6 
model   : 30 
model name  : Intel(R) Xeon(R) CPU   X3440 @ 2.53GHz 
stepping  : 5 
cpu MHz   : 2527.052 
cache size  : 8192 KB 
fpu    : yes 
fpu_exception : yes 
cpuid level  : 11 
wp    : yes 
flags   : fpu de tsc msr pae cx8 sep cmov pat clflush mmx fxsr sse sse2 ss ht syscall nx lm constant_tsc rep_good aperfmperf pni ssse3 cx16 sse4_1 sse4_2 popcnt hypervisor lahf_lm 
bogomips  : 5054.10 
clflush size : 64 
cache_alignment : 64 
address sizes : 36 bits physical, 48 bits virtual 
power management: 

processor  : 5 
vendor_id  : GenuineIntel 
cpu family  : 6 
model   : 30 
model name  : Intel(R) Xeon(R) CPU   X3440 @ 2.53GHz 
stepping  : 5 
cpu MHz   : 2527.052 
cache size  : 8192 KB 
fpu    : yes 
fpu_exception : yes 
cpuid level  : 11 
wp    : yes 
flags   : fpu de tsc msr pae cx8 sep cmov pat clflush mmx fxsr sse sse2 ss ht syscall nx lm constant_tsc rep_good aperfmperf pni ssse3 cx16 sse4_1 sse4_2 popcnt hypervisor lahf_lm 
bogomips  : 5054.10 
clflush size : 64 
cache_alignment : 64 
address sizes : 36 bits physical, 48 bits virtual 
power management: 

processor  : 6 
vendor_id  : GenuineIntel 
cpu family  : 6 
model   : 30 
model name  : Intel(R) Xeon(R) CPU   X3440 @ 2.53GHz 
stepping  : 5 
cpu MHz   : 2527.052 
cache size  : 8192 KB 
fpu    : yes 
fpu_exception : yes 
cpuid level  : 11 
wp    : yes 
flags   : fpu de tsc msr pae cx8 sep cmov pat clflush mmx fxsr sse sse2 ss ht syscall nx lm constant_tsc rep_good aperfmperf pni ssse3 cx16 sse4_1 sse4_2 popcnt hypervisor lahf_lm 
bogomips  : 5054.10 
clflush size : 64 
cache_alignment : 64 
address sizes : 36 bits physical, 48 bits virtual 
power management: 

meminfo 파일

MemTotal:  6146908 kB 
MemFree:   2231936 kB 
Buffers:   45436 kB 
Cached:   2542340 kB 
SwapCached:   0 kB 
Active:   2629024 kB 
Inactive:   915652 kB 
Active(anon):  956724 kB 
Inactive(anon): 46272 kB 
Active(file): 1672300 kB 
Inactive(file): 869380 kB 
Unevictable:   0 kB 
Mlocked:    0 kB 
SwapTotal:  2097144 kB 
SwapFree:  2097144 kB 
Dirty:   972812 kB 
Writeback:   1412 kB 
AnonPages:  956912 kB 
Mapped:   18048 kB 
Shmem:    46104 kB 
Slab:    144676 kB 
SReclaimable:  137764 kB 
SUnreclaim:   6912 kB 
KernelStack:  1136 kB 
PageTables:   7524 kB 
NFS_Unstable:   0 kB 
Bounce:    0 kB 
WritebackTmp:   0 kB 
CommitLimit:  5170596 kB 
Committed_AS: 4964188 kB 
VmallocTotal: 34359738367 kB 
VmallocUsed:  26032 kB 
VmallocChunk: 34359711292 kB 
HardwareCorrupted:  0 kB 
HugePages_Total:  0 
HugePages_Free:  0 
HugePages_Rsvd:  0 
HugePages_Surp:  0 
Hugepagesize:  2048 kB 
DirectMap4k:  6156288 kB 
DirectMap2M:   0 kB 

예 스키마 : documentation 2.에

CREATE TABLE IF NOT EXISTS Produkte` (
    id int(11) NOT NULL AUTO_INCREMENT, 
    uniqueID varchar(50) CHARACTER SET latin1 NOT NULL, 
    Link varchar(255) CHARACTER SET latin1 NOT NULL, 
    Title varchar(1000) CHARACTER SET latin1 NOT NULL, 
    foundTime varchar(100) CHARACTER SET latin1 NOT NULL, 
    Desc text CHARACTER SET latin1 NOT NULL, 
    Rank int(11) NOT NULL DEFAULT '10000000', 
    PRIMARY KEY (id), 
    UNIQUE KEY uniqueID (uniqueID) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC AUTO_INCREMENT=9407809 ; 
+0

Linux에서는 일반적으로 디스크로드가 높을수록 CPU 사용량이 적습니다. –

+0

'posts' 테이블의 크기는 얼마이며, 전체 DB는 버퍼 풀 크기 4G보다 큽니다. 캐싱되지 않은 대형 테이블에서 많은 것을 읽는 것일 수도 있고 전체 테이블을 읽는 대신 행이나 범위 또는 행을 대상으로하도록 쿼리를 변경해야 할 수도 있습니다. –

+0

이 질문은 관련 데이터베이스 테이블 스키마에 대한 지식이 없으면 대답 할 수 없습니다. (예 : 인덱스가 없기 때문에 선택이 느린 것 같습니다.) –

답변

0

보십시오 변화 innodb_flush_log_at_trx_commit :

당신은 다른 값을 설정하여 더 나은 성능을 달성 할 수 1,하지만 최대 1 초의 트랜스를 잃을 수 있습니다. 충돌시의 행동.

+1

은 선택입니다. innodb_flush_log_at_trx_commit과 아무 관련이 없습니다 ... –