The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]




Версия для распечатки Пред. тема | След. тема
Новые ответы [ Отслеживать ]
Как урегулитровать работу скриптов?, !*! harlan, 17-Сен-03, 12:31  [смотреть все]
На машине работают два скрипта (Perl):
1. срабатывает в момент, когда пользователь, подключенный по ppp отваливается (/etc/ppp/ip-down) и заносит статистику сеанса по этому абоненту в БД;
2. срабатывает по кронтабу, и заносит в БД промежуточные значения текущих сеансов ppp.
Эти скрипты не должны обрабатывать данные одновременно, т.е., если пользователь отключился в момент, когда отрабатывает скрипт 2, то скрипт 1 должен сначала дождаться, когда скрипт 2 завершит свою работу.
Соответственно так же должен работать и скрипт 2.
Я решил эту проблему следующим образом: В каждый скрипт вставил следующую структуру:
=========================================================
#!/usr/local/sbin/perl
# Ждём, пока файл /var/run/script не будет уничтожен.
while (-e '/var/run/script') { }
# создаём файл /var/run/script
open FLAG, '>/var/run/script';
close FLAG
# ...
# Далее идёт обработка данных
# ...
# Уничтожаем файл /var/run/script
unlink '/var/run/script'
# Конец скрипта
=========================================================
Вроде бы работает, но что-то подсказывает мне, что так сделано не очень красиво.
Подскажите, как сделать правильно?

  • Как урегулитровать работу скриптов?, !*! uldus, 10:26 , 19-Сен-03 (1)
    > while (-e '/var/run/script') { }

    Вставь задержку и пиши pid:
    while (-e '/var/run/script') { sleep(1); }
    ....
    open FLAG, '>/var/run/script';
    flock(FLAG, 2);
    print FLAG "$$\n";
    close FLAG

    >Вроде бы работает, но что-то подсказывает мне, что так сделано не очень
    >красиво.
    >Подскажите, как сделать правильно?

    Нужно предусмотреть ситуацию когда скрипт преждевременно умер, а лок остался. Т.е. нужно проверять не только лок, но писать в него uid процесса и при проверке проверять жив ли он. Если нет - можно удалять лок.

    Вторая проблема отследить зацикливание обработчика - определить время жизни которое может выполняться скрипт, если время превышено - убивать процесс или  экстренно высылать сообщение администратору.

    Третье - организовать очередь ожидания, чтобы по крону не наплодилось слишком много процессов в очереди, которые при удалении лока могут почти одновременно начать выполняться невзирая на лок. Т.е. ввести второй лок - лок на ожидающий процесс, если он есть то претендент на второе место в очереди должен отваливаться не ожидая освобождения первичного лока или ждать сперва пока освободится лок на ожидающий процесс и только потом смотреть на первичный лок.





Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2025 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру