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 05:55 | Komunita

Dries Buytaert, autor a vedoucí projektu Drupal a prezident Drupal Association, požádal soukromě před několika týdny Larryho Garfielda, jednoho z klíčových vývojářů Drupalu, aby projekt Drupal opustil. Larry Garfield minulý týden na svých stránkách napsal, že důvodem jsou jeho BDSM praktiky a rozpoutal tím bouřlivou diskusi. Na druhý den reagoval Dries Buytaert i Drupal Association. Pokračuje Larry Garfield [reddit].

Ladislav Hagara | Komentářů: 15
dnes 04:44 | Humor

Společnost SAS zveřejnila na svých stránkách studii s názvem Open Source vs Proprietary: What organisations need to know (pdf). Organizace by měly například vědět, že ideální je mix 40 % open source softwaru a 60 % proprietárního softwaru [Slashdot].

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

Byl vydán ShellCheck ve verzi 0.4.6. Jedná se o nástroj pro statickou analýzu shellových skriptů. Shellové skripty lze analyzovat na webové stránce ShellChecku, v terminálu nebo přímo z textových editorů. Příklady kódů, na které analýza upozorňuje a doporučuje je přepsat. ShellCheck je naprogramován v programovacím jazyce Haskell. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GPLv3.

Ladislav Hagara | Komentářů: 0
včera 23:33 | Pozvánky

Czech JBoss User Group zve na setkání JBUG v Brně, které se koná ve středu 5. dubna 2017 v prostorách Fakulty informatiky Masarykovy univerzity v místnosti A318 od 18:00. Přednáší Pavol Loffay na téma Distributed Tracing and OpenTracing in Microservice Architecture.

… více »
mjedlick | Komentářů: 0
včera 11:33 | Zajímavý článek

Národní centrum kybernetické bezpečnosti (NCKB) vypracovalo (pdf) 26 podrobných bezpečnostních doporučení pro síťové správce. Tato doporučení jsou nastavena tak, aby je bylo možné aplikovat v každé instituci. Jsou rozdělena na tři základní části: bezpečnost infrastruktury, bezpečnost stanic a serverů a bezpečnost uživatelů.

Ladislav Hagara | Komentářů: 14
včera 05:55 | Komunita

Prezident Nadace pro svobodný software (FSF) Richard M. Stallman vyhlásil na slavnostním ceremoniálu v rámci konference LibrePlanet 2017 vítěze Free Software Awards za rok 2016. Ocenění za společenský přínos získal SecureDrop (Wikipedie). Za rozvoj svobodného softwaru byl oceněn Alexandre Oliva (Wikipedie).

Ladislav Hagara | Komentářů: 0
včera 04:44 | Nová verze

Byla vydána verze 0.7.0 debugovacího nástroje cgdb. Mezi novinky patří například zvýrazňování syntaxe jazyka Rust. Podrobnosti v poznámkách o vydání.

Neel | Komentářů: 0
25.3. 22:00 | Komunita

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 (podcast) detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 64 tisíc vývojářů. Jejich nejmilovanější platformou je linuxový desktop. Ten je také druhou nejpoužívanější platformou vývojářů.

Ladislav Hagara | Komentářů: 7
24.3. 11:55 | Komunita

Vývojový tým OpenSSL ve spolupráci s iniciativou Core Infrastructure konsorcia Linux Foundation spustil proces přelicencování této kryptografické knihovny ze současné licence na licenci Apache Licence v 2.0 (ASLv2). Nová licence usnadní začleňování OpenSSL do dalších svobodných a open source projektů. Všichni dosavadní vývojáři OpenSSL (Authors) obdrží v následujících dnech email s prosbou o souhlas se změnou licence.

Ladislav Hagara | Komentářů: 32
24.3. 01:11 | Komunita

Před třemi týdny Mozilla.cz představila projekt Photon, jehož cílem je návrh a implementace nového vzhledu Firefoxu. Včera zveřejnila první náhled vzhledu Photon. Práce na projektu Photon jsou rozděleny do pěti týmů, které celkem čítají 19 lidí. Zaměřují se na zlepšení prvního spuštění Firefoxu a zaujetí nových uživatelů, celkovou úpravu vzhledu, zlepšení animací, zrychlení odezvy uživatelského rozhraní a také upravení nabídek. Vývoj lze sledovat v Bugzille.

Ladislav Hagara | Komentářů: 50
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (14%)
 (2%)
 (71%)
 (3%)
 (10%)
Celkem 949 hlasů
 Komentářů: 72, poslední 1.3. 11:16
    Rozcestník

    Dotaz: zavreny soket je porad aktivni

    20.9.2005 17:38 Frantisek Fencl
    zavreny soket je porad aktivni
    Přečteno: 116×
    Zdravim, mam nasledujici dotaz: delam program (v C), ktery komunikuje s webserverem na portu 1719. Hlavni cast zdrojaku:

    #define MAX 100
    #define EXIT_FAILURE 0
    #define EXIT_SUCCESS 1
    #define PORT 1719
    #define BACKLOG 10 //how many pending connections will stay in front
    #define BUFLEN 200 //how long (max) will be recieving message

    int recok, len, max, retval, mainSocket, clientSocket;
    struct sockaddr_in sockName, clientName;
    char message[BUFLEN], buffer[BUFLEN], end_seq[3] = "666";

    /* 1 - Creating a socket */
    if ((mainSocket = socket(PF_INET,SOCK_STREAM,0)) == -1) // vytvoreni soketu main - naslouchaci soket
    {
    printf("%s\n","Cannot create a communication socket");
    exit(EXIT_FAILURE);
    }

    /* Naming a socket */
    sockName.sin_family = AF_INET; // protokoly TCP/IP
    sockName.sin_port = htons(PORT); // preklad na sitovou adresu - univerzalni format
    sockName.sin_addr.s_addr = INADDR_ANY; // INADDR_ANY je IP adresa stroje
    memset(&(sockName.sin_zero),'\0',8); // vyplneni 8-mi zbylych bytu nulou
    retval = bind(mainSocket, (struct sockaddr *) &sockName, sizeof(sockName)); // pojmenovani soketu

    /* The Big Loop */
    while (1)
    {
    retval = listen(mainSocket,BACKLOG); // naslouchani na soketu
    retval = sizeof(clientName);
    clientSocket = accept(mainSocket, (struct sockaddr *) &clientName, &retval); //vytvoreni komunikacniho soketu
    if ((len = recv(clientSocket, buffer, BUFLEN - 1, 0)) > 0) //prijem zpravy ze soketu (cislo), len je delka zpravy v bajtech
     {
      buffer[len] = '\0';
      printf("%s %s\n","Recieved number:",buffer);
      strcpy(message,"Number was recieved successfully\0");
     }
    else
     {
      printf("%s\n","Nothing was send");
      strcpy(message,"Number was not recieved\0");
     }
    send(clientSocket,message,sizeof(message),0);
    printf("%s %s%s\n","Message\"",message,"\"was sent to Apache");
    close(clientSocket); //uzavreni soketu
    if ((strcmp(buffer, end_seq)) == 0)
     {
      close(mainSocket);
      exit(EXIT_FAILURE);
     }
    }

    Na opacne strane je PHP skript:

    $number = $_REQUEST["number"];
    $socket = FSockOpen("127.0.0.1",1719);
    $writeok = FPuts($socket,$number);
    $message = FGetS($socket,200);
    $close_sock = FClose($socket);

    Vsechno vypada v poradku, obe strany zaviraji po komunikaci soket. Kdyz ale vypisu sokety pomoci socklist, vzdycky tam najdu ten chteny naslouchaci soket ale taky soket co nechci:

    tcp 1719 36764 2001 11500 4 konfd
    tcp 1719 0 0 0 0

    Ten nechteny soket se vzdycky tak cca po 50 sekundach ztrati, ale problem je, kdyz posilam vic cisel za sebou, tak mi to potom vyhodi "Segmentation fault".
    Diky za pomoc

    Odpovědi

    Luboš Doležel (Doli) avatar 20.9.2005 17:43 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Stav toho socketu je TIME_WAIT ne? Pokud ano, tak je vše v pořádku.
    20.9.2005 18:02 Frantisek Fencl
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Tak nevim, po spusteni programu je vypise socklist pouze ten chteny soket (mainSocket), po prvnim prijeti cisla, kdy je vytvoren a zavren soket "clientSoket" se objevi dalsi soket v socklistu. Nevidim duvod proc by se tam mel objevit dalsi soket. Pokud se mylim, prosim o vysvetleni :)
    Luboš Doležel (Doli) avatar 20.9.2005 18:13 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Nevím, co je to socklist, ale co ukáže netstat?
    20.9.2005 18:31 Frantisek Fencl
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Aha, v netstatu se objevi taky o soket vic:

    Local Address Foreign Address State User Inode
    localhost:1719 localhost:2140 TIME_WAIT root 0

    Normalne je tam jenom:

    Local Address Foreign Address State User Inode
    *:1719 *:* LISTEN frankie 75147

    Jak se mam ale toho soketu zbavit?
    Josef Kufner avatar 20.9.2005 19:18 Josef Kufner | skóre: 67
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    TIME_WAIT znamena, ze socket je už mrtvý a čeká se na nějaký timeout, aby to obě strany věděly jistě. Je to naprosto normální a není to chyba. Taky to nijak nepřekáží, pokud nejde o poslouchací socket serveru, poté co server chcípne a chce znovu poslouchat na tomtéž portu.
    Hello world ! Segmentation fault (core dumped)
    20.9.2005 19:31 Frantisek Fencl
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Ted jsem zjistil, ze mi probehnou v pohode tri spojeni a vzdycky pri ctvrtym to spadne - tak to jsem z toho fakt jelen :)
    20.9.2005 18:41 petr_p
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Hledejte volbu SO_REUSEADDR v socket(7).
    20.9.2005 19:21 Frantisek Fencl
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Nasel jsem:

    int yes = 1;
    setsockopt(mainSocket, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(yes)

    ale nic to nepomaha - chova se to porad stejne
    23.9.2005 11:29 petr_p
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Kotroluj navratovy hodnoty a ruzne chybove stavy.

    Napr. fce recv() muze vratit 0, coz znamena, ze druha strana zavrela spojeni, ale ty se stejne pokousis do nej neco poslat pomoci send() a pak fci strcmp() ctes z bufferu, ktery napr. nemusi obsahovat '\0', cimz uteces z alokovane pameti pro buffer[BUFLEN] a jadro ti posle SIGSEGV.

    Zkousel jsi to vubec debugovat? Skompiluj to s volbou -g, pak to pust pres nejaky debugger az to spadne, tak se podivej kde a jake jsou hodnoty prommenych.
    23.9.2005 16:34 Beda
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    stav toho soketu je v netstatu popsan jako finwait nebo finwait2, ne?

    to znamena, ze probiha rozpojovani cekani na paket s reset flagem a dokonce i po rozpojeni je soket jeste nejakou dobu podrzeny, aby ho nekdo nepouzil, protoze tcp pakety muzou prijit vice nez jednou.
    23.9.2005 16:37 Beda
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    asi sockName.sin_port zmenit tak, aby odchozi port byl any a cilovy port byl PORT?
    2.10.2005 17:00 Frantisek Fencl
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Diky vsem za pomoc, chyba byla jinde. Aspon jsem se naucil neco noveho
    2.10.2005 17:16 Zdeněk Burda | skóre: 61 | blog: Zdendův blog | Praha
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Co kdybys napsal, kde?
    -- Nezdar není hanbou, hanbou je strach z pokusu.
    23.5.2006 02:12 czfrankie | skóre: 8 | blog: frankie
    Rozbalit Rozbalit vše Re: zavreny soket je porad aktivni
    Chyba s tím vůbec nesouvisela, zapisoval jsem do soubou, který neexistoval :). Dvakrát to prošlo a potřetí už ne
    Tak zahraj, ať víme jakej seš

    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.