IMDBOptimizer (OC 1.5) - Оптимизация базы данных

IMDBOptimizer (OC 1.5) - Оптимизация базы данных

IMDBOptimizer - Оптимизация базы данных OpenCart 1.5

Все просто! Бекап базы -> Выбрать таблицы -> Нажать Генерировать -> ВСЕ!!!


подробнее ...
Цена
450р.
Загружен: 02.10.2017
devimirochnik Россия портфолио
Товаров: Рейтинг: Продаж:
Название файла Имя файла Дата Действие
IMDBOptimizer(1.5).zip IMDBOptimizer(1.5).zip 2017-10-02 14:10:21 Платный файл
* Возможность скачивания появится после покупки

IMDBOptimizer (OC 1.5) - Оптимизация базы данных

Найти версию для OpenCart 2.0 - 2.2 можно тут:

http://shop.opencart-russia.ru/imdboptimizer

Найти версию для OpenCart 2.3 можно тут:

http://shop.opencart-russia.ru/imdboptimizer23


Оптимизация базы данных интернет-магазина — это весьма непростой вопрос, порой требующий отдельных исследований.
И самое неприятное в этом процессе заключается в том, что сделать хоть какую-то оптимизацию может только тот, кто знает sql-запросы и разбирается в базах данных (БД).

Есть и еще один неприятный момент. По умолчанию, не считая просто необходимых индексов, в базе данных опенкарта попросту не хватает индексов даже для всех полей с идентификаторами. Хотя это является одной из базовых рекомендаций при проектировании любых БД.

Для тех, кто не совсем представляет в чем суть, приведу простой пример.

Допустим, у вас есть 1000 записей в таблице и вам нужно найти по какому-то полю предпоследнюю запись (при этом каждое значение в поле уникально). В случае, если для этого поля не будет создано индекса в базе данных, то чтобы найти запись mysql придется проверить 999 записей. Если же индекс будет создан, то mysql потребуется не более 10 сравнений.

Если же поле неуникально (то есть у разных записей может встречаться одно и то же значение), то создание индекса так же может сократить время поиска. Допустим, та же самая ситуация - 1000 записей и вам нужно найти предпоследнюю. Так же считаем, что в среднем каждое значение поля повторяется 10 раз. Без индекса — все по прежнему — 999 проверок. С индексом, даже в худшем случае будет 17 сравнений (7 поиск по индексу и 10 поиск среди похожих записей). 

Примечание: Во второй ситуации поиск по индексу происходит быстрее (7 вместо 10), так групп записей всего 100 (1000 разделить на 10). Немного упрощая, максимальное количество сравнений рассчитывается по формуле двоичного логарифма от исходного количества log2 от 100 примерно равно 7.

Модуль уже содержит настройки для проведения базовой оптимизации базы данных, так что с этой задачей справится даже новичок (более подробное описание представлено ниже).

Так, например, в чистом OpenCart 1.5.6.4 было создано 208!!!! индексов. Даже обладая всеми необходимыми знаниями, проверить и создать такое количество индексов — весьма длительная рутинная задача. Что же говорить про остальных?

Кроме того, модуль так же позволяет просматривать все существующие индексы в БД для выбранных таблиц (кнопка «Показать данные таблиц!»), что нередко облегчает анализ и оптимизацию, так как нет необходимости настраивать доступ к phpMyAdmin, создавать пользователей, вручную вводить sql-запросы и прочее.

Демо модуля

Демо админки (demo/demo)
 

Статьи про модуль или просто полезные материалы:

1. Что такое индексы базы данных (для начинающих)?

2. Индексы и немного хитрой математики

3. Тестируем IMDBOptimizer для 2000 и 5500 товаров

 

Для тех, кому нужна только базовая оптимизация


Если вы не планируете сами вносить дополнительные индексы (или же оставите это тем, кто в этом разбирается), то, как уже говорил, модуль содержит настройки по умолчанию для базовой оптимизации БД.

Важно! Учтите, что операция весьма длительная и что требуется минимальная нагрузка в базе данных (то есть, желательно, чтобы пользователей сайта вообще не было или их было немного). В крайнем случае, вы можете создавать индексы по одной таблице отдельно, а не все скопом.

1. Сделайте бэкап всей базы данных! Это важно!
2. Откройте модуль
3. Выберите все таблицы (можно щелкнуть по ссылке «Выделить всё»)
4. Чуть ниже, щелкните по кнопке «Генерировать!»
5. Откиньтесь на спинку кресла и наблюдайте как модуль создает индексы

