abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 18:33 | Nová verze

    Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.

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

    Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.

    Ladislav Hagara | Komentářů: 11
    včera 02:22 | Nová verze

    Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.

    Ladislav Hagara | Komentářů: 2
    včera 01:22 | IT novinky

    Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.

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

    Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinekpoznámkách k vydání.

    Fluttershy, yay! | Komentářů: 2
    25.7. 17:44 | Zajímavý článek Ladislav Hagara | Komentářů: 2
    25.7. 17:22 | Nová verze

    Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.

    Ladislav Hagara | Komentářů: 0
    25.7. 17:11 | Nová verze

    Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    25.7. 14:11 | IT novinky

    Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.

    Ladislav Hagara | Komentářů: 23
    25.7. 13:11 | IT novinky

    Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: Jak dlouho je proces v read()?

    xvasek avatar 7.12.2010 16:02 xvasek | skóre: 21 | blog: | Zlín
    Jak dlouho je proces v read()?
    Přečteno: 329×
    Ahojte,

    mám před sebou problém, kdy potřebuju zabít instance serveru (procesy), které dlouho nic nedělají. Server typicky volá read(), ve kterém je "zaseknutý" dokud nedostane data a jakmile je dostane, tak je zpracuje, něco udělá a pak zase visí v read(). Představoval bych si to tak, že např. každou hodinu poběží cronjob, který projde procesy serveru a ty, které jsou v read() už více než čtyři hodiny, tak zabije. Dá se nějak poznat, kdy (nejlíp v sekundách od začátku epochy) ten proces zavolal read(), ve kterém teď visí, popřípadě kolik sekund už tam visí doteď?

    Předem díky.

    Odpovědi

    7.12.2010 16:45 psonek | skóre: 20 | blog: psonek
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Pred read() nekam zapsat svuj PID a akt. cas, po dokonceni readu zase zapsat, ze uz se operace dokoncila.

    V tom cronjobu pak precist PIDy a podle casu je pozabijet.

    Jinak read() operace se da prerusit z jineho vlakna pres pthread_kill() a nebo je mozne pouzit async io. Externi zabijec je zajimavej, ale spis by se mel korektne ukoncit sam server podle me.
    xvasek avatar 7.12.2010 18:02 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Aha, to jsem mohl napsat do dotazu - server je closed-source. Vím o něm, že jej můžu bezpečně zabít přes kill -15. Ono je to v praxi tak, že chci implementovat automatické odpojování uživatelů při nečinnosti, protože nepřítomnost komunikace se rovná tomu, že uživatel s daným oknem nepracuje. Výrobce tuto funkci neplánuje, tak jsem chtěl vzít spravedlnost do vlastních rukou. Taky by mi to vyřešilo mé problémy s freetds, protože to se dostane do stejného stavu, pokud se restartuje MSSQL server. (Timeouty freetds mám nastavené, ale nepomáhá to.)
    7.12.2010 16:52 lofcek
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Myslim, ze takto moze program napisat iba velmi neskuseny programator (po slovensky blb) a takyto program moze nainstalovat iba velmi neskuseny administrator (do slovenciny radsej neprekladam).

    Nie .. prenositelny a jednoduchy sposob ako toto spoznat neexistuje. Zrejme by sa to cez velke hacky dalo zistit, ale myslim, ze ovela vhodnejsie je autora tohto programu kopat do zadnej casti tak dlho, kym to neopravi.

    Tento sposob opravy ma mnohe vyhody - zlepsuje prenositelnost kodu, ma mensie hardvarove naroky a znamena aj jednoduchsiu administraciu systemu.
    stativ avatar 7.12.2010 16:54 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Určitě by to šlo přes profiler. To je ale blbost, protože ten běh nehorázně zpomalí.

    Já bych na to šel cestou LD_PRELOAD. Vytvořil bych si knihovnu s fcí read(), která by někam uložila záznam o čase jejího zavolání. Po jejím dokončení by se zase záznam smazal.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    xvasek avatar 7.12.2010 18:05 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Zajímavý nápad, ale myslel jsem, že by to mohlo jít jednoduššeji z té hromady čísílek, která jsou v souborech v /proc/PID, každopádně toto vypadá taky schůdně.
    rADOn avatar 7.12.2010 19:29 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Jestli ten server pro kazde spojeni spawnuje novy pracovni podproces, stacilo by nastavit mu nejaky rozumny cas na zivot pres ulimit nebo proste signal na budik.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    xvasek avatar 7.12.2010 21:01 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Nene, takto to nejde. Je mi jedno, kolik si proces vezme zdrojů. Velký proces, který pořád sedí na CPU a pořád komunikuje, je "dobrý", naopak malý proces, který nic dlouhodobě nedělá, je "špatný" - bere totiž licenci ze serveru.

    Jinak pokud by to pomohlo, tak to celé běží přes inetd / xinetd, ale tam jsem se díval a ten tuto funkci nepodporuje - otevře socket, přilepí vstupy / výstupy a dál se o to nestará.

    Tak mě tak napadá, že by to tím pádem mohlo jít přes nějaké tee jednak k serveru a druhak do watchdogu, který by nečinnost vlastnoručně "trestal". (Ale původní idea "zjisti, jak dlouho už stojí ten read() a zabij to" mi přijde jednodušší, ale jestli nic takového nejde...)
    rADOn avatar 8.12.2010 14:44 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    nápad: v cronjobu si někam poznačit cpu time spotřebovaný dotyčným PID. Pokud při příštím spuštení bude stejný, proces visí.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    michich avatar 8.12.2010 16:12 michich | skóre: 51 | blog: ohrivane_parky
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Nebo třeba počet přepnutí kontextu, které proces zažil. Je to někde v /proc/PID/... Při zapnutém CONFIG_SCHEDSTATS je tam někde i časová značka, kdy šel proces spát.
    xvasek avatar 9.12.2010 12:16 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    To si právě myslím taky. Původně jsem ten dotaz pokládal s tím, že někdo za 5 minut vysype z hlavy, kde ta značka je.
    8.12.2010 09:30 lofcek
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Existuje aj dalsie riesenie .. a sice, ze inet daemon by spustil Vas program na monitorovanie aktivity. Tento program by nasledne spustil prislusnu ulohu a predposielal by jej vsetky vstupy a vystupy. A ked by ziadne citanie ani zapis neboli nejaky dostatocne dlhy cas, tak by ju cez kill poslal do prec.

    Ale stale si myslim, ze opravit utilitku aby sa nazasekla pri open je v 99% pripadov jednoduchsie ako tahat kalibre ma monitoravanie aktivit procesu.
    8.12.2010 17:29 lofcek
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Kazde volanie je prerusitelne (ak neobsahuje kernel chybu - uz som videl aj to). Signaly ako SIGINT, SIGHUP, SIGTERM sa daju ignorovat, ale SIGKILL (a este SIGSTOP - ale ten teraz nepotrebujeme) sa neda.
    frEon avatar 8.12.2010 15:28 frEon | skóre: 40 | Praha
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    read() je syscall, tudiz proces, kterej je uprostred blokujiciho volani read() nezabijes protoze je v neprerusitelnem spanku. Doruceny signal se zpracuje az prave probihajici syscall skonci.
    Talking about music is like dancing to architecture.
    michich avatar 8.12.2010 16:09 michich | skóre: 51 | blog: ohrivane_parky
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Jak víš, že ten spánek bude nepřerušitelný? Pravděpodobně ten proces čte z nějaké roury nebo soketu, to bude přerušitelné.
    8.12.2010 22:21 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    v dokumentaci od read je že vrací EINTR pokud je přerušen signálem, ergo dojde i k přepnutí kontextu a obsluze signálu.
    In Ada the typical infinite loop would normally be terminated by detonation.
    frEon avatar 9.12.2010 10:28 frEon | skóre: 40 | Praha
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    nj, koukam. mas pravdu
    Talking about music is like dancing to architecture.
    xvasek avatar 9.12.2010 12:12 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Přesně tak, když to přes kill zabiju, tak si to korektně ukončí session k aplikačnímu serveru - je to v dokumentaci toho serveru.
    8.12.2010 18:15 Semo | skóre: 45 | blog: Semo
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    V jadre 2.6.36 pribudol do iptables filter testujuci dobu necinnosti spojenia. Ale ak po spojeni behaju keepalive pakety, tak to nepomoze. Ak ale tvrdis, ze server visi v read(), tak keepalive pakety asi nebehaju a dalo by sa to tymto mechanizmom rozpoznat.

    Ak nemozes mat najnovsie jadro, tak by som sa priklonil by som sa ku jednoduchemu forwarderu medzi xinetd a samotnym serverom, ktory bude pocitat cas od posledneho prietoku dat. A ak expiruje, tak strihne spojenie, co by server mohol vyhodnotit ako odpojenie klienta.

    Vyhol by som sa podstrceniu read() cez LD_PRELOAD, pretoze tym by si prepisal aj vsetky ostatne vyskyty read pouzite na inom mieste servera.
    If you hold a Unix shell up to your ear, you can you hear the C.
    9.12.2010 00:01 darkenik
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    otazka je este, ze na akom OS to bezi. v Solarise by sa to dalo robit nejak cez dtrace skripty. A pokial viem, tak linux ma na sledovanie tiez nejaku sadu *trace prikazov a nejaky sposob sledovacich bodov v kerneli.
    xvasek avatar 9.12.2010 12:10 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Jak dlouho je proces v read()?
    Linux, nejčastěji Debian 5, ale taky RHEL 4 a výš. Dávat tam nedistribuční jádro se mi moc nechce.

    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.