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 11:00 | Komunita

Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už zítra 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.

xkucf03 | Komentářů: 0
včera 21:55 | Komunita

Nadace pro svobodný software (FSF) oznámila aktualizaci seznamu prioritních oblastí (changelog), na které by se měli vývojáři a příznivci svobodného softwaru zaměřit. Jsou to například svobodný operační systém pro chytré telefony, hlasová a video komunikace nebo softwarový inteligentní osobní asistent.

Ladislav Hagara | Komentářů: 3
včera 16:44 | Nová verze

Byla vydána verze 2.0.0 knihovny pro vykreslování grafů v programovacím jazyce Python Matplotlib (Wikipedie, GitHub). Přehled novinek a galerie grafů na stránkách projektu.

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

V australském Hobartu probíhá tento týden konference linux.conf.au 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online.

Ladislav Hagara | Komentářů: 0
včera 10:20 | Zajímavý článek

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje bitmapovým (rastrovým) grafickým editorům ve Fedoře. V prvním dílu se věnuje editorům MyPaint, MtPaint, Pinta, XPaint, Krita a GIMP. V pokračování pak editorům GNU Paint (gpaint), GrafX2, KolourPaint, KIconEdit a Tux Paint.

Ladislav Hagara | Komentářů: 1
16.1. 17:11 | Komunita

Byl proveden bezpečnostní audit svobodného IMAP a POP3 serveru Dovecot (Wikipedie). Audit byl zaplacen z programu Mozilla Secure Open Source a provedla jej společnost Cure53. Společnost Cure53 byla velice spokojena s kvalitou zdrojových kódu. V závěrečné zprávě (pdf) jsou zmíněny pouze 3 drobné a v upstreamu již opravené bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
16.1. 15:30 | IT novinky

Nadace Raspberry Pi představila na svém blogu Raspberry Pi Compute Module 3 (CM3 a CM3L), tj. zmenšené Raspberry Pi vhodné nejenom pro průmyslové využití. Jedná se o nástupce Raspberry Pi Compute Module (CM1) představeného v dubnu 2014. Nový CM3 vychází z Raspberry Pi 3 a má tedy dvakrát více paměti a desetkrát větší výkon než CM1. Verze CM3L (Lite) je dodávána bez 4 GB eMMC flash paměti. Uživatel si může připojit svou vlastní. Představena byla

… více »
Ladislav Hagara | Komentářů: 2
16.1. 01:23 | Nová verze

Oficiálně bylo oznámeno vydání verze 3.0 multiplatformního balíku svobodných kancelářských a grafických aplikací Calligra (Wikipedie). Větev 3 je postavena na KDE Frameworks 5 a Qt 5. Krita se osamostatnila. Z balíku byly dále odstraněny aplikace Author, Brainstorm, Flow a Stage. U Flow a Stage se předpokládá jejich návrat v některé z budoucích verzí Calligry.

Ladislav Hagara | Komentářů: 7
15.1. 15:25 | Nová verze

Bylo oznámeno vydání první RC (release candidate) verze instalátoru pro Debian 9 s kódovým názvem Stretch. Odloženo bylo sloučení /usr jako výchozí nastavení v debootstrap. Vydán byl také Debian 8.7, tj. sedmá opravná verze Debianu 8 s kódovým názvem Jessie.

Ladislav Hagara | Komentářů: 6
15.1. 13:37 | Zajímavý projekt

1. ledna byl představen projekt Liri (GitHub). Jedná se o spojení projektů Hawaii, Papyros a původního projektu Liri s cílem vyvíjet operační systém (linuxovou distribuci) a aplikace s moderním designem a funkcemi. Včera byl představen Fluid 0.9.0 a také Vibe 0.9.0. Jedná se o toolkit a knihovnu pro vývoj multiplatformních a responzivních aplikací podporující Material Design (Wikipedie) a volitelně také Microsoft Design Language (designový jazyk Microsoft) [reddit].

Ladislav Hagara | Komentářů: 8
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 309 hlasů
 Komentářů: 24, poslední včera 10:14
    Rozcestník
    Reklama

    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: 305×
    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: 50 | 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: 50 | 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: 44 | 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.