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 12:33 | Komunita

    Alex Ellis upozornil 15. března, že firma Docker se chystala zrušit bezplatný hosting open-source projektů na Docker Hubu. Po vlně odporu se představitelé firmy omluvili a posléze byl původní záměr odvolán.

    Fluttershy, yay! | Komentářů: 0
    dnes 07:00 | IT novinky

    Ve věku 94 let zemřel Gordon Moore, mj. spoluzakladatel společnosti Intel a autor Moorova zákona.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | Nová verze

    Mercurial (Wikipedie), software pro SCM (Source Code Management), byl vydán ve verzi 6.4. Přehled novinek v poznámkách k vydání. Ve dnech 5. až 7. dubna proběhne konference Mercurial Paris.

    Ladislav Hagara | Komentářů: 0
    včera 11:55 | IT novinky

    Byly rozdány Ceny Velkého bratra (Big Brother Awards) za rok 2022 pro největší slídily pořádané nevládní organizací Iuridicum Remedium. Dlouhodobý slídil: Microsoft. Firemní slídil: Seznam. Úřední slídil: Nejvyšší správní soud. Výrok Velkého bratra: Marian Jurečka. Pozitivní cena: NoLog.

    Ladislav Hagara | Komentářů: 10
    včera 11:11 | Zajímavý projekt

    Byla představena online vzdělávací platforma Ada Computer Science pro učitele, studenty a kohokoli, kdo se zajímá o informatiku. Stojí za ní Raspberry Pi Foundation a Univerzita v Cambridgi.

    Ladislav Hagara | Komentářů: 0
    včera 09:11 | Bezpečnostní upozornění

    GitHub má nový RSA SSH klíč. Předchozí soukromý klíč byl krátce vystaven na GitHubu.

    Ladislav Hagara | Komentářů: 0
    včera 08:55 | IT novinky

    Společnost Framework Computer představila (YouTube) nové modulární notebooky: Laptop 13 s Intel Core nebo AMD Ryzen a Laptop 16 (YouTube).

    Ladislav Hagara | Komentářů: 0
    23.3. 19:33 | Nová verze

    Bylo vydáno Ubuntu 20.04.6 LTS, tj. šesté opravné vydání Ubuntu 20.04 LTS s kódovým názvem Focal Fossa. Přehled novinek v poznámkách k vydání a v přehledu změn.

    Ladislav Hagara | Komentářů: 2
    23.3. 14:44 | IT novinky

    Připojit neznámý USB flash disk do počítače může být nebezpečné. Dokonce může jít i o život. Někdo rozeslal ekvádorským novinářům USB flash disky, které po připojení do počítače explodují [BBC, Twitter].

    Ladislav Hagara | Komentářů: 2
    23.3. 13:33 | Nová verze

    Byla vydána nová verze 7.4 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu.

    Ladislav Hagara | Komentářů: 0
    Používáte WSL (Windows Subsystem for Linux)?
     (74%)
     (12%)
     (4%)
     (10%)
    Celkem 319 hlasů
     Komentářů: 4, poslední včera 06:42
    Rozcestník


    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: 175×
    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í.)

    Odpovědi

    26.2.2008 12:52 Zdenek
    Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
    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)
    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: 46 | blog: slon_v_porcelane | Košice
    Rozbalit Rozbalit vše Re: Zaznamenávání běhu webového systému (PHP)
    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   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.