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 14:44 | Pozvánky

Spolek OpenAlt zve příznivce otevřených technologií a otevřeného přístupu na 151. brněnský sraz, který proběhne v pátek 20. 4. od 18:00 hodin v restauraci Benjamin na Drobného 46.

Ladislav Hagara | Komentářů: 0
včera 13:33 | Nová verze

Byla vydána verze 18.04.0 KDE Aplikací (KDE Applications). Přehled novinek v kompletním seznamu změn a na stránce s dalšími informacemi.

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

Bylo oznámeno vydání nové stabilní verze 1.26 a beta verze 1.27 open source textového editoru Atom (Wikipedie). Přehled novinek i s náhledy v příspěvku na blogu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
včera 12:55 | Komunita

Dle plánu byla dnes vydána hra Rise of the Tomb Raider (Wikipedie) pro Linux. Koupit ji lze za 49,99 €.

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

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno bylo celkově 254 bezpečnostních chyb. V Oracle Java SE je například opraveno 14 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 12 z nich. V Oracle MySQL je opraveno 33 bezpečnostních chyb. Vzdáleně zneužitelné bez autentizace jsou 2 z nich.

Ladislav Hagara | Komentářů: 3
18.4. 23:11 | Nová verze

Byla vydána verze 8.0 linuxové distribuce Trisquel GNU/Linux. Nejnovější verze Trisquel nese kódové jméno Flidas a bude podporována do roku 2021. Výchozím prostředím je nově MATE 1.12. Trisquel patří mezi svobodné distribuce doporučované Nadací pro svobodný software (FSF).

Ladislav Hagara | Komentářů: 0
18.4. 16:00 | Nová verze

Byla vydána nová verze 27.9.0 webového prohlížeče Pale Moon (Wikipedie) vycházejícího z Firefoxu. Přehled novinek v poznámkách k vydání. Jedná se o poslední větší aktualizaci verze 27. Vývojáři se zaměří na novou verzi 28.

Ladislav Hagara | Komentářů: 0
18.4. 12:00 | Nová verze

Google Chrome 66 byl prohlášen za stabilní (YouTube). Nejnovější stabilní verze 66.0.3359.117 tohoto webového prohlížeče přináší řadu oprav a vylepšení. Vylepšeny byly také nástroje pro vývojáře (YouTube). Opraveno bylo 62 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 0
18.4. 06:00 | Nová verze

Byla vydána druhá RC verze nové řady 2.10 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP. Přehled novinek i s náhledy v oznámení o vydání.

Ladislav Hagara | Komentářů: 0
17.4. 23:39 | Pozvánky

Již tento čtvrtek (19. 4.) se v posluchárně 107 na Fakultě informačních technologií ČVUT v Praze Dejvicích odehraje večer s Turrisem, tentokrát zaměřený na nový modulární router MOX. Mluvit o něm budou Patrick Zandl a Ondřej Filip, ale bude i prostor pro dotazy a diskuzi s vývojáři. Akce začíná v 18:00 a plánovaný konec je v 19:45. Mapka, kde se nachází daná posluchárna, a možnost registrace je k dispozici na webu CZ.NIC.

Miška | Komentářů: 0
Používáte na serverech port knocking?
 (2%)
 (7%)
 (47%)
 (27%)
 (16%)
Celkem 323 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    Rozcestník

    Dotaz: Sucasene citanie a zapis zo soketu - chat klient

    11.12.2005 17:53 Miso Miso | skóre: 1
    Sucasene citanie a zapis zo soketu - chat klient
    Přečteno: 60×
    Ahojte,

    pokusam sa napisat chat program(server a klient). Server cast riesim pomocou klasickeho selectu. Problem mam pri programovani klienta. Totiz potrebujem zaroven citat a zapisovat do soketu, ktorym je klient pripojeny na server.

    Citat potrebujem neustale(server moze poslat spravu od ostatnych klientov v ktoromkolvek okamihu - tuto spravu musim vypisat). Zapisovat potrebujem po tom, co pouzivatel zada spravu na odoslanie.

    Zatial som to spravil tak, ze jeden thread cita zo soketu a druhy thread cita z prikazoveho riadku a po stlaceni enter zapise do soketu text. Cize z dvoch threadov zaroven zapisujem a citam z jedneho soketu. Klient sa tvari tak, ze to funguje ale pochybuje o bezpecnosti tohto riesenia.

    Dalsia moznost je zaregistrovat soket do mnozin na zapis a citanie (FD_SET). A pomocou select citat zo soketu a zapisovat do soketu (ak je pripraveny text na zapis). Taketo riesenie vsak spotrebuje 100% procesoroveho casu pretoze soket je vzdy pripraveny na zapis a teda select ihned skonci.

    Este som rozmyslal nad tym, ze potom ako uzivatel napise spravu modifikujem mnozinu soketov cakajucich na zapis. toto vsak tiez nie je asi najbezpecnejsie riesenie :).

    Ako by ste riesili klienta?

    Za cennu radu dakujem Michal

    Odpovědi

    Luboš Doležel (Doli) avatar 11.12.2005 17:55 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Tak si mezi selecty dejte usleep().
    11.12.2005 22:29 Miso Miso | skóre: 1
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    toto riesenie sa mi vidi take hackerske obidenie problemu :), co sa mi velmi nepaci.
    11.12.2005 18:09 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Zatial som to spravil tak, ze jeden thread cita zo soketu a druhy thread cita z prikazoveho riadku a po stlaceni enter zapise do soketu text. Cize z dvoch threadov zaroven zapisujem a citam z jedneho soketu. Klient sa tvari tak, ze to funguje ale pochybuje o bezpecnosti tohto riesenia.

    Pokud to ošetříte mutexem, neviděl bych v tom problém. Nebo když použijete streamové funkce, které to zamykají automaticky.

    Este som rozmyslal nad tym, ze potom ako uzivatel napise spravu modifikujem mnozinu soketov cakajucich na zapis. toto vsak tiez nie je asi najbezpecnejsie riesenie

    Proč? Ale asi bych použil spíš poll(), tam si nemusíte hrát s těmi nepřehlednými množinami a jen přehazujete jeden příznak. Nebo jste to myslel tak, že byste změnil množinu, zatímco v druhém threadu běží ten select()? To by asi opravdu nešlo.

    11.12.2005 22:36 Miso Miso | skóre: 1
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Pokud to ošetříte mutexem, neviděl bych v tom problém. Nebo když použijete streamové funkce, které to zamykají automaticky.

    neviem ci sme sa pochopili. Ja v tom vidim problem asi taky, ze ked spravim v jednom threade synchornizovany recv pomocou mutexu a do soketu sa nikdy nic nepride, potom sa v druhom threade nidky nedostanem k zapisu do soketu. Inak by som musel pouzit neblokovaci rezim, taketo riesenie by vsak bolo velmi neefektivne pretoze recv by stale okamzite skoncil a hned na to by sa spustal znova.

    Okrem toho mate pravdu, druhe riesenie asi naozaj nepojde.
    11.12.2005 23:34 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Myslel jsem to spíš tak, že v jednom threadu by čekal poll(), až bude možné číst, a mutex by se zamykal až na samotný read(). Ve druhém threadu by se zamkl mutex na zápis, když by bylo potřeba. To by mělo projít, ale nezkoušel jsem to.
    11.12.2005 18:12 maleprase | skóre: 28
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    pres select kontroluj akorat cteni. zapis provadis stejne az ve chvili kdy mas neco ve vstupni fronte kterou muzes kontrolovat vzdy po selectu nebo po jeho timeoutu.
    11.12.2005 18:30 #Tom
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Mně se také zalíbíl poll - pole se nachystalo jenom jednou a čistěji. Také jsem psal kecací prográmek (jako úlohu do prográmka v C). Žádná vlákna ani podprocesy jsem nepotřeboval ani u klienta, ani u serveru. Jinak se mi osvědčilo u klienta hlídat funkcí poll i standardní vstup, takže šlo snadno obsloužit jak psaní na klávesnici, tak přijímání zpráv.
    11.12.2005 18:47 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    V tomto případě opravdu stačí select() nebo poll(). Řešení pomocí threadů nebo samostatných procesů je vhodnější tam, kde je větší množství klientů a vyřízení požadavku trvá netriviální dobu (protože během vyřizování jednoho požadavku se nemůžete bavit s dalšími klienty).
    11.12.2005 22:46 Miso Miso | skóre: 1
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Naozaj super napad. pollovat standardny vstup. dakujem. Momentalne vsak este neviem ci riesenie nebude zalozene na ncurses. V tom pripade by som do jedneho okna zapisoval a z druheho cital. teda by som potreboval zavesit poll na ncurses okno.

    Nakoniec to asi spravim tak ako mi niekto poradil v predchadzajucom prispevku. nastavim do selectu nejaky "rozumny" timeout a stale ked select skonci tak sa pozriem do fronty sprav ci mozem nieco zapisat a ak ano tak to zapisem. Je to sice dost nepruzne ale aspon bezpecne riesenie a nezabera tolko proceseroveho casu. (ako napr. zaregistrovanie soketu aj na zapis - vtedy sa select skonci hned)

    Ak niekoho napadne lepsie riesenie este sa ozvite. Chcelo by to nejaky asynchronny soket :), ktoremu by som nastavil callbacky na send a receive :).

    Zatial dakujem, michal
    11.12.2005 22:49 #Tom
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Můžete se kouknot na moje řešení (cv9), ale moc uhlazený kód tam není, tento program byl napsán v ještě větším spěchu než ostatní (za 3-4 dny) a kvalitou nepřekypuje.
    11.12.2005 23:45 Miso Miso | skóre: 1
    Rozbalit Rozbalit vše Re: Sucasene citanie a zapis zo soketu - chat klient
    Dakujem za riesenie. trochu som zazmatkoval, ked som povedal ze treba poll zavesit na okno :). jasne ze na poll staci zavesit standardny vstup, kedze ncurses tiez iba citaju standardny vstup, ked pouzijem wgetch(). Sory ze som sa takto pomylil a tym Vas este otravoval.

    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.