abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
dnes 14:44 | Zajímavý projekt

Byla zveřejněna pravidla hackerské soutěže Pwn2Own 2017, jež proběhne od 15. do 17. března v rámci bezpečnostní konference CanSecWes ve Vancouveru. Soutěžit se bude o více než milion dolarů v pěti kategoriích. Letos se bude útočit i na Ubuntu. Jedná se již o 10. ročník této soutěže.

Ladislav Hagara | Komentářů: 0
dnes 13:33 | Nová verze

Po sedmi měsících vývoje od vydání verze 5.7 byla vydána verze 5.8 (YouTube) toolkitu Qt. Z novinek lze zmínit například Qt Lite pro vestavěná zařízení. Nově jsou plně podporovány moduly Qt Wayland Compositor (YouTube) a Qt SCXML (YouTube). Současně byla vydána verze 4.2.1 integrovaného vývojového prostředí (IDE) Qt Creator.

Ladislav Hagara | Komentářů: 0
dnes 11:52 | Pozvánky

Lednový Prague Containers Meetup se koná ve čtvrtek 26. ledna 2017 od 18:00 v Apiary, Pernerova 49, Praha 8. Přijďte se podívat na přednášky o Enterprise Kubernetes a Jenkins as a code.

little-drunk-jesus | Komentářů: 0
dnes 11:40 | Pozvánky

Program letošního ročníku konference Prague PostgreSQL Developer Days, která se koná již 15. a 16. února 2017 na ČVUT FIT, Thákurova 9, Praha 6, byl dnes zveřejněn. Najdete ho na stránkách konference včetně anotací přednášek a školení. Registrace na konferenci bude otevřena zítra (24. ledna) v brzkých odpoledních hodinách.

TomasVondra | Komentářů: 0
včera 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
včera 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
21.1. 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
21.1. 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 7
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 11
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (11%)
 (2%)
 (73%)
 (3%)
 (10%)
Celkem 374 hlasů
 Komentářů: 26, poslední dnes 14:32
Rozcestník
Reklama

Dotaz: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?

27.10.2012 22:42 vasek
Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
Přečteno: 354×
Ahoj. V PHP mám napsaný nějaký skript a potřeboval bych spolehlivě zjišťovat, jak dlouho se vykonával určitý cyklus. Zásadní problém je, že pokud použiju třeba microtime() před cyklem a po cyklu znovu a odečtu od sebe naměřené hodnoty, tak získám nějaký čas, který vůbec nemusí odpovídat dobu běhu - může dojít k přestupné sekundě nebo např. ntpd může zrovna zpomalovat čas. Jak mám tedy tu dobu spolehlivě zjistit?

Odpovědi

27.10.2012 23:34 l4m4
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
Pravděpodobně hledáš getrusage(). Pokud bys chtěl měřit skutečný fyzikální čas, tak tomu je asi nejbližší CLOCK_MONOTONIC_RAW čas vrácený clock_gettime(), ale jak/zda se to dá zavolat z PHP, netuším.
28.10.2012 23:28 azurIt | skóre: 34 | blog: zatial_bez_mena
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
Len upozornim, ze getrusage() vrati spotrebovany procesorovy cas, co sa samozrejme nemusi rovnat fyzikalnemu casu - uloha proste moze realne bezat ovela dlhsie, pretoze tvojej aplikacii proste nebol procesor prideleny, pripadne cakala napr. na disky.
28.10.2012 23:40 l4m4
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
Ano, v průběhu vykonávání se může stát spousta věcí od uspání po přemigrování na jiný node clusteru... Jde-li o měření CPU-bound akce, tak je getrusage() IMO vhodná veličina, protože ji až tak moc neovliňuje kontext vykonávání. Jde-li ale o změření, jak dlouho potrvá nastavit monochromátor ovldádaný přes RS232 na danou vlnovou délku, tak je samořejmě zapotřebí měřit fyzikální čas.
28.10.2012 23:33 azurIt | skóre: 34 | blog: zatial_bez_mena
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
co tak vyuzit na to systemovy uptime? /proc/uptime
Josef Kufner avatar 29.10.2012 02:25 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
Obávám se, že s tímhle máš smůlu. Těch věcí se může přihodit mnoho a prakticky nemáš šanci to ani zjistit.

Díky tomu, že microtime vrací unixový timestamp, tak tě přestupná sekunda a podobné blbosti netrápí. Unixový timestamp je krásná lineární posloupnost bezjakýchkoliv zoubků a uzlíků.

Ovšem ntpd ti to rozhodit může. Velké záporné změny je snadné detekovat prostým ověřením, zda rozdíl časů je kladný. A s tím zbytkem... no... příjemnou zábavu. Asi nejjednodušším řešením je sestřelit na potřebnou dobu ntpd a doufat, že nic jiného na čas hrabat nebude. Ale pokud jde jen o nějaký profiler, kašli na to.
Hello world ! Segmentation fault (core dumped)
29.10.2012 09:51 azurIt | skóre: 34 | blog: zatial_bez_mena
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
Nemas pravdu, uz tu padli dva navrhy, ktorymi by to bolo mozne urobit. Pre priklad, ak sa jedna o fyzicky stroj a nie virtualny, tak /proc/uptime by mal byt vcelku presny, vypocitava sa na zaklade frekvencie procesoru (standardne sa navysuje kazdych 100 Hz, co je na vacsine architektur 0,01 sekundy).
Josef Kufner avatar 29.10.2012 11:00 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
Ptá se na PHP, nikoliv nutně na Linux. Pokud to pak hodí na server s BSD nebo přibere kolegu s Windows, má smůlu. Leda by pro každou podporovanou platformu sehnal způsob, jak to zjistit, ale pochybuju, že se mu to vyplatí.
Hello world ! Segmentation fault (core dumped)
Josef Kufner avatar 29.10.2012 11:02 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
... navíc nikde nemá zaručeno, že systémové hodiny jdou správnou rychlostí.
Hello world ! Segmentation fault (core dumped)
30.10.2012 09:18 azurIt | skóre: 34 | blog: zatial_bez_mena
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
/proc/uptime nezavisi od systemovych hodin, procesorovy cas neviem
frEon avatar 29.10.2012 14:17 frEon | skóre: 40 | Praha
Rozbalit Rozbalit vše Re: Jak v PHP spolehlivě zjistit dobu vykonávání určité části kódu?
proc to potrebujes vedet? Nestacil by profiler?
Talking about music is like dancing to architecture.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267   www.czech-server.cz
© 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.