Norn Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 Столкнулся с проблемой умирания opencart 3x. На базовом шаблоне (эти запросы зависают в бд). Warning: mysqli::__construct(): (HY000/1226): User 'db_name' has exceeded the 'max_user_connections' resource (current value: 45) in ../www/system/library/db/mysqli.php on line 7Warning: DB\MySQLi::__construct(): Couldn't fetch mysqli in.../www/system/library/db/mysqli.php on line 10Warning: SELECT p.product_id, (SELECT AVG(rating) AS total FROM oc_review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT price FROM oc_product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '1' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM oc_product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '1' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special FROM oc_category_path cp LEFT JOIN oc_product_to_category p2c ON (cp.category_id = p2c.category_id) LEFT JOIN oc_product p ON (p2c.product_id = p.product_id) LEFT JOIN oc_product_description pd ON (p.product_id = pd.product_id) LEFT JOIN oc_product_to_store p2s ON (p.product_id = p2s.product_id) WHERE pd.language_id = '2' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '0' AND cp.path_id = '129' GROUP BY p.product_id ORDER BY p.date_added DESC, LCASE(pd.name) DESC LIMIT 0,20 SELECT COUNT(DISTINCT p.product_id) AS total FROM oc_category_path cp LEFT JOIN oc_product_to_category p2c ON (cp.category_id = p2c.category_id) LEFT JOIN oc_product p ON (p2c.product_id = p.product_id) LEFT JOIN oc_product_description pd ON (p.product_id = pd.product_id) LEFT JOIN oc_product_to_store p2s ON (p.product_id = p2s.product_id) WHERE pd.language_id = '2' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '0' AND cp.path_id = '157 Кто-то сталкивался с таким? Как можно оптимизировать запросы? Надіслати Поділитися на інших сайтах More sharing options...
snastik Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 У вас не в запросах проблема. А в количестве max_user_connections. Необходимо увеличить этот параметр. Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 32 минуты назад, snastik сказал: А в количестве max_user_connections. Сколько посетителей? А может быть это какой-то модуль делает подключение какждый раз получая данные, в обход стандартных методов 2 Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 юзеров всего 30-50 за день Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 Просто такой же сайт с такими же запросами, не вызывает проблема на хостинге. А тут просто умирают запросы и висят в бд. Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 1 час назад, Norn сказал: не вызывает проблема на хостинге. На этом же хостингге? Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 5 hours ago, chukcha said: На этом же хостингге? Да, на этом(как демка идет). Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 отличия в модулях? Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 все тоже, просто на демо сайте 200 товаров, а на "продакшене" 2300 товаров Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 20 травня 2019 Автор Share Опубліковано: 20 травня 2019 Разве должен быть такой запрос в бд по продукту $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND pr.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'"); ??? Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 А какой должен быть? Надіслати Поділитися на інших сайтах More sharing options... 100napb Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 (змінено) On 5/16/2019 at 5:11 PM, Norn said: А тут просто умирают запросы и висят в бд. On 5/16/2019 at 4:51 PM, Norn said: юзеров всего 30-50 за день стоит попробовать в конфиг mysql добавить два параметра: wait_timeout = 90 interactive_timeout = 90 по истечению этих таймаутов неактивные коннекты к базе будут отключаться, освобождая место новым. Даже на достаточно нагруженных ИМ на опенкарте кол-во активных подключений к базе не очень-то и большое. Ясное дело, что все индивидуально, но я не раз встречал ИМ на ОС с более 1к уников в день и максимальным кол-вом используемых коннектов к базе в районе 13-15 Змінено 20 травня 2019 користувачем 100napb Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Opencart 3.x Opencart 3.x: Загальні питання Запросы в Бд opecanrt 3 Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень API каталогу розширень Вирішення спорів щодо авторських прав Корисна інформація Публічна оферта Політика повернень Політика конфіденційності Платіжна політика Політика передачі особистих даних Політика прозорості Останні розширення Повний пакет SEO Автор: GeekoDev SameSite Session Fix Opencart 3 Автор: web_bond SP Telegram повідомлення FREE Автор: spectre Відключити порожні категорії Автор: spectre SEO Автор тексту категорії / фільтра / блогу з датою оновлення контенту + мікророзмітка Автор: radaevich × Уже зареєстровані? Ввійти Реєстрація Ваші замовлення Назад Придбані модулі та шаблони Ваші рахунки Лист очікувань Альтернативні контакти Форум Новини ocStore Назад Офіційний сайт Демо ocStore 3.0.3.2 Демо ocStore 2.3.0.2.4 Завантажити ocStore Документація Історія версій ocStore Блоги Модулі Шаблони Назад Безкоштовні шаблони Платні шаблони Де купувати модулі? Послуги FAQ OpenCart.Pro Назад Демо Купити Порівняння × Створити... Important Information На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність. Я даю згоду
chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 32 минуты назад, snastik сказал: А в количестве max_user_connections. Сколько посетителей? А может быть это какой-то модуль делает подключение какждый раз получая данные, в обход стандартных методов 2 Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 юзеров всего 30-50 за день Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 Просто такой же сайт с такими же запросами, не вызывает проблема на хостинге. А тут просто умирают запросы и висят в бд. Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 1 час назад, Norn сказал: не вызывает проблема на хостинге. На этом же хостингге? Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 5 hours ago, chukcha said: На этом же хостингге? Да, на этом(как демка идет). Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 отличия в модулях? Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 все тоже, просто на демо сайте 200 товаров, а на "продакшене" 2300 товаров Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 20 травня 2019 Автор Share Опубліковано: 20 травня 2019 Разве должен быть такой запрос в бд по продукту $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND pr.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'"); ??? Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 А какой должен быть? Надіслати Поділитися на інших сайтах More sharing options... 100napb Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 (змінено) On 5/16/2019 at 5:11 PM, Norn said: А тут просто умирают запросы и висят в бд. On 5/16/2019 at 4:51 PM, Norn said: юзеров всего 30-50 за день стоит попробовать в конфиг mysql добавить два параметра: wait_timeout = 90 interactive_timeout = 90 по истечению этих таймаутов неактивные коннекты к базе будут отключаться, освобождая место новым. Даже на достаточно нагруженных ИМ на опенкарте кол-во активных подключений к базе не очень-то и большое. Ясное дело, что все индивидуально, но я не раз встречал ИМ на ОС с более 1к уников в день и максимальным кол-вом используемых коннектов к базе в районе 13-15 Змінено 20 травня 2019 користувачем 100napb Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Opencart 3.x Opencart 3.x: Загальні питання Запросы в Бд opecanrt 3 Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень API каталогу розширень Вирішення спорів щодо авторських прав Корисна інформація Публічна оферта Політика повернень Політика конфіденційності Платіжна політика Політика передачі особистих даних Політика прозорості Останні розширення Повний пакет SEO Автор: GeekoDev SameSite Session Fix Opencart 3 Автор: web_bond SP Telegram повідомлення FREE Автор: spectre Відключити порожні категорії Автор: spectre SEO Автор тексту категорії / фільтра / блогу з датою оновлення контенту + мікророзмітка Автор: radaevich × Уже зареєстровані? Ввійти Реєстрація Ваші замовлення Назад Придбані модулі та шаблони Ваші рахунки Лист очікувань Альтернативні контакти Форум Новини ocStore Назад Офіційний сайт Демо ocStore 3.0.3.2 Демо ocStore 2.3.0.2.4 Завантажити ocStore Документація Історія версій ocStore Блоги Модулі Шаблони Назад Безкоштовні шаблони Платні шаблони Де купувати модулі? Послуги FAQ OpenCart.Pro Назад Демо Купити Порівняння × Створити... Important Information На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність. Я даю згоду
Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 юзеров всего 30-50 за день Надіслати Поділитися на інших сайтах More sharing options...
Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 Просто такой же сайт с такими же запросами, не вызывает проблема на хостинге. А тут просто умирают запросы и висят в бд. Надіслати Поділитися на інших сайтах More sharing options...
chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 1 час назад, Norn сказал: не вызывает проблема на хостинге. На этом же хостингге? Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 5 hours ago, chukcha said: На этом же хостингге? Да, на этом(как демка идет). Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 отличия в модулях? Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 все тоже, просто на демо сайте 200 товаров, а на "продакшене" 2300 товаров Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 20 травня 2019 Автор Share Опубліковано: 20 травня 2019 Разве должен быть такой запрос в бд по продукту $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND pr.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'"); ??? Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 А какой должен быть? Надіслати Поділитися на інших сайтах More sharing options... 100napb Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 (змінено) On 5/16/2019 at 5:11 PM, Norn said: А тут просто умирают запросы и висят в бд. On 5/16/2019 at 4:51 PM, Norn said: юзеров всего 30-50 за день стоит попробовать в конфиг mysql добавить два параметра: wait_timeout = 90 interactive_timeout = 90 по истечению этих таймаутов неактивные коннекты к базе будут отключаться, освобождая место новым. Даже на достаточно нагруженных ИМ на опенкарте кол-во активных подключений к базе не очень-то и большое. Ясное дело, что все индивидуально, но я не раз встречал ИМ на ОС с более 1к уников в день и максимальным кол-вом используемых коннектов к базе в районе 13-15 Змінено 20 травня 2019 користувачем 100napb Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Opencart 3.x Opencart 3.x: Загальні питання Запросы в Бд opecanrt 3 Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень API каталогу розширень Вирішення спорів щодо авторських прав Корисна інформація Публічна оферта Політика повернень Політика конфіденційності Платіжна політика Політика передачі особистих даних Політика прозорості Останні розширення Повний пакет SEO Автор: GeekoDev SameSite Session Fix Opencart 3 Автор: web_bond SP Telegram повідомлення FREE Автор: spectre Відключити порожні категорії Автор: spectre SEO Автор тексту категорії / фільтра / блогу з датою оновлення контенту + мікророзмітка Автор: radaevich
Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 5 hours ago, chukcha said: На этом же хостингге? Да, на этом(как демка идет). Надіслати Поділитися на інших сайтах More sharing options...
chukcha Опубліковано: 16 травня 2019 Share Опубліковано: 16 травня 2019 отличия в модулях? Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 все тоже, просто на демо сайте 200 товаров, а на "продакшене" 2300 товаров Надіслати Поділитися на інших сайтах More sharing options... Norn Опубліковано: 20 травня 2019 Автор Share Опубліковано: 20 травня 2019 Разве должен быть такой запрос в бд по продукту $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND pr.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'"); ??? Надіслати Поділитися на інших сайтах More sharing options... chukcha Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 А какой должен быть? Надіслати Поділитися на інших сайтах More sharing options... 100napb Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 (змінено) On 5/16/2019 at 5:11 PM, Norn said: А тут просто умирают запросы и висят в бд. On 5/16/2019 at 4:51 PM, Norn said: юзеров всего 30-50 за день стоит попробовать в конфиг mysql добавить два параметра: wait_timeout = 90 interactive_timeout = 90 по истечению этих таймаутов неактивные коннекты к базе будут отключаться, освобождая место новым. Даже на достаточно нагруженных ИМ на опенкарте кол-во активных подключений к базе не очень-то и большое. Ясное дело, что все индивидуально, но я не раз встречал ИМ на ОС с более 1к уников в день и максимальным кол-вом используемых коннектов к базе в районе 13-15 Змінено 20 травня 2019 користувачем 100napb Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Opencart 3.x Opencart 3.x: Загальні питання Запросы в Бд opecanrt 3
Norn Опубліковано: 16 травня 2019 Автор Share Опубліковано: 16 травня 2019 все тоже, просто на демо сайте 200 товаров, а на "продакшене" 2300 товаров Надіслати Поділитися на інших сайтах More sharing options...
Norn Опубліковано: 20 травня 2019 Автор Share Опубліковано: 20 травня 2019 Разве должен быть такой запрос в бд по продукту $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND pr.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'"); ??? Надіслати Поділитися на інших сайтах More sharing options...
chukcha Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 А какой должен быть? Надіслати Поділитися на інших сайтах More sharing options... 100napb Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 (змінено) On 5/16/2019 at 5:11 PM, Norn said: А тут просто умирают запросы и висят в бд. On 5/16/2019 at 4:51 PM, Norn said: юзеров всего 30-50 за день стоит попробовать в конфиг mysql добавить два параметра: wait_timeout = 90 interactive_timeout = 90 по истечению этих таймаутов неактивные коннекты к базе будут отключаться, освобождая место новым. Даже на достаточно нагруженных ИМ на опенкарте кол-во активных подключений к базе не очень-то и большое. Ясное дело, что все индивидуально, но я не раз встречал ИМ на ОС с более 1к уников в день и максимальным кол-вом используемых коннектов к базе в районе 13-15 Змінено 20 травня 2019 користувачем 100napb Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку
100napb Опубліковано: 20 травня 2019 Share Опубліковано: 20 травня 2019 (змінено) On 5/16/2019 at 5:11 PM, Norn said: А тут просто умирают запросы и висят в бд. On 5/16/2019 at 4:51 PM, Norn said: юзеров всего 30-50 за день стоит попробовать в конфиг mysql добавить два параметра: wait_timeout = 90 interactive_timeout = 90 по истечению этих таймаутов неактивные коннекты к базе будут отключаться, освобождая место новым. Даже на достаточно нагруженных ИМ на опенкарте кол-во активных подключений к базе не очень-то и большое. Ясное дело, что все индивидуально, но я не раз встречал ИМ на ОС с более 1к уников в день и максимальным кол-вом используемых коннектов к базе в районе 13-15 Змінено 20 травня 2019 користувачем 100napb Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0
Recommended Posts