Оптимизация производительности информационных систем




Принцип обмена данными из 1С с сайтом (на MySQL) и выдачи (публикации) этих данных по запросу.
PHP-Скрипт автоматической загрузки данных из файла данных в формате CSV в базу данных сайта работающего на WordPress.

В продолжение моей темы: 1С:Альфа-Авто Автосалон Автосервис: обмен с сайтом.
С помощью данного скрипта можно загружать в автоматическом режиме, по расписанию, данные сервисных книжек (ремонтов авто) из 1С:Альфа-Авто Автосалон Автосервис.
Также можно загружать данные в ручном режиме: для этого делается скрытая страница, где размещается специальная кнопка.
Комментарии размещенные внутри скрипта разъяснят логику и порядок действия.
Комментарии с "/////    echo" использовались для отладки.
Дополнительно создана таблица для журналирования результатов загрузки данных.
Скрипт включает в себя защиту от SQL инъекций (думаю безопасность соблюдена в полной мере).
В кратце:
1. Пишется скрипт, который запускает этот.
2. Создается регламентное задание в WordPress, по которому запускается скрипт из п.1. 
3. Этот скрипт осуществляет проверку на существование файла обмена в папке.
4. Если данные не новые, загрузка не производится.
5. Если данные новые, очищается таблица сервисных книжек.
6. Загружаются новые данные.

Собственно сам скрипт:

<?php // Полная загрузка сервисных книжек, создан 2025-01-05 12:44:55

global $wpdb2;
global $failure;
global $file_hist;

/////  echo '<H2><b>Старт загрузки</b></H2><br>';

$failure=FALSE;
//подключаемся к базе
$wpdb2 = include_once 'connection.php'; ; // подключаемся к MySQL
// если не удалось подключиться, и нужно оборвать PHP с сообщением об этой ошибке
if (!empty($wpdb2->error))
{
/////   echo '<H2><b>Ошибка подключения к БД, завершение.</b></H2><br>';
$failure=TRUE;
wp_die( $wpdb2->error );
}

$m_size_file=0;
$m_mtime_file=0;
$m_comment='';
/////проверка существования файлов выгрузки из 1С
////файл выгрузки сервисных книжек
$file_hist = ABSPATH.'/_1c_alfa_exchange/AA_hist.csv';
if (!file_exists($file_hist))
{
/////   echo '<H2><b>Файл обмена с сервисными книжками не существует.</b></H2><br>';
$m_comment='Файл обмена с сервисными книжками не существует';
$failure=TRUE;
}

/////инициируем таблицу лога
/////если не существует файла то возврат и ничего не делаем
if ($failure){
///включает защиту от SQL инъекций и данные можно передавать как есть, например: $_GET['foo']
/////   echo '<H2><b>Попытка вставить запись в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>$m_comment));
wp_die();
/////    echo '<H2><b>Возврат в начало.</b></H2><br>';
return $failure;
}
/////проверка лога загрузки, что бы не загружать тоже самое
$masiv_data_file=stat($file_hist);   ////передаем в массив свойство файла
$m_size_file=$masiv_data_file[7];    ////получаем размер файла
$m_mtime_file=$masiv_data_file[9];   ////получаем дату модификации файла
////создаем запрос на получение последней удачной загрузки
////выбираем по штампу времени создания (редактирования) файла загрузки AA_hist.csv, $m_mtime_file

/////   echo '<H2><b>Размер файла: '.$m_size_file.'</b></H2><br>';
/////   echo '<H2><b>Штамп времени файла: '.$m_mtime_file.'</b></H2><br>';
/////   echo '<H2><b>Формирование запроса на выборку из лога</b></H2><br>';
////препарируем запрос
$text_zaprosa=$wpdb2->prepare("SELECT * FROM `vin_logs` WHERE `last_mtime_upload` = %s", $m_mtime_file);
$results=$wpdb2->get_results($text_zaprosa);

if ($results)
{   foreach ( $results as $r)
{
////если штамп времени и размер файла совпадают, возврат
if (($r->last_mtime_upload==$m_mtime_file) && ($r->last_size_upload==$m_size_file))
{////echo '<H2><b>Возврат в начало, т.к. найдена запись в логе.</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>'Загрузка отменена, новых данных нет, т.к. найдена запись в логе.'));
wp_die();
return $failure;
}
}
}
////если данные новые, пишем в лог запись о начале загрузки
/////echo '<H2><b>Попытка вставить запись о начале загрузки в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>0, 'last_size_upload'=>$m_size_file, 'comment'=>'Начало загрузки'));

////очищаем таблицу
$clear_tbl_zap=$wpdb2->prepare("TRUNCATE TABLE %s", 'vin_history');
$clear_tbl_zap_repl=str_replace("'","`",$clear_tbl_zap);
$results=$wpdb2->query($clear_tbl_zap_repl);
/////   echo '<H2><b>Очистка таблицы сервисных книжек</b></H2><br>';
if (empty($results))
{
/////   echo '<H2><b>Ошибка очистки таблицы книжек, завершение.</b></H2><br>';
//// если очистка не удалась, возврат
$failure=TRUE;
wp_die();
return $failure;
}

////загружаем данные
$table='vin_history';         // Имя таблицы для импорта
//$file_hist Имя CSV файла, откуда берется информация     // (путь от корня web-сервера)
$delim=';';          // Разделитель полей в CSV файле
$enclosed='"';      // Кавычки для содержимого полей
$escaped='\