Несколько щелчков мыши и у вас проведена базовая оптимизация базы данных!

Профилактика

Для профилактики, необходимо запускать генерацию после установки любых других модулей, которые создают свои таблицы (не всегда в них имеются все необходимые индексы).

Индексы создаются самые простые без ограничений, так что в таблицах модулей не будет нарушена какая-либо логика (только если модуль не будет в последствии добавлять индексы без проверок, но обычно это редкость).

Блок с именами

Для настройки автоматического поиска и создания одиночных индексов, рядом с блоком таблиц есть три поля, где можно указывать конкретные имена полей, их начало или окончание (через запятую). 

Стоит понимать, что они действуют по правилу ИЛИ. То есть если поле таблицы указано среди конкретных полей ИЛИ начинается с одного из указанных префиксов ИЛИ заканчивается на одном из указанных окончаний, то для поля в текущей таблице будет создан индекс. 

Например:

Конкретные поля:
product_id, language_id

Префиксы:
stat, col

Окончания:
_id

При таких настройках, индекс для поля «product_option_value_id» будет создан (если его нет в таблице), так как поле заканчивается на «_id»


Карта индексов

В данном блоке можно составлять конкретные индексы, которые необходимо создать. Важно, что таблица каждого правила должна быть выбрана в списке таблиц. Иначе индекс не будет проверен или создан. 

Правила составляются по следующему принципу: 

Имя таблицы - Поле (, Поле)


Где имя таблицы может быть как указано с общим префиксом БД, так и вместо префикса можно использовать символ #, который будет автоматически заменен на префикс. Чтобы создать индексы из нескольких полей, их необходимо перечислить через запятую.

Например:

#product_description - language_id, product_id


В данном случае будет создан индекс (language_id, product_id) для таблицы oc_product_description (если такового индекса не было в таблице).

Особенности и ограничения

1. Важно учитывать, что генерация индексов происходит для каждой таблицы отдельно. То есть для каждой таблицы отдельно посылается AJAX-запрос. Это связано с тем, что для больших таблиц создание одного индекса может быть весьма длительной операцией. Поэтому, если вы запустили генерацию, то просто дождитесь, когда рядом с кнопками появится сообщение, что генерация завершена.
2. Создаются только обычные индексы. 
3. Если не существует указанных таблиц или полей, то указанные данные будут просто игнорироваться. 
4. В БД проверяются только те таблицы, которые начинаются с префикса копии опенкарта (Сделано для тех, кто использует в одной БД несколько сайтов)
5. Пользователь должен иметь полные права для получения доступа к БД (или достаточные для получения метаданных и создания индексов)
6. Оптимизация производится для БД MySQL
7. Имена создаваемых индексов имеют технические названия (техническое ограничение автоматизации)
8. Если существует идентичный по полям индекс, то ничего не будет происходить.
9. Требуется boostrap и jquery

Установка, следующие версии и использование

1. Распакуйте в корень сайта содержимое (каталоги admin и system)
2. Откройте админку и установите модуль (если это следующая версия, то переустановите)
3. Обновите модификаторы
4. Откройте в админке модуль (редактирование)

Лицензия и использование

Сделано для версий OpenCart 1.5.4 и 1.5.6.4, ocStore 1.5.1.3, 1.5.5.1.2
Лицензия распространяется только для одного сайта. Т.е. 1 домен = 1 оплата.
Купив модуль вы автоматически соглашаетесь с текстом лицензии.
Модуль имеет принцип распространения "as is" ("Как есть").
 
В течении 5 дней действует демо-период (автоматически активируется после установки). После этого или до этого необходимо ввести лицензионный ключ (состоит из двух частей).
Ключи необходимо вводить так, как они были присланы, без лишних пробелов и символов.
Если вы приобрели модуль до введения лицензирования, то вам необходимо написать мне и указать при этом доменное имя сайта и тестовый домен, если таковой имеется (учтите, что тестовый домен должен быть тестовым, то есть поддоменом какого-либо сайта).
Если у вас русский домен, то необходимо указывать то имя, которое указано в config.php в корне сайта.

IMDBOptimizer (OC 1.5) - Оптимизация базы данных IMDBOptimizer (OC 1.5) - Оптимизация базы данных

Написать отзыв

* Выполните Вход в свой аккаунт, для получения возможности оставить отзыв о товаре.

Оставить комментарий



Примечание: HTML разметка не поддерживается! Используйте обычный текст.

Введите код, указанный на картинке: