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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
včera 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 6
včera 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 7
včera 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 1
včera 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
včera 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 0
včera 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
1.12. 21:00 | Nová verze

Byla vydána beta verze Linux Mintu 18.1 s kódovým jménem Serena. Na blogu Linux Mintu jsou hned dvě oznámení. První o vydání Linux Mintu s prostředím MATE a druhé o vydání Linux Mintu s prostředím Cinnamon. Stejným způsobem jsou rozděleny také poznámky k vydání (MATE, Cinnamon) a přehled novinek s náhledy (MATE, Cinnamon). Linux Mint 18.1 bude podporován až do roku 2021.

Ladislav Hagara | Komentářů: 0
1.12. 16:42 | Nová verze

Byl vydán Devuan Jessie 1.0 Beta 2. Jedná se o druhou beta verzi forku Debianu bez systemd představeného v listopadu 2014 (zprávička). První beta verze byla vydána v dubnu letošního roku (zprávička). Jedna z posledních přednášek věnovaných Devuanu proběhla v listopadu na konferenci FSCONS 2016 (YouTube, pdf).

Ladislav Hagara | Komentářů: 0
1.12. 15:16 | Komunita

Na GOG.com začal zimní výprodej. Řada zlevněných her běží oficiálně také na Linuxu. Hru Neverwinter Nights Diamond lze dva dny získat zdarma. Hra dle stránek GOG.com na Linuxu neběží. Pomocí návodu ji lze ale rozběhnout také na Linuxu [Gaming On Linux].

Ladislav Hagara | Komentářů: 1
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 763 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Rotovani Apache Logu

1.11.2004 15:01 Martin
Rotovani Apache Logu
Přečteno: 484×
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.