10 Comments

  1. ivanov660

    1. Скажите, а 1500 пользователей это вообще или одновременно работающих?

    2. К сожалению, не увидел примеров решений (всего один) и много воды (до конца просматривал через три строчки). Хотелось бы почитать про вопросы в стиле «знаю-как» (симптом-анализ-решение).

    Reply
  2. gallam99

    (1) ivanov660,

    Ответы

    1. 1500 работающих и это не предел. Максимальное количество более 3000

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

    Reply
  3. finkont

    Добрый день!

    Отличная статья, есть информация для размышления. Пользователи как раз жалуются что базы стали работать медленнее после 16 часов.

    Единственное, много орфографических ошибок, поправьте, пожалуйста.

    Если можно ответьте на вопрос: есть несколько десятков небольших баз, до 2 Гб , фирма зарабатывает аутсорсингом бухгалтерии. Базы типовые. Я отключил через консоль сервера 1С выполнение регламентных заданий почти на всех базах, т.к., на мой взгляд, там много лишних. Никто не жаловался что возникли какие-то проблемы. Ранее процессоры были загружены под 90 процентов, очередь диска доходила до 15. Сейчас процессоры редко до 50 загружены, очередь диска не увеличивается больше 2. Но быстродействие, со слов пользователей, не улучшилось. Есть еще одна проблема, почти полностью занята вся оперативная память, т.к. на сервере одновременно работает SQL и сервер 1С. В эти выходные планирую перенести часть баз на другой физический сервер с SQL. Предполагаю что это поможет освободить ОП и быстродействие улучшится.

    Собственно сам вопрос: насколько действенно отключение регламентных заданий на типовых базах и может ли это привести к проблемам? Может еще что-то вкратце посоветуете или скажете что сделал неправильно.

    Спасибо!

    Reply
  4. gallam99

    (3) finkont,

    Несколько вопросов:

    1. Какой функционал в регламентах отключенных был?

    2. Есть ли средства объективного контроля параметров производительности (пример, логирование длительности основных операций — проведение документов, отчетов и прочее)? Как один из способов — внедрение в код 1С замеров и сохранение, например, в регистр сведений.

    От пользователей не всегда объективная информация.

    По поводу памяти — статья http://infostart.ru/public/336003/ — случай с отсутствием свободной физической памяти.

    Решается он не переносом БД, а скорее переносом роли сервера приложения 1С на другой физический сервер. Проблема совмещения ролей сервера БД и сервера приложения состоит в том, что ограничивать память, потребляемую сервером приложения мы не можем и он, таким образом, съедает всю свободную (а это подробнее описывается в статье выше).

    По ошибкам попрошу копирайтеров проверить, текст настолько знаком, что сам ошибок не вижу)))

    Reply
  5. finkont

    (4)

    1. Всего порядка 35, некоторые каждые 60 секунд, например, ПланированиеОбработкиЗаданий. ПерестроениеАгрегатов — раз в неделю, в субботу.Подозреваю, что есть задания, которые было бы лучше не отключать, но пройти порядка 100 баз, и выбирать что отключать, что нет, на это уйдет 2-3 дня.

    2. Такого нет.

    По поводу ОП, прочитал статью, которую Вы посоветовали, перед тем как прочитал Ваш ответ в этой ветке.

    Как раз перенос баз на другой сервер и ставит своей целью оставить текущий сервер только для сервера 1С, или, как минимум, снизить нагрузку на него и разделить яйца по разным корзинам.

    По поводу использования ОП рабочими процессами 1С, недавно прочитал статью про их перезапуск при превышении прописанного объема памяти, https://helpf.pro/faq8/view/1502.html. Правда пока не решился это использовать, т.к. надо сначала протестировать как будет работать, а тестовой среды нет. А вообще жаль, что 1С пока не сделала настроек подобно SQL, чтобы можно было ограничить используемый объем ОП.

    В любом случае, спасибо за статью и остальную информацию. Буду продолжать смелые эксперименты. Если получится, о результатах отпишусь.

    Reply
  6. kosmo0

    Теперь – самое интересное. Что же нам позволяет соблюдать все требования при ведении проектов по оптимизации?

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

    Вы ждете от статьи конкретных алгоритмов оптимизации производительности? Хм.

    Reply
  7. dancer

    Копирайтеру двойка по русскому. Писать на тему ИТ и не знать, что терабайт — не от Терры, а от тера (τέρας — чудовище), — это моветон и, повторюсь, двойка по русскому.

    Reply
  8. gallam99

    (6) kosmo0,

    целью материала и было освещение общих вопросов (но это не значит, что они неважные).

    По поводу средства мониторинга — можно подобрать любой инструмент, который удовлетворяет требованиям к ведению проектов по оптимизации, мы предлагаем PerfExpert.

    Один пример показан для наглядной демонстрации поиска первопричины (это чтобы теория вначале была подкреплена практикой в конце).

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

    Reply
  9. logarifm

    В итоге статья — это Реклама. что у нас есть штучка которой мы умеем делать что-то… А по сути решений никаких эта статься не несет в себе.

    Reply
  10. Velifer

    (1) ivanov660,

    Вот здесь я делал проект на 5000 пользователей в единой базе.

    Хотя всего соединений с одним класером 1С получилось почти 10 тыс

    http://www.youtube.com/watch?v=0KN5DdkbS2g

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *