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í
×
    včera 21:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | Zajímavý software

    Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.

    Ladislav Hagara | Komentářů: 0
    13.6. 15:22 | IT novinky

    Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.

    Ladislav Hagara | Komentářů: 7
    13.6. 02:22 | Nová verze

    Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.

    Ladislav Hagara | Komentářů: 0
    12.6. 16:33 | Bezpečnostní upozornění

    V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.

    Ladislav Hagara | Komentářů: 13
    12.6. 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    12.6. 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

    Ladislav Hagara | Komentářů: 2
    11.6. 14:11 | Komunita

    Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.

    Ladislav Hagara | Komentářů: 5
    11.6. 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    11.6. 04:44 | Nová verze

    Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.

    Ladislav Hagara | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1908 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: Neblokujici operace se socketem

    9.12.2010 12:43 roman
    Neblokujici operace se socketem
    Přečteno: 541×

    Dobry den, trochu si hraji se socketama v linuxu, takovy maly chat jen mezi dvema pocitaci, jednoduse se pripojim k druhemu stroji, ten muze poslat data nebo naopak je mohu poslat ja.

    Mam trochu problem jak do jednoho programu vmesnat i to odesilani, umim prijimat data, cekam v nekonecne smycce a ctu data ze socketu, pokud se nejaka objevi tak je jen zobrazim.

    Lze nejak zaridit neblokujici volani read? Abych mohl dovolit uzivateli v tu chvili i zadavat data, ukoncit enterem a odeslat?

    Nebo lze nejak zaridit, aby se po prichodu dat vyvolava nejaka mnou definovana fce? Nebo treba signal.

    Nebo tuto ulohu musim rozdeli do vlakna ve kterem budu jen cist data ze site a v hlavnim main programu budu cekat na uzivatelsky vstup a ten odesilat do site?

    Jo abych nezapomel, pisu to v jazyce C.

    Dekuji za info jak toto vyresit.

    Odpovědi

    9.12.2010 13:03 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Chcete-li neblokující čtení, můžete buď použít příznak O_NONBLOCK rovnou při volání open() nebo ho následně nastavit pomocí fcntl(). U socketu to asi jde jen tím druhým způsobem. Obvykle dávám přednost čtení v samostatném threadu nebo procesu, ale ve vašem případě bude možná neblokující čtení v kombinaci s poll() (nebo select()) jednodušší.
    9.12.2010 14:50 roman
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Dekuji na informaci, zkusim variantu s vlaknem pro cteni, nebyl by nejaky example?
    9.12.2010 15:03 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Příloha:
    Zkuste se podívat do přílohy, jsou tam tři různé implementace serveru pro službu time (nebo daytime, nikdy si nepamatuji, která je která), mp-poll funguje pomocí poll(), mp-fork používá samostatné procesy a mp-thread samostatná vlákna. Není to sice zrovna to, co byste potřeboval (tahle služba od klienta nic nečte), ale třeba vám to k něčemu bude.
    9.12.2010 22:31 roman
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    dekuji mnohokrat, prostuduji to.
    10.12.2010 08:04 Pavel Löbl | skóre: 7 | blog: vadnej_pixel
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Pouziti select je zde asi fakt jednodussi nez vlakna nebo procesy. Takhle by to mohlo jit, ale netvrdim ze to je nejlepsi reseni :) Je to jen navrh, bylo by asi jeste potreba cekat na konec zpravy (nejaky oddelovac), neni zaruceno ze ji prectete celou jednim volanim recv. atd
    
    int sock;
    
    ...
    
    struct timeval timeout;
    timeout.tv_usec = 0;
    	
    char buffer[BUFFER_SIZE];
    ssize_t ret;
    fd_set sock_set;
    
    FD_ZERO(&sock_set);
    		
    while(1)
    {
      timeout.tv_sec = TIMEOUT;
    
      /* nastaveni deskriptoru ktere budem sledovat */
      FD_SET(sock, &sock_set);
      FD_SET(STDIN_FILENO, &sock_set);	
    
      /* sledovani deskriptoru */		
      if((ret = select(MAX(sock, STDIN_FILENO)+1, &sock_set, 0, 0, &timeout)) == -1)
          /* osetreni chyby */
    
      /* pokud lze cist ze socketu */	
      if(FD_ISSET(sock, &sock_set))
      {
        if((ret = recv(sock, buffer, BUFFER_SIZE, O_NONBLOCK) == -1)
          /* osetreni chyby */
    
        if(ret == 0)
          break;
    			
        if((ret = write(STDOUT_FILENO, buffer, ret)) == -1)
          /* osetreni chyby */
      }		
    
      /* pokud lze cist ze std. vstupu */	
      if(FD_ISSET(STDIN_FILENO, &sock_set))
      {
        if((ret = read(STDIN_FILENO, buffer, BUFFER_SIZE)) == -1)
          /* osetreni chyby */ */
    	
        if(ret == 0)
          break;
    
        if((ret = send(sock, buffer, ret, O_NONBLOCK) == -1)
          /* osetreni chyby */
      }	
    
      ... 
    
    }
    11.12.2010 18:50 Mr.S1lent.cz
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Co takhle normalne pouzit neblokujici rezim socketu? :-)
    int oldFlag = fcntl( sock_id, F_GETFL, 0 );
    fcntl( sock_id, F_SETFL, oldFlag | O_NONBLOCK );
    
    11.12.2010 19:05 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Viz #1.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)

    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.