File: logrotate-pthread.cpp

package info (click to toggle)
easyloggingpp 9.97.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 2,840 kB
  • sloc: cpp: 11,415; python: 2,336; sh: 337; makefile: 29
file content (44 lines) | stat: -rw-r--r-- 1,052 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
//
// This file is part of Easylogging++ samples
//
// Sample to show how to implement log rotate using easylogging++ (posix thread version)
// Thanks to Darren for efforts (http://darrendev.blogspot.com.au/)
//
// Compile: g++ -std=c++11 -Wall -Werror logrotate.cpp -lpthread -o logrotate -DELPP_THREAD_SAFE
//
// Revision 1.1
// @author mkhan3189
//

#define ELPP_NO_DEFAULT_LOG_FILE
#include "easylogging++.h"
#include <unistd.h> // for sleep()

INITIALIZE_EASYLOGGINGPP

void* logRotate(void*){
	// Rotate every 20 seconds
	while (true){
		sleep(20);
		LOG(INFO) << "About to rotate log file!";
		el::Loggers::getLogger("default")->reconfigure();
	}
	return NULL;
}

int main(int, char**){
    el::Loggers::configureFromGlobal("logrotate.conf");
    LOG(INFO) << "The program has started!";
    
    pthread_t logRotatorThread;
	pthread_create(&logRotatorThread, NULL, logRotate, NULL);
    
    //Main thread
    for(int n = 0; n < 60; ++n){
        LOG(TRACE) << n;
        sleep(1);
    }
    
    LOG(INFO) << "Shutting down.";
    return 0;
}