Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: tasktimer();

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: Считаем время выполнения отдельного процесса.
DeepVarvar Супермодератор
Отправлено: 20 Апреля, 2011 - 21:37:57
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Написал себе функцию, которая считает время выполнения отдельных процессов в коде.
Ну там всякие тесты, бамминг...
Ф-ция проста как топор. Однако с ней удобно работать в классе ядра (сделав её методом),
в котором идут всякие include, file_get_contents, foreach, mysql_query, коннект куда-нибудь, создание/модификация и уничтожение объектов и прочая суета..

Ф-ция возвращает float-значение в виде xS.UUUUUU
S - секунды.
x - возможный второй разряд секунд (SS - если очень уж долго работает процесс).
Макс 99 сек, но это и так уже слишком. ))))
U - микросекунды, 6 после запятой.

PHP:
скопировать код в буфер обмена
  1. define("STOP",true);
  2. function timer($stop = false,$t = false) {
  3.   list($usec,$sec) = explode(" ",microtime());
  4.   $time = round(substr($sec,8) + $usec,6);
  5.   //return !$stop ? $time : round($time - (!$t ? $time : $t),6);
  6.   // исправил чуток, зачем считать если и так ясно что ноль?
  7.   return !$stop ? $time : (!$t ? 0 : round($time - $t,6));
  8.   }

Юзать типа так:
PHP:
скопировать код в буфер обмена
  1. $myworktime = timer();
  2. foreach ($longarray as $bigdata) {
  3.   // работаем там, все дела...
  4.   }
  5. echo timer(STOP,$myworktime);

(Отредактировано автором: 20 Апреля, 2011 - 22:03:19)

 
 Top
EuGen Администратор
Отправлено: 20 Апреля, 2011 - 21:44:51
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




Полезно, но для замеров производительности лучше видимо использовать ab
Ну и код в виде класса неплохо бы все же оформить. У него можно сделать два метода - вернуть текущее время и вернуть разницу между текущим и последним замером. Тогда и STOP не будет нужен.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
DeepVarvar Супермодератор
Отправлено: 20 Апреля, 2011 - 21:48:47
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




EuGen пишет:
ab

Можт я туплю, однако а что это?
EuGen пишет:
код в виде класса неплохо бы все же оформить

Я сюда выложил адаптированно, в виде ф-ции.
 
 Top
EuGen Администратор
Отправлено: 21 Апреля, 2011 - 18:51:57
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




Про ab:
http://httpd[dot]apache[dot]org/docs/2[dot]0[dot][dot][dot]programs/ab[dot]html
В виде класса было бы, на мой взгляд, более логично и проще. Ну да в любом случае вещь полезная.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
DeepVarvar Супермодератор
Отправлено: 21 Апреля, 2011 - 19:43:43
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




EuGen пишет:
Про ab

Блин, а у меня nginx...
EuGen пишет:
В виде класса было бы, на мой взгляд, более логично

DeepVarvar пишет:
Ф-ция проста как топор. Однако с ней удобно работать в классе ядра (сделав её методом)

Закатив глазки
А тут я лишь показал смысл и принцип использования.
Те, кто "в теме", оформят эту ф-цию хоть методом объекта, хоть отдельным объектом.
Я склоняюсь к первому (метод). Думаю вообще обернуть это в генератор массива статистики процессов "ядра".
Но с другой стороны с возрастанием функционала, вырастет и погрешность.
Саму себя то ф-ция не считает.
Поэтому это изначально именно "tasktimer" - считаем только внутренние "подпроцессы" скрипта...
 
 Top
EuGen Администратор
Отправлено: 21 Апреля, 2011 - 20:39:23
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




ab все равно, какой у Вас веб-сервер. Она просто делает http-запросы и ведет статистику.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
ALEN Модератор
Отправлено: 21 Апреля, 2011 - 21:12:47
Post Id



Участник


Покинул форум
Сообщений всего: 1459
Дата рег-ции: Авг. 2008  
Откуда: Крым


Помог: 11 раз(а)




DeepVarvar
Данный раздел форума подразумевает готовые функции, классы или скрипты. Если это урок, то нужно переносить сообщение в соответствующий раздел. Если же все таки класс, то рекомендую оформить соответственно.
 
 Top
DeepVarvar Супермодератор
Отправлено: 21 Апреля, 2011 - 21:19:32
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




ALEN это функция.
С тематикой этой ветки форума контекст представленного кода не конфликтует.
 
 Top
ALEN Модератор
Отправлено: 21 Апреля, 2011 - 21:47:19
Post Id



Участник


Покинул форум
Сообщений всего: 1459
Дата рег-ции: Авг. 2008  
Откуда: Крым


Помог: 11 раз(а)




DeepVarvar пишет:
я лишь показал смысл и принцип использования.

Вот поэтому я написал предыдущий пост.
 
 Top
EuGen Администратор
Отправлено: 21 Апреля, 2011 - 22:12:39
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




ALEN,
Все в порядке. Здесь допустимы как классы, так и функции. Равно как и любой код, который можно назвать самостоятельным решением. Тем более что человек старался и опубликовал своё.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Пользовательские функции »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB