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 17:22 | Nová verze

Node.js Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 10.0.0 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). Verze 10 se v říjnu stane novou aktivní LTS verzí. Podpora je plánována do dubna 2021.

Ladislav Hagara | Komentářů: 0
dnes 15:33 | Nová verze

Neal Cardwell ze společnosti Google oznámil zveřejnění verze 2.0 nástroje pro testování síťového stacku packetdrill. Jde o souhrnné vydání změn z interního vývoje od roku 2013.

Michal Kubeček | Komentářů: 0
dnes 13:22 | Zajímavý software

Microsoft na svém blogu oznámil, že správce knihoven pro C++ Vcpkg (VC++ Packaging Tool) lze nově používat také na Linuxu a macOS. Aktuálně je pro Linux k dispozici více než 350 knihoven [reddit].

Ladislav Hagara | Komentářů: 1
dnes 12:44 | Komunita

Byly zveřejněny exploity na Nintendo Switch a platformu Tegra X1: Fusée Gelée a ShofEL2. Jejich zneužití nelze zabránit softwarovou aktualizací. Na druhou stranu exploity umožní na Nintendo Switch snadno a rychle nainstalovat Linux, viz. ukázka na YouTube. Jenom je potřeba sáhnout na hardware.

Ladislav Hagara | Komentářů: 0
dnes 00:55 | Nová verze

Byla vydána verze 2.12.0 QEMU (Wikipedie). Přispělo 204 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn. Řešeny jsou také bezpečnostní chyby Meltdown a Spectre.

Ladislav Hagara | Komentářů: 5
dnes 00:33 | Komunita

Google zveřejnil seznam 1 264 studentů přijatých do letošního Google Summer of Code. Přehled projektů, studentů, 212 organizací a mentorů je k dispozici na stránkách GSoC.

Ladislav Hagara | Komentářů: 0
včera 23:55 | Nová verze

Oracle vydal verzi 1.0 univerzálního virtuálního stroje GraalVM, který umožňuje běh programů napsaných v jazycích založených na JVM, JavaScript, LLVM bitcode a experimentálně Ruby, R a Python.

razor | Komentářů: 1
včera 01:22 | Zajímavý článek

Julia Evans pomocí svých kreslených obrázků proniká do Linuxu a informačních technologií. Vedle ucelených zinů publikuje také jednotlivé kreslené obrázky (RSS).

Ladislav Hagara | Komentářů: 5
23.4. 13:22 | Zajímavý software

Jordi Sanfeliu vydal verzi 1.0.0 svého unixového jádra Fiwix (Wikipedie) určeného také pro výuku operačních systémů. Dle článku na OSNews na něm začal pracovat již před více než dvaceti lety. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Stáhnout a vyzkoušet lze živou disketu nebo CD s GNU/Fiwixem.

Ladislav Hagara | Komentářů: 5
23.4. 06:00 | Nová verze

Byla vydána nová verze 10.7 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab (Wikipedie). Představení nových vlastností v příspěvku na blogu. Vývojáři GitLabu zdůrazňují Web IDE (YouTube) a SAST (Static Application Security Testing) pro Go a C/C++.

Ladislav Hagara | Komentářů: 8
Používáte na serverech port knocking?
 (2%)
 (7%)
 (46%)
 (27%)
 (17%)
Celkem 372 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    Rozcestník

    Dotaz: SIGCLD, system, deamon

    16.7.2004 13:15 honza
    SIGCLD, system, deamon
    Přečteno: 44×
    v minulosti (napr. suse 7.1) mi fungoval deamon program, ktery na zacatku ignoroval SIGCLD. V deamonu se provadelo volani.. ret = system("aaaa_exe"); ret pote obdrzel exit kod provadeneho programu. na novych systemech (suse 9.1) je nyni ret=-1 a errno=10. Kdyz SIGCLD ale neignoruji, tak se hromadi zobie's.

    Nema nekdo poneti, jak je to treba programovat dneska?

    Odpovědi

    16.7.2004 14:43 Maude Lebowski
    Rozbalit Rozbalit vše Re: SIGCLD, system, deamon
    ja tyhle veci neprogramuju pres system, ktery ma omezene pouzivani prave funkci na cekani, ale mam vlastni wraper: ( veci za include musi byt v < > zavorkach)
    /*
    
      execute system utilities, run a specified binary with
      string arguments and return an output as a single string 
    
      $Id$
    
    */
    
    #include unistd.h
    #include stdio.h
    #include stdlib.h
    #include string.h
    #include syslog.h
    #include sys/types.h
    #include sys/wait.h
    
    #define TIMEOUT_SEC 1
    #define TIMEOUT_MSEC 200000
    /* how long we will waiting for childs... */
    
    int exec_command(const char *command, char *const args[], char *output, int len)
    {
    
      /* parameters:
    
      - command is a command (the same meaning as path in exec functions)
      - args[] are arugumets for execvp commands (null terminated array of strins)
      - output is output buffer previously allocated to lenght len
      - len is the max. lenght of output
    
      */
    
      pid_t f;
      int pipa[2];      /* pipa = the tap to get out beer from barel,in czech:-) */
      int i,j,n;
      fd_set rfds;
      struct timeval tv;
    
      if( pipe(pipa) < 0 ) {
        syslog(LOG_ERR,"pipe: %m: cannot create for %s\n",command);
        return(-1);
      }
    
      f = fork();
      if( f < 0 ) {
        syslog(LOG_ERR,"Fork failed. The %s move failed.\n",command);
        return(-1);
      }
      else if( f == 0 ) {
        close(1);
        dup(pipa[1]);
        close(pipa[0]);
        close(pipa[1]);
        fprintf(stderr,"%s %s %s %s\n",command,args[0],args[1],args[2]);
    #ifdef DEBUG
        fprintf(stderr,"%s %s %s %s\n",command,args[0],args[1],args[2]);
    #endif
        if( (j = execvp(command,args)) < 0 ) {
          syslog(LOG_ERR,"execlp %s: %m\n",command);
          /* a child should (!) write any output else a thread is stoped forever 
             (if block-read without select is used in main) or zombie is created */
          write(1,"",len-1);
        }
        exit(j);
      }
      else {
    
        /* use of the non-block input when no data are presented */ 
        n = 0;
        strcpy(output,"");
        FD_ZERO(&rfds);
        FD_SET(pipa[0], &rfds);
        tv.tv_sec = TIMEOUT_SEC;
        tv.tv_usec = TIMEOUT_MSEC;
        if( select(pipa[0]+1, &rfds, NULL, NULL, &tv) ) {
          read(pipa[0],output,len);
        }
        for( i = 0; output[i] != '\0' && i < len ; i++)
          if( output[i] == '\n' )
            output[i] = '\0';
    #ifdef DEBUG
        printf("Child returned: >%s<\n",output);
    #endif
        if( waitpid(f,&i,0) < 0 ) {
          syslog(LOG_ERR,"wait: %m\n");
          return(-1);
        }
        if( !WIFEXITED(i) ) {
          syslog(LOG_ERR,"Child exited with code %d\n",WEXITSTATUS(i)); 
          return(-1);
        }
      }
    
      return(i);
    }
    
    17.7.2004 12:41 honza
    Rozbalit Rozbalit vše Re: SIGCLD, system, deamon
    predem dekuji za zaslany kod. Provedu obsahly test v mem programu a v pripade chyb nebo nesrovnalosti se ozvu.

    P.S.

    'Maude Lebowski' je cool

    'pipa = the tap to get out beer from barel..' to mi pripada ne tak cool - jestli to smim pouzit, tak to vyndam ?

    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.