O que significam os tamanhos das unidades "tamanho do buffer de chave" e "índices MyISAM totais"?

O que significam os tamanhos das unidades "tamanho do buffer de chave" e "índices MyISAM totais"?

Executei o MySQLTuner em meu banco de dados para verificar se as coisas estão funcionando corretamente e de maneira ideal, mas fiquei confuso quanto às unidades usadas para esses dois valores.

Esta é a aparência do resultado das métricas de desempenho

-------- Performance Metrics -------------------------------------------------
[--] Up for: 2d 5h 11m 20s (47M q [249.471 qps], 45M conn, TX: 65B, RX: 8B)
[--] Reads / Writes: 79% / 21%
[--] Total buffers: 1.1G global + 2.7M per thread (300 max threads)
[!!] Maximum possible memory usage: 1.9G (198% of installed RAM)
[OK] Slow queries: 0% (43/47M)
[OK] Highest usage of available connections: 5% (17/300)
[OK] Key buffer size / total MyISAM indexes: 600.0M/128.0K
[OK] Key buffer hit rate: 100.0% (17K cached / 0 reads)
[OK] Query cache efficiency: 98.1% (46M cached / 47M selects)
[!!] Query cache prunes per day: 22728
[OK] Sorts requiring temporary tables: 0% (9 temp sorts / 65K sorts)
[!!] Joins performed without indexes: 2839
[OK] Temporary tables created on disk: 0% (235 on disk / 42K total)
[OK] Thread cache hit rate: 99% (79 created / 45M connections)
[!!] Table cache hit rate: 1% (400 open / 27K opened)
[OK] Open file limit used: 0% (0/1K)
[OK] Table locks acquired immediately: 100% (1M immediate / 1M locks)
[!!] Connections aborted: 99%
[!!] InnoDB data size / buffer pool: 6.5G/128.0M

Mas minha pergunta é sobre essa linha

[OK] Key buffer size / total MyISAM indexes: 600.0M/128.0K

Não sei o que significam as unidades ou quão diferentes elas são em tamanho. O que é 'M' e 'K'

Eu sei que o tamanho do meu buffer de chave deve ser maior que os índices MyISAM, mas não sei dizer se é porque não entendo as unidades. Procurei on-line, mas não consegui encontrar as respostas que procurava. Se alguém pudesse esclarecer isso para mim, eu realmente apreciaria.

Responder1

M é Megabytes, K é Kilobytes,

key_buffer_sizea configuração do MySQL está relacionada ao mecanismo MyISAM

Se você usar o mecanismo InnoDB para todas as suas tabelas, precisará apenas de um key_buffer_size pequeno (mas diferente de zero), e de um innodb_buffer_pool_size grande.

Eu recomendoesta página da webpois fornece respostas simples para coisas muito complexas, que é a otimização do MySQL. Então, se você não quer perder muito tempo e basta configurar para algo “relativamente bom”. Vá ali.

informação relacionada