Portál AbcLinuxu, 20. dubna 2024 05:20


Dotaz: Zaznamenávání běhu webového systému (PHP)

freshmouse avatar 26.2.2008 12:42 freshmouse | skóre: 42 | blog: Bruno Banány
Zaznamenávání běhu webového systému (PHP)
Přečteno: 181×
Odpovědět | Admin
Zdravím.

Pracuju na nějakém systému pro zaznamenávání běhu systému (někdo možná spíš uslyší na "tvorbu logů"). Prakticky mám všechno hotovo, jen bych se s vámi chtěl poradit o tom, jak je nejvhodnější záznam provádět (hlavně z hlediska výkonu; hledám tedy zejména lidi, co mají s podobným problémem zkušenosti).

Jeden z výstupů je soubor (dále je tam mj. databáze atp. -- není podstatné). Mám to dělané tak, že se tam dá nastavit, kdy se záznam do souboru zapíše: 1. jakmile přijde záznam, otevře se soubor, zapíše se do něj a zavře se; 2. záznamy jsou skladovány v zásobníku a zapíšou se až po posledním záznamu (je to dělané přes destruktor), 3. je otevřeno trvalé spojení k souboru, zapisuje se průběžně a zavře se až po posledním záznamu (opět přes destruktor).

(Poznámka: možnost 3. je spíš jen do počtu, jelikož kombinuje nevýhody možností 1. a 2.)

Z hlediska výkonu je asi nejvhodnější možnost 2, tedy zásobník a jeho hromadný zápis. Je ale dobré s "logy" pracovat tímto stylem? Nemohou nastat komplikace např. tehdy, když se celý systém zhroutí (třeba při ladění)? Co kdyby se už do souboru vůbec nezapsalo (a tedy celý záznam běhu by nebyl k dispozici, jinými slovy by naše ladění bylo k ničemu)?

Nejbezpečnější je možnost 1. Ta ale, při větším počtu záznamů, bude neustále otevírat a zavírat soubory, a to se mi moc nechce líbit kvůli výkonu.

Co byste volili vy?

(Nejde o programování, jde spíše o použití.)
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

26.2.2008 12:52 Zdenek
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Odpovědět | | Sbalit | Link | Blokovat | Admin
Pouzil bych moznost cislo 2 a soubor otviral s O_DIRECT|O_SYNC.
26.2.2008 12:56 Zdenek
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Ted jsem si ale vsiml, ze to chcete v PHP. Tam to asi takhle nebude mozne.
26.2.2008 12:57 maleprase | skóre: 28
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Odpovědět | | Sbalit | Link | Blokovat | Admin
misto zasobniku frontu, aby ten zaznam co se prvni vlozi se taky prvni ulozil a ne obracene jak tomu je u zasobniku
freshmouse avatar 26.2.2008 12:59 freshmouse | skóre: 42 | blog: Bruno Banány
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Máš pravdu. Špatně jsem to napsal: myslel jsem frontu.
freshmouse avatar 26.2.2008 14:16 freshmouse | skóre: 42 | blog: Bruno Banány
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Ale díky, žes mě upozornil, měl jsem to špatně pojmenované i v kódu (měl jsem tam "stack").
26.2.2008 14:34 Sinuhet
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
A skutecne je to takova vykonostni tragedie, otevrit si pri prvnim pozadavku na zapis soubor, zapamatovat si ho a pri dalsich prilezitostech ho znovu pouzit? Docela by me zajimala cisla, jestli jste to meril.
freshmouse avatar 26.2.2008 14:55 freshmouse | skóre: 42 | blog: Bruno Banány
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Neměřil a teď ani nemám kde to zkoušet a měřit -- proto se ptám.

Navíc: kromě toho, že je po celý běh aplikace otevřen soubor (dalo by se to optimalizovat tak, aby se otevřel až při první potřebě zápisu, ale to je jedno), je tu hlavně to riziko, že se do něj nezapíše (v případě chyby).
26.2.2008 16:19 Sinuhet
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
AraxoN avatar 26.2.2008 15:09 AraxoN | skóre: 47 | blog: slon_v_porcelane | Košice
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ak to robíš v PHP, tak na to už je jedna fcia - error_log(), s typom 3 to ukladá do súboru, do ktorého mu povieš. Som toho názoru, že čokoľvek iné od tohoto (naprogramované v PHP) je len a len pomalšie.
freshmouse avatar 26.2.2008 15:39 freshmouse | skóre: 42 | blog: Bruno Banány
Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
Moje vlastní řešení v PHP určitě bude pomalejší než knihovní funkce PHP v C. Ale moje řešení je zase víc ohebnější a lze jej použít k více účelům.

Výstupy mám volitelné; můžu to posílat kam chci, ať už to je databáze, textový soubor, elektronická pošta, Jabber nebo RSS. Stačí jen implementovat rozhraní a předat objekt jako parametr.

Dále tam mám nastavitelné "typy" zpráv. Můžu si třeba vytvořit typy zpráv STRAŠNÁ_CHYBA a MALINKATÁ_CHYBKA a potom si určit, co se bude ukládat.

Založit nové vláknoNahoru

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

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.