Eu tenho o site Drupal, uma das tabelas é cache_form. eu tenho um cron para
DELETE FROM cache_form where expire < UNIX_TIMESTAMP(NOW());
que funciona bem.
O tamanho cache_form.myd
é de 4,9 G, embora eu tenha isso:
mysql>select sum(length(data))/1024/1204 from cache_form;
11.19144630 <b>==> 11 M
mysql>check table cache_form\G
Table: drupal.cache_form
Op: check
Msg_type: status
Msg_text: OK
mysql>select cid,length(data) from cache_form order by length(data) desc limit 1;
82373 ==> 80K
select * from information_schema.tables where table_name='cache_form'\G
*************************** 1. row ***************************
TABLE_CATALOG: NULL
TABLE_SCHEMA: drupal
TABLE_NAME: cache_form
TABLE_TYPE: BASE TABLE
ENGINE: MyISAM
VERSION: 10
ROW_FORMAT: Dynamic
TABLE_ROWS: 2681
AVG_ROW_LENGTH: 4621
DATA_LENGTH: 12391088 <b>==>11M</b>
MAX_DATA_LENGTH: 281474976710655
INDEX_LENGTH: 177152
DATA_FREE: 0
AUTO_INCREMENT: NULL
CREATE_TIME: 2011-07-11 19:07:38
UPDATE_TIME: 2011-12-26 08:40:09
CHECK_TIME: 2011-12-26 08:09:45
TABLE_COLLATION: utf8_general_ci
CHECKSUM: NULL
CREATE_OPTIONS:
TABLE_COMMENT:
ja tentei consertar
mysql> repair table cache_form;
+-------------------+--------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+-------------------+--------+----------+----------+
| drupal.cache_form | repair | status | OK |
+-------------------+--------+----------+----------+
então eu tenho o tamanho correto!!
Alguma ideia do que pode fazer com que o arquivo cache_form.myd fique com esse tamanho e a tabela de reparo finalmente removeu o espaço extra?
Obrigado
Quando se trata de uma tabela MyISAM, a exclusão de linhas aciona um tipo de coleta de lixo, pois todo o espaço não utilizado é registrado em uma lista encadeada.
O comprimento dos dados que você viu está correto. Seu cron job excluiu todas as linhas com menos de
UNIX_TIMESTAMP(NOW())
. Isso não fará com que a mesa encolha. Todas as linhas de exclusão são apenas encadeadas.Existem outras opções que você poderia ter escolhido para reduzir a tabela:
ALTER TABLE cache_form ENGINE=MyISAM;
OPTIMIZE TABLE cache_form;
A opção 1 simplesmente faz o seguinte
cache_form.MYD
.cache_form.MYI
.Naturalmente, a Opção 1 não copiará o espaço não utilizado.
A opção 2 executa a mesma operação que a opção 1 e, em seguida, executa
ANALYZE TABLE cache_form;
para calcular estatísticas de índice.A opção 3 seria simplesmente uma emulação da opção 1. Aqui está:
Sempre que você fez a compactação dessa maneira, descubra para que serve data_length
cache_form_new
. Isso lhe dará uma ideia de qual deve ser o tamanho real.