Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на языке Perl


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный ХОСТИНГ на базе Linux x64 и Windows x64

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

_Ayl_
Статус: Профессионал
Рейтинг: 1847
∙ повысить рейтинг »
Хватов Сергей
Статус: Профессионал
Рейтинг: 262
∙ повысить рейтинг »
Hubbitus
Статус: 10-й класс
Рейтинг: 89
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / Perl (Перл)

Номер выпуска:122
Дата выхода:30.05.2010, 01:00
Администратор рассылки:Калашников О.А., Руководитель
Подписчиков / экспертов:151 / 26
Вопросов / ответов:1 / 1

Вопрос № 178622: Уважемые эксперты! Есть довольно интересный вопрос. Есть скрипт: http://moshoster.net/test.txt Он просто получает текущую дату. А вот результат его работы: <...



Вопрос № 178622:

Уважемые эксперты!
Есть довольно интересный вопрос.

Есть скрипт: http://moshoster.net/test.txt
Он просто получает текущую дату.

А вот результат его работы:
http://moshoster.net/test.cgi
Вроде всё верно. Но попробуйте обновить страницу раз 5-10, увидите, что происходит.

Сталкивался ли кто-нибудь из вас с такой интересной вещью?

Отправлен: 25.05.2010, 00:35
Вопрос задал: Калашников О.А., Руководитель
Всего ответов: 1
Страница вопроса »


Отвечает Хватов Сергей, Профессионал :
Здравствуйте, Калашников О.А..
Формулирую ответ по результатам совместных экспериментов.

Это прежде всего ошибка в сервере Apache, связанная с особенностями его архитектуры: при его работе запускаются несколько подпроцессов, каждый из которых обслуживает по несколько разных запросов. Кроме того, интерпретаторы perl, php и python в нём встроенные. В результате если какой-то из скриптов сделает изменения в environment, эти изменения попадут и в некоторые другие запросы. В этом бы не было особой ошибки, если бы environment неявно не использовалась в ряде библиотечных функций. localtime() использует TZ, и изменение каким-то скриптом TZ и вызвало тот эффект, который вы наблюдали - неожиданное изменение временной зоны в скрипте. Дже в логи записывается дата с изменённой зоной.
В Интернете также упоминаются эффекты от изменения LANG и LC_*
Чтобы этого избежать, придётся перед использованием localtime() явно удалять $ENV{'TZ'}. Возможно, что также придётся для корректировки уже заполненных статических данных вызвать POSIX::tzset (мне в python не понадобилось)


Ответ отправил: Хватов Сергей, Профессионал
Ответ отправлен: 25.05.2010, 21:34
Номер ответа: 261646

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 261646 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:

  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2010.6.16 от 26.05.2010

    В избранное