Я пытаюсь выполнить массовую загрузку около 12 м записей в таблицу InnoDB в (локальном) mysql с помощью LOAD DATA INFILE (из CSV) и обнаружил, что для его завершения требуется очень много времени.
Первичныйтип ключа - UUID, а ключи не отсортированы в файлах данных.
Я разбил файл данных на файлы, содержащие 100000 записей, и импортировал его как:
mysql -e 'ALTER TABLE customer DISABLE KEYS;'
for file in *.csv
mysql -e "SET sql_log_bin=0;SET FOREIGN_KEY_CHECKS=0; SET UNIQUE_CHECKS=0;
SET AUTOCOMMIT=0;LOAD DATA INFILE '${file}' INTO TABLE table
FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n'; COMMIT"
Это прекрасно работает дляпервые несколько сотен тысяч записей, но затем время вставки для каждой последующей загрузки, похоже, продолжает расти (с примерно 7 секунд до примерно 2 минут на загрузку, прежде чем я ее отключил).
Я работаю на машине с8 ГБ ОЗУ и для параметров InnoDB:
innodb_buffer_pool_size =1024M
innodb_additional_mem_pool_size =512M
innodb_log_file_size = 256M
innodb_log_buffer_size = 256M
Я также попытался загрузить один CSV, содержащий все строки, но безуспешно - это работало более 2 часов, прежде чем я его убил.
Есть ли что-нибудь еще, что могло бы ускорить это, так как это кажется чрезмерным временем для загрузки только 12-метровых записей?