Masalah:
Kami memiliki situs sosial di mana anggota dapat menilai satu sama lain untuk kompatibilitas atau pencocokan. user_match_ratingsTabel ini berisi lebih dari 220 juta baris (9 pertunjukan data atau hampir 20 pertunjukan dalam indeks). Kueri terhadap tabel ini secara rutin muncul di slow.log (ambang> 2 detik) dan merupakan kueri lambat yang paling sering dicatat dalam sistem:
Query_time: 3 Lock_time: 0 Rows_sent: 3 Rows_examined: 1051
"select rating, count(*) as tally from user_match_ratings where rated_user_id = 395357 group by rating;"
Query_time: 4 Lock_time: 0 Rows_sent: 3 Rows_examined: 1294
"select rating, count(*) as tally from user_match_ratings where rated_user_id = 4182969 group by rating;"
Query_time: 3 Lock_time: 0 Rows_sent: 3 Rows_examined: 446
"select rating, count(*) as tally from user_match_ratings where rated_user_id = 630148 group by rating;"
Query_time: 5 Lock_time: 0 Rows_sent: 3 Rows_examined: 3788
"select rating, count(*) as tally from user_match_ratings where rated_user_id = 1835698 group by rating;"
Query_time: 17 Lock_time: 0 Rows_sent: 3 Rows_examined: 4311
"select rating, count(*) as tally from user_match_ratings where rated_user_id = 1269322 group by rating;"
Versi MySQL:
- versi protokol: 10
- versi: 5.0.77-log
- versi bdb: Perangkat Lunak Sleepycat: Berkeley DB 4.1.24: (29 Januari 2009)
- mesin kompilasi versi: x86_64 version_compile_os: redhat-linux-gnu
Info tabel:
SHOW COLUMNS FROM user_match_ratings;
Memberi:
╔═══════════════╦════════════╦════╦═════╦════════╦════════════════╗
║ id ║ int(11) ║ NO ║ PRI ║ NULL ║ auto_increment ║
║ rater_user_id ║ int(11) ║ NO ║ MUL ║ NULL ║ ║
║ rated_user_id ║ int(11) ║ NO ║ MUL ║ NULL ║ ║
║ rating ║ varchar(1) ║ NO ║ ║ NULL ║ ║
║ created_at ║ datetime ║ NO ║ ║ NULL ║ ║
╚═══════════════╩════════════╩════╩═════╩════════╩════════════════╝
Permintaan sampel:
select * from mutual_match_ratings where id=221673540;
memberi:
╔═══════════╦═══════════════╦═══════════════╦════════╦══════════════════════╗
║ id ║ rater_user_id ║ rated_user_id ║ rating ║ created_at ║
╠═══════════╬═══════════════╬═══════════════╬════════╬══════════════════════╣
║ 221673540 ║ 5699713 ║ 3890950 ║ N ║ 2013-04-09 13:00:38 ║
╚═══════════╩═══════════════╩═══════════════╩════════╩══════════════════════╝
Indeks
Tabel ini memiliki 3 indeks yang diatur:
- indeks tunggal aktif
rated_user_id - indeks komposit pada
rater_user_iddancreated_at - indeks komposit pada
rated_user_iddanrater_user_id
tampilkan indeks dari user_match_ratings;
memberi:
╔════════════════════╦════════════╦═══════════════════════════╦══════════════╦═══════════════╦═══════════╦═════════════╦══════════╦════════╦═════════════════════════╦════════════╦══════════════════╗
║ Table ║ Non_unique ║ Key_name ║ Seq_in_index ║ Column_name ║ Collation ║ Cardinality ║ Sub_part ║ Packed ║ Null ║ Index_type ║ Comment ║
╠════════════════════╬════════════╬═══════════════════════════╬══════════════╬═══════════════╬═══════════╬═════════════╬══════════╬════════╬═════════════════════════╬════════════╬══════════════════╣
║ user_match_ratings ║ 0 ║ PRIMARY ║ 1 ║ id ║ A ║ 220781193 ║ NULL ║ NULL ║ BTREE ║ ║ ║
║ user_match_ratings ║ 1 ║ user_match_ratings_index1 ║ 1 ║ rater_user_id ║ A ║ 11039059 ║ NULL ║ NULL ║ BTREE ║ ║ ║
║ user_match_ratings ║ 1 ║ user_match_ratings_index1 ║ 2 ║ created_at ║ A ║ 220781193 ║ NULL ║ NULL ║ BTREE ║ ║ ║
║ user_match_ratings ║ 1 ║ user_match_ratings_index2 ║ 1 ║ rated_user_id ║ A ║ 4014203 ║ NULL ║ NULL ║ BTREE ║ ║ ║
║ user_match_ratings ║ 1 ║ user_match_ratings_index2 ║ 2 ║ rater_user_id ║ A ║ 220781193 ║ NULL ║ NULL ║ BTREE ║ ║ ║
║ user_match_ratings ║ 1 ║ user_match_ratings_index3 ║ 1 ║ rated_user_id ║ A ║ 2480687 ║ NULL ║ NULL ║ BTREE ║ ║ ║
╚════════════════════╩════════════╩═══════════════════════════╩══════════════╩═══════════════╩═══════════╩═════════════╩══════════╩════════╩═════════════════════════╩════════════╩══════════════════╝
Bahkan dengan indeks permintaan ini lambat.
Pertanyaan saya:
Apakah memisahkan tabel / data ini ke database lain di server yang memiliki ram cukup untuk menyimpan data ini dalam memori akankah ini mempercepat pertanyaan ini? Apakah ada hal lain yang mengatur tabel / indeks yang dapat kita tingkatkan untuk membuat kueri ini lebih cepat?
Saat ini kami memiliki memori 16GB; namun kami sedang mencari cara meningkatkan mesin yang ada ke 32GB atau menambahkan mesin baru dengan setidaknya sebanyak itu, mungkin solid state drive juga.
SELECT QUERY. Tolong sarankan? PS Pertanyaan Anda memaksa saya untuk bergabung dengan komunitas ini (y);)