File: logrotate.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 (48 lines) | stat: -rw-r--r-- 1,367 bytes parent folder | download | duplicates (7)
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
45
46
47
48
//
// This file is part of Easylogging++ samples
//
// Sample to show how to implement log rotate using easylogging++
// 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.0
// @author Darren
//

#include <thread>
#define ELPP_NO_DEFAULT_LOG_FILE
#include "easylogging++.h"

INITIALIZE_EASYLOGGINGPP

int main(int,char**){
    el::Loggers::configureFromGlobal("logrotate.conf");
    LOG(INFO)<<"The program has started!";
    
    std::thread logRotatorThread([](){
        const std::chrono::seconds wakeUpDelta = std::chrono::seconds(20);
        auto nextWakeUp = std::chrono::system_clock::now() + wakeUpDelta;
        
        while(true){
            std::this_thread::sleep_until(nextWakeUp);
            nextWakeUp += wakeUpDelta;
            LOG(INFO) << "About to rotate log file!";
            auto L = el::Loggers::getLogger("default");
            if(L == nullptr)LOG(ERROR)<<"Oops, it is not called default!";
            else L->reconfigure();
        }
        
    });
    
    logRotatorThread.detach();
    
    //Main thread
    for(int n = 0; n < 1000; ++n){
        LOG(TRACE) << n;
        std::this_thread::sleep_for(std::chrono::milliseconds(100));
    }
    
    LOG(INFO) << "Shutting down.";
    return 0;
}