Планировщик задач для PHP-сайта::Журнал СА 7-8.2017
www.samag.ru
Журнал «БИТ. Бизнес&Информационные технологии»      
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
1001 и 1 книга  
19.03.2018г.
Просмотров: 6963
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7428
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4835
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3187
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3984
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3988
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6485
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3337
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3612
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7472
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10840
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12547
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14267
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9285
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7241
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5538
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4766
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3587
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3292
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3524
Комментарии: 1
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3180
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 Планировщик задач для PHP-сайта

Архив номеров / 2017 / Выпуск №7-8 (176-177) / Планировщик задач для PHP-сайта

Рубрика: Разработка /  Автоматизация   | Дополнительные материалы

Игорь Орещенков ИГОРЬ ОРЕЩЕНКОВ, инженер-программист, iharsw@tut.by

Планировщик задач для PHP-сайта

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

Планировщик задач для PHP-сайтаВ современной «всемирной паутине» преобладают динамические сайты. Чтобы заинтересовать пользователя, информацию на сайте необходимо регулярно обновлять. Попав на сайт, пользователь должен увидеть актуальные курсы валют, прогноз погоды, свежие новости и последние рекламные предложения.

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

Во-вторых, можно генерировать странички «на лету» по каждому пользовательскому запросу. Это один из самых популярных подходов среди сайтов, разработанных на PHP. Он позволяет получить максимальную гибкость содержания засчет увеличения вычислительной нагрузки на сервер.

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

На практике лучше использовать комбинацию этих двух вариантов: данные собираются и преобразуются в удобный промежуточный формат фоновым процессом, а страничка для выдачи пользователю формируется сценарием окончательной cборки. Такой подход позволяет достичь компромисса между производительностью и актуальностью веб-ресурса.

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

Рекурсивный запуск PHP-сценария HTTP-запросом

Первый вопрос, который встает на пути разработчика системы автоматизации, заключается в способе запуска PHP-сценария на выполнение по расписанию или другому событию.

Однократный запуск легко осуществить направлением HTTP-запроса из браузера – таким способом запускаются все PHP-сценарии. После запуска PHP-сценарий мог бы организовать бесконечный цикл с периодической проверкой наступления времени выполнения задачи.

Но время выполнения PHP-сценария в составе веб-приложения ограничено как настройкой среды выполнения (параметр max_execution_time конфигурационного файла по умолчанию равен 30 секундам, см. рис. 1), так и настройкой веб-сервера (для Apache и IIS это ограничение составляет 300 секунд). Как бы либерально ни был настроен веб-сервер, сам факт наличия ограничения является препятствием в вопросе организации фонового PHP-процесса. Можно попытаться его преодолеть, вспомнив, что любой цикл может быть заменен рекурсией.

Рисунок 1. Время выполнения сценария ограничено настройками среды PHP

Рисунок 1. Время выполнения сценария ограничено настройками среды PHP

Организовывать рекурсивный вызов PHP-сценария нужно через HTTP-запрос к самому себе, в противном случае его выполнение будет происходить в рамках одного серверного потока, что не позволит справиться с описанными ограничениями. Если же эстафета будет передаваться вызовом сценария по сетевому запросу, то веб-сервер воспримет это как обычный пользовательский запрос и запустит сценарий в новом потоке, со сброшенными таймерами (см. рис. 2).

Рисунок 2. Схема сценария, реализующего рекурсивный HTTP-вызов

Рисунок 2. Схема сценария, реализующего рекурсивный HTTP-вызов

Статью целиком читайте в журнале «Системный администратор», №7-8 за 2017 г. на страницах 62-67.

PDF-версию данного номера можно приобрести в нашем магазине.


  1. RFC 2616: Hypertext Transfer Protocol – HTTP/1.1 – URL: http://www.ietf.org/rfc/rfc2616.txt.
  2. Орещенков И. О совместном доступе к файлам в PHP. // «Системный администратор», № 4, 2017 г. – С. 66-71/ URL: http://samag.ru/archive/article/3413.
  3. Планировщик задач phpJobScheduler – URL: http://www.phpjobscheduler.co.uk.

Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru