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 00:11 | Bezpečnostní upozornění

Vývojáři linuxové distribuce Mageia na svém blogu upozorňují na narušení bezpečnosti Mageia Identity. Narušitel získal přístup k LDAP databázi a zveřejnil jména uživatelů, jejich emailové adresy a haše hesel. Hesla uživatelů byla resetována.

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

Byla vydána verze 2.0.0 nástroje pro záznam a sdílení terminálových sezení asciinema (GitHub). Z novinek je nutno upozornit na nový zpětně nekompatibilní formát záznamu asciicast v2. S novým formátem si poradí nové verze asciinema-playeru a asciinema-serveru [Hacker News].

Ladislav Hagara | Komentářů: 0
včera 05:55 | Zajímavý projekt

Dle příspěvku na blogu zaměstnanců CZ.NIC byl spuštěn ostrý provoz služby Honeypot as a Service (HaaS). Zapojit se může kdokoli. Stačí se zaregistrovat a nainstalovat HaaS proxy, která začne příchozí komunikaci z portu 22 (běžně používaného pro SSH) přeposílat na server HaaS, kde honeypot Cowrie (GitHub) simuluje zařízení a zaznamenává provedené příkazy. Získat lze tak zajímavé informace o provedených útocích. K dispozici jsou globální statistiky.

Ladislav Hagara | Komentářů: 2
včera 04:44 | Komunita

Před týdnem společnost Feral Interactive zabývající se vydáváním počítačových her pro operační systémy macOS a Linux oznámila, že pro macOS a Linux vydají hru Rise of the Tomb Raider. Včera společnost oznámila (YouTube), že pro macOS a Linux vydají také hru Total War Saga: Thrones of Britannia. Verze pro Windows by měla vyjít 19. dubna. Verze pro macOS a Linux krátce na to.

Ladislav Hagara | Komentářů: 0
19.2. 21:33 | Nová verze

Byla vydána nová major verze 7.10 svobodného systému pro řízení vztahů se zákazníky (CRM) s názvem SuiteCRM (Wikipedie). Jedná se o fork systému SugarCRM (Wikipedie). Zdrojové kódy SuiteCRM jsou k dispozici na GitHubu pod licencí AGPL.

Ladislav Hagara | Komentářů: 0
19.2. 16:44 | Nová verze

Byla vydána nová verze 0.30 display serveru Mir (Wikipedie) a nová verze 2.31 nástrojů snapd pro práci s balíčky ve formátu snap (Wikipedie). Z novinek Miru vývojáři zdůrazňují vylepšenou podporu Waylandu nebo možnost sestavení a spouštění Miru ve Fedoře. Nová verze snapd umí Mir spouštět jako snap.

Ladislav Hagara | Komentářů: 0
19.2. 14:00 | Komunita

Na Indiegogo běží kampaň na podporu Sway Hackathonu, tj. pracovního setkání klíčových vývojářů s i3 kompatibilního dlaždicového (tiling) správce oken pro Wayland Sway. Cílová částka 1 500 dolarů byla vybrána již za 9 hodin. Nový cíl 2 000 dolarů byl dosažen záhy. Vývojáři přemýšlejí nad dalšími cíli.

Ladislav Hagara | Komentářů: 1
19.2. 11:11 | Nasazení Linuxu

Před dvěma týdny se skupina fail0verflow (Blog, Twitter, GitHub) pochlubila, že se jim podařilo dostat Linux na herní konzoli Nintendo Switch. O víkendu bylo Twitteru zveřejněno další video. Povedlo se jim na Nintendo Switch rozchodit KDE Plasmu [reddit].

Ladislav Hagara | Komentářů: 3
19.2. 05:55 | Komunita

Byla vydána vývojová verze 3.2 softwaru Wine (Wikipedie), tj. softwaru, který vytváří aplikační rozhraní umožňující chod aplikací pro Microsoft Windows také pod GNU/Linuxem. Z novinek lze zdůraznit například podporu HID gamepadů. Aktuální stabilní verze Wine je 3.0, viz verzování. Nejistá je budoucnost testovací větve Wine Staging s řadou experimentálních vlastností. Současní vývojáři na ni již nemají čas. Alexandre Julliard, vedoucí projektu Wine, otevřel v diskusním listu wine-devel diskusi o její budoucnosti.

Ladislav Hagara | Komentářů: 4
18.2. 16:55 | Komunita

Do 22. března se lze přihlásit do dalšího kola programu Outreachy (Wikipedie), jehož cílem je přitáhnout do světa svobodného a otevřeného softwaru lidi ze skupin, jež jsou ve světě svobodného a otevřeného softwaru málo zastoupeny. Za 3 měsíce práce, od 14. května do 14. srpna 2018, v participujících organizacích lze vydělat 5 500 USD.

Ladislav Hagara | Komentářů: 63
Který webový vyhledávač používáte nejčastěji?
 (2%)
 (28%)
 (62%)
 (3%)
 (3%)
 (1%)
 (1%)
 (1%)
Celkem 400 hlasů
 Komentářů: 34, poslední 14.2. 18:44
    Rozcestník

    Dotaz: Rotovani Apache Logu

    1.11.2004 15:01 Martin
    Rotovani Apache Logu
    Přečteno: 497×
    Cau, nevite nekdo jak rotovat logy u apache a logy vubec ? nemam s tim vubec zkusenosti, tet mam nekolik virtualhostu a kazdej ma svuj log, ale mam to hlavne proto, aby kazdej vecer generoval statistiky, myslim ze by mi stacilo, kdyz treba presahne 250 MB, aby se smazal zacatek, kterej se us stejne znova pak negeneruje, nebo jinak to vyresit, ale nevim ,dik za help.

    Odpovědi

    1.11.2004 15:11 jm
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    Co pouzit k tomu urcenou utilitu, napr. logrotate a nastavit ji? ;-)

    U me v Gentoo to napr. vypada takhle:
    /var/log/apache2/*log {
        missingok
        notifempty
        sharedscripts
        postrotate
          /etc/init.d/apache2 reload > /dev/null 2>&1 || true
        endscript
    
    1.11.2004 17:14 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    Co je @#$%! na tom dotazu Nezařaditelného?
    1.11.2004 20:29 Michal Kubeček
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    Mně se osvědčilo nerotovat vůbec a místo toho používat cronolog.
    1.11.2004 20:45 jm
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    Jake to ma vyhody? Dik.
    1.11.2004 21:58 Michal Kubeček
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    Několikrát jsem v různých fórech viděl zmínky o problémech s logrotate na velmi zatížených serverech, které spočívaly v tom, že rotovací skript nestačil včas shodit všechny procesy Apache, takže rotace neproběhla správně. Jestli mne paměť neklame, hlavní zádrhel byl v tom, že při větší zátěži může 'apachectl stop' (nebo ekvivalent) skončit dříve (i výrazně dříve), než jsou ukončeny všechny httpd procesy. Při použití cronologu toto riziko odpadá.

    Na druhou stranu ale mám praktické zkušenosti spíše se servery, kde zátěž vytvářejí především PHP skripty a databáze, takže jsem nikdy nedělal praktické testy, o kolik je cronolog pomalejší než přímý zápis do logu. Nemohu tedy vyloučit, že u serveru, který posílá velké množství statických stránek, může být zvýšení zátěže samotným cronologem nezanedbatelné.
    2.11.2004 13:23 gogo
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu

    jo. stop posle pouze signal a na poravdu pretizenych servrech to muze trvat i nekolik vterin, nez skonci vsechny httpd procesy. cronolog mi jeste porad nevyhovoval, tak jsem misto toho sesmolil (pouzivame to uz pres rok) todle: -u include chybi < > protoze se me s tim nechtelo prepisovat HOWG. -

    #define	_GNU_SOURCE
    #include stdio.h
    #include time.h
    #include string.h
    #include unistd.h
    #include sys/types.h
    #include sys/stat.h
    #include fcntl.h
    #include sys/time.h
    #include errno.h
    #include stdlib.h
    
    #define	DEBUG	fprintf
    
    
    extern int errno;
    
    static int log= -1;
    static char *jmeno=NULL;
    static char *webal=NULL;
    static int firstmem=1;
    char last='\n';
    int findnewline=0;
    
    
    int newlinereset(void);
    void cas(struct tm *plogtime);
    void konci( int);
    void linkwebal(struct tm *caslogu, char *webal, char *prefix);
    void pojmenuj(struct tm *caslogu, char *prefix);
    void otevri( char *jmeno, char *param);
    
    
    int main(int argc, char **argv)
    {
    	struct tm caslogu, casted;
    	struct stat staty;
    	
    	char buff[4096];
    	int ret;
    
    	buff[0]='\0';
    
    	/* neblokuj pri cteni vstupu */
    	fcntl( fileno(stdin), O_NONBLOCK);
    	
    	/* kontrola parametru */
    	if ( argc!=2) {
    		DEBUG(stderr, "spatny pocet argumentu\n");
    		konci(1);
    	}
    
    	/* webalizerovy link */
    	ret= strlen("webalizer") + strlen( argv[1]);
    	webal= malloc( ret+1);
    	strcpy( webal, argv[1]);
    	strcat( webal, "webalizer" );
    	DEBUG( stderr, "%s\n", webal);
    
    	/* vnejsi cyklus, ktery se stara o soubory */
    	do {
    		/* nacti cas */
    		cas(&caslogu);
    		/* vytvor link pro webalizer */
    		linkwebal( &caslogu, webal, argv[1]);
    		/* vytvor jmeno */
    		pojmenuj(&caslogu, argv[1]);
    		/* otevri log soubor */
    		otevri( jmeno, argv[1]);
    
    		/* vnitrni cyklus ktery se stara o cteni a preruseni jen na \n */
    		do {
    			/* smazany log? */
    			ret=stat(jmeno, &staty);
    			if (0!=ret) {
    				DEBUG(stderr, "nekdo smazal soubor? chyba stat(): %s\n",
    						strerror(errno));
    				if (newlinereset()) break;
    			}
    
    			/* kontrola casu */
    			cas(&casted);
    
    			/* zmena dne je zmena logu (na konci radky) */
    			if (caslogu.tm_yday!= casted.tm_yday) {
    				DEBUG(stderr, "zmena casu. bude se menit soubor\n");
    				if (newlinereset()) break;
    			}
    
    			if ( strlen(buff)) {
    				if (strlen(buff)!= write(log, buff, strlen(buff))) {
    					konci(3);
    				} else {
    					last= buff[strlen(buff)-1];
    				}
    			}
    		} while ( !feof(stdin) && !ferror(stdin) &&
    			fgets(buff, sizeof(buff), stdin)!=NULL);
    
    	} while ( !feof(stdin) && !ferror(stdin));
    	/* nikdy */
    	close( log);
    	free(jmeno);
    	return(0);
    }
    
    
    /* korektne skonci */
    void konci(int kod)
    {
    	if (log>=0) close(log);
    	if (!firstmem && NULL!=jmeno) free(jmeno);
    	exit(kod);
    }
    
    /* nacti cas */
    void cas(struct tm *plogtime)
    {
    	time_t ted= time(NULL);
    	localtime_r( &ted, plogtime);
    }
    
    /* vytvor link pro webalizer */
    void linkwebal(struct tm *caslogu, char *webal, char *prefix)
    {
    	int ret;
    	struct tm oldlogtime;
    	struct stat wstaty;
    	time_t vcera= time(NULL) - 86400;
    
    	/* zkontroluj existenci "webalizer" hardlinku */
    	ret=stat( webal, &wstaty);
    	if ( ret && !ENOENT== errno) perror("webalizer link - stat");
    	
    	/* pokud existuje, tak jej odstran */
    	if (( 0== ret) || (! ENOENT== errno)) {
    		if ( (0== ret) || (-1 == ret && (! ENOENT== errno))) {
    			ret= unlink( webal);
    			if (ret) perror("webalizer link - unlink");
    		}
    	}
    
    	/* pokud je to po stratu, tak vyrob jmeno z minuleho dne */
    	if ( NULL== jmeno) {
    		localtime_r( &vcera, &oldlogtime);
    		pojmenuj( &oldlogtime, prefix);
    	}
    
    	/* pokud existuje, tak proved hardlink */
    	ret= stat( jmeno, &wstaty);
    	if (! ret) {
    		ret= link( jmeno, webal);
    		if ( ret) perror("webalizer link - link");
    	}
    }
    
    /* vytvor jmeno z casu */
    void pojmenuj(struct tm *caslogu, char *prefix)
    {
    	int delka, cela;
    	char strcas[10];
    
    	if (8!=strftime( strcas, 9, "%Y%m%d", caslogu)) {
    		DEBUG(stderr, "spatna delka prevedeneho casu\n");
    		konci(2);
    	}
    	strcas[8]='\0';
    
    	/* vyrob jmeno logu */
    	delka= strlen(prefix);
    	cela= delka+ strlen(strcas)+ 1;
    	if (firstmem) {
    		jmeno= (char *)malloc( cela);
    		firstmem=0;
    		if ( NULL==jmeno) {
    			DEBUG(stderr, "nepodarilo se alokovat pamet\n");
    			konci(3);
    		}
    	}
    
    	/* pospojuj argument a cas do jmena */
    	strncpy(jmeno, prefix, delka);
    	jmeno[delka]='\0';
    
    	strncpy( (char *)&(((char *)jmeno)[delka]), strcas, cela-delka);
    	jmeno[cela]='\0';
    }
    
    /* otevri soubor */
    void otevri( char *jmeno, char *param)
    {
    	log= open( jmeno, O_WRONLY | O_CREAT | O_APPEND, 384);
    	if (-1==log) {
    		DEBUG(stderr, "nepodarilo se otevrit soubor\n");
    		konci(4);
    	}
    	unlink(param );
    	link( jmeno, param);
    }
    
    /* kontroluj jestli je posledni zapsany \n */
    int newlinereset(void)
    {
    	fdatasync( fileno(stdin));
    	/* byl napsan naposled konec radku */
    	if (last=='\n') {
    		DEBUG(stderr, "newlinereset(): last \\n\n");
    		findnewline=0;
    		close( log);
    		return(1);
    		/* je potreba najit konec radku */
    	} else if (last!='\n') {
    		DEBUG(stderr, "newlinereset(): last neni \\n\n");
    		findnewline=1;
    		return(0);
    	}
    }
    
    

    v konfiguraku pak

    CustomLog "|/usr/local/bin/jmeno /usr/local/apache2/logs/access_log" combined
    

    no a zalohovani resim z cronu jen pro stary logy nejak takhle:

    #!/bin/bash
    
    store="/mnt/backup/log/apache";
    log="${store}/default.tar";
    
    if test -f ${log} && test -r ${log}; then
            if test `date +%u` = 2; then
                    newlog=`date +%Y%m%d_%s`;
                    mv ${log} ${store}/default_do_${newlog}.tar;
                    bzip2 -9z ${store}/default_do_${newlog}.tar;
            fi
    fi
    
    for F in `cat /usr/local/var/logs/default.log`; do
            dir=`dirname ${F}`;
            find ${dir} -mtime +3 | grep -e "${F}[0-9]\+" | xargs --no-run-if-empty tar vuf ${log} --exclude ${F} --exclude ${F}`date +%Y%m%d` --remove-files
    done
    

    kdyz tak na to letmo koukam, tak uz ani presne nevim co ten skript dela... ale par jich necha ne puvodnim miste a zbytek hodi do tar archivu kterej po case zrotuje a zbali bzipem. ale funguje a to je hlavni.

    2.11.2004 14:44 Beda
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    no ale tady zmineny priklad je az na jedinou drobnost funkcni snad bez problemu. protoze jde o akci v casti "postrotate" a provadi se reload coz akorat instuuje otevrit nove logovaci soubory.

    akorat tam zbyva uvest, ze to nebude fungovat s "compress", ale pouze s delaycompress nebo nocompress.
    2.11.2004 15:15 jm
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    Ech, koukam ono z toho vypadla druha cast ktera je v globalnim nastaveni v jinem adresari:
    weekly
    rotate 4
    create
    compress
    delaycompress
    notifempty
    nomail
    noolddir
    
    2.11.2004 10:24 Roman DAVID | skóre: 24 | Brno
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu
    Coz tahle pouzit programek "rotatelogs", ktery je soucasti apache ?
    Umi ty featury, ktere pozadujete a jeste neco navic.
    Vice vam napovi man rotatelogs :-)

    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.