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 01:22 | Nová verze Ladislav Hagara | Komentářů: 0
    dnes 00:55 | Zajímavý projekt

    PyXL je koncept procesora, ktorý dokáže priamo spúštat Python kód bez nutnosti prekladu ci Micropythonu. Podľa testov autora je pri 100 MHz približne 30x rýchlejší pri riadeni GPIO nez Micropython na Pyboard taktovanej na 168 MHz.

    vlk | Komentářů: 0
    včera 19:44 | Nová verze

    Grafana (Wikipedie), tj. open source nástroj pro vizualizaci různých metrik a s ní související dotazování, upozorňování a lepší porozumění, byla vydána ve verzi 12.0. Přehled novinek v aktualizované dokumentaci.

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

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2025-05-06. Přehled novinek v příspěvku na blogu Raspberry Pi a poznámkách k vydání. Pravděpodobně se jedná o poslední verzi postavenou na Debianu 12 Bookworm. Následující verze by již měla být postavena na Debianu 13 Trixie.

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

    Richard Stallman dnes v Liberci přednáší o svobodném softwaru a svobodě v digitální společnosti. Od 16:30 v aule budovy G na Technické univerzitě v Liberci. V anglickém jazyce s automaticky generovanými českými titulky. Vstup je zdarma i pro širokou veřejnost.

    Ladislav Hagara | Komentářů: 16
    včera 03:55 | Komunita

    sudo-rs, tj. sudo a su přepsáné do programovacího jazyka Rust, nahradí v Ubuntu 25.10 klasické sudo. V plánu je také přechod od klasických coreutils k uutils coreutils napsaných v Rustu.

    Ladislav Hagara | Komentářů: 0
    6.5. 22:11 | Nasazení Linuxu

    Fedora se stala oficiální distribucí WSL (Windows Subsystem for Linux).

    Ladislav Hagara | Komentářů: 2
    6.5. 13:22 | IT novinky

    Společnost IBM představila server IBM LinuxONE Emperor 5 poháněný procesorem IBM Telum II.

    Ladislav Hagara | Komentářů: 1
    6.5. 04:55 | Nová verze

    Byla vydána verze 4.0 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Přehled novinek v poznámkách k vydání. Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 1
    6.5. 00:33 | Komunita

    Podpora Windows 10 končí 14. října 2025. Připravovaná kampaň Konec desítek (End of 10) může uživatelům pomoci s přechodem na Linux.

    Ladislav Hagara | Komentářů: 34
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (3%)
     (1%)
     (1%)
     (3%)
    Celkem 551 hlasů
     Komentářů: 26, poslední dnes 09:58
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    24.1.2014 17:41 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Systemovy daemon pomoci select()
    Ahoj,

    mam za ukol napsat daemona v C jako takovou nahradu za syslog.

    Daemon přijímá data z pojmenované roury, zapisovat do tohoto souboru smí kdokoliv. Prvním parametrem daemona je název souboru, do kterého bude zapisovat události ve tvaru
    time caller: message
    A dale vytvorit knihovnu s funkcí pro zápis do této roury. dalším parametrem daemona je interval, ve kterém daemon zapisuje vlastní statistiku (počet obdržených zpráv) do syslogu.

    Daemon jsem napsal pomoci fce select(), ale nemuzu odstranit chybu, ktera spociva v ukonceni programu pote, co si precte prvni zpravu z roury a korektne ji zapise do zadaneho logu.

    V nasledujicim prubehu WHILE funkce select vrati hodnotu vetsi nez nula, jakoby dosla dalsi zprava, ale funkce read vrati nulu. Zajimalo by me, kde je chyba. Je to nekde v souboru s rourou, nebo v samotnem spatnem pouziti select ?

    Kod daemona:
    /*
     
    #define DEFAULT_INTERVAL 2
    #define SIZE 256
    
    char* get_current_time() {
    
        
            time_t current_time;
            char* c_time_string;
            int j;
            current_time = time(NULL); /* Obtain current time as seconds elapsed since the Epoch. */
     
            if (current_time == ((time_t)-1)) {
                
                    (void) fprintf(stderr, "Failure to compute the current time.");
                    exit(EXIT_FAILURE);
            }
                           
            c_time_string = ctime(¤t_time);  /* Convert to local time format. */
                                                   
            for ( j = 0; c_time_string[j] != '\n'; j++)  /*Get rid EOL*/
                                    ;                          
            c_time_string[j] = '\0';
     
            if (c_time_string == NULL) {
                
                    (void) fprintf(stderr, "Failure to convert the current time.");
                    exit(EXIT_FAILURE);
            }
            
            return c_time_string;   
    }
    
    void print_help() {
    
            printf("Programme must be run with with 2 arguments:\n"
                "argv[1] is a name of the file which the daemon wil be writting in\n"
                "argv[2] is an interval the daemon will be sending logs into syslog\n");
    }
    
    int main(int argc, char *argv[]) {
    
            if (argc != 3) {
        
                    print_help();
                    exit(1);
            }
            
            int c;
            while((c = getopt(argc, argv, "h")) != -1) {
    
                    switch (c) {
    
                    case 'h':
                            print_help();
                            break;
                            
                    case '?':
                            printf("try -h for help");
                            break;
                    default:
                        break;
                    }
    
            }
        
    
            FILE *fw;
            int fp;
            char buf[SIZE];
        char *linesep;
            int line, i, count; 
            buf[0] = '\0'; // in case there is nothing to read
            buf[SIZE] = '\0'; // guarentee a end-of-line
            fd_set readfds;
            struct timeval timeout;
            int r;
            int interval = atoi(argv[2]);
        openlog ("exampleprog", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
            
        fprintf(stderr, "Daemonizing...\n");    
        //daemon(0,0);
    
        unlink("/tmp/pb173_syslog");
            mkfifo("/tmp/pb173_syslog", S_IWUSR | S_IRUSR | S_IRGRP | S_IROTH);
        
            fp = open("/tmp/pb173_syslog", O_RDONLY | O_NONBLOCK);
    
            if(fp == -1) {
            syslog (LOG_CRIT, "Could not open the pipe: %s\n", strerror(errno));
                    exit(1);
            }
    
        fw = fopen(argv[1], "a+");
    
            if(fw == NULL) {
            openlog ("exampleprog", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
            syslog (LOG_CRIT, "Error openning logfile : %s\n", strerror(errno));
                    exit(1);
            }
    
            
            timeout.tv_sec = interval; 
            timeout.tv_usec = 0;
            count = 0;
           
        line = 0; 
        r = 0;
            while(1) {        
            FD_ZERO(&readfds);
            FD_SET(fp,&readfds);
                    r = select(fp+1, &readfds, NULL, NULL, &timeout);
            if (r == -1) {
                openlog ("daemon", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
                syslog (LOG_CRIT, "Error openning logfile : %s\n", strerror(errno));
                close(fp);
                fclose(fw);
                exit(1);
            }
                if (r == 0) {
                timeout.tv_sec = interval;
                timeout.tv_usec = 0;
                setlogmask (LOG_UPTO (LOG_NOTICE));    
                            openlog ("daemon", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
                            syslog (LOG_NOTICE, "Number of received messages: %d\n", count ); 
                            closelog ();        
            } else {
                line += (r = read(fp, buf+line, SIZE-line-1));
                if (r == 0) {
                    close(fp);
                    fclose(fw);
    
                    exit(EXIT_SUCCESS);
                }
                buf[line] = '\0';
    
                if (line && (linesep = strstr(buf, "\n"))) { 
                    *linesep = '\0';
                    char *caller;
                    int callerLength;
                    char *message;
                    caller = strtok(buf, "^");
                    callerLength = strlen(caller);
                    message = caller + callerLength + 1;
                    fprintf(fw, "%s %s: %s\n", get_current_time(), caller, message);
                    fflush(fw);
                    memmove(buf, linesep + 1, (line = strlen(linesep + 1)) + 1);                
                    count++;
                        }
                    }       
            }
            
            close(fp);
            fclose(fw);
    
            exit(EXIT_SUCCESS);
    }
    
    
    A kod funkce, ktera zapisuje do roury:
    
    int sl_log(const char *caller, const char* message) {
        
        int fp;
        fp = open("/tmp/pb173_syslog", O_WRONLY);
        char *msg;
    
        if (fp == -1) {
            perror("Could not open the pipe\n");
            exit(1);
        }
        
        asprintf(&msg, "%s^%s\n", caller, message);
        write(fp, msg, strlen(msg));
        free(msg);
        close(fp);
        return 0;
    } 
    

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.