diff --git a/example/bench.cpp b/example/bench.cpp index 6810c717..87cf4946 100644 --- a/example/bench.cpp +++ b/example/bench.cpp @@ -52,7 +52,7 @@ int main(int argc, char* argv[]) int howmany = 1000000; int threads = 10; - int flush_interval = 0; + bool auto_flush = true; int file_size = 30 * 1024 * 1024; int rotating_files = 5; @@ -63,39 +63,38 @@ int main(int argc, char* argv[]) howmany = atoi(argv[1]); if (argc > 2) threads = atoi(argv[2]); - /* + cout << "*******************************************************************************\n"; - cout << "Single thread, " << format(howmany) << " iterations, flush every " << flush_interval << " lines"<< endl; + cout << "Single thread, " << format(howmany) << " iterations, auto flush=" << auto_flush << endl; cout << "*******************************************************************************\n"; - auto rotating_st = spdlog::rotating_logger_st("rotating_st", "logs/rotating_st", file_size, rotating_files, flush_interval); + auto rotating_st = spdlog::rotating_logger_st("rotating_st", "logs/rotating_st", file_size, rotating_files, auto_flush); bench(howmany, rotating_st); - auto daily_st = spdlog::daily_logger_st("daily_st", "logs/daily_st", flush_interval); + auto daily_st = spdlog::daily_logger_st("daily_st", "logs/daily_st", auto_flush); bench(howmany, daily_st); bench(howmany, spdlog::create("null_st")); cout << "\n*******************************************************************************\n"; - cout << threads << " threads sharing same logger, " << format(howmany) << " iterations, flush every " << flush_interval << " lines" << endl; + cout << threads << " threads sharing same logger, " << format(howmany) << " iterations, auto_flush=" << auto_flush << endl; cout << "*******************************************************************************\n"; - auto rotating_mt = spdlog::rotating_logger_mt("rotating_mt", "logs/rotating_mt", file_size, rotating_files, flush_interval); + auto rotating_mt = spdlog::rotating_logger_mt("rotating_mt", "logs/rotating_mt", file_size, rotating_files, auto_flush); bench_mt(howmany, rotating_mt, threads); - auto daily_mt = spdlog::daily_logger_mt("daily_mt", "logs/daily_mt", flush_interval); + auto daily_mt = spdlog::daily_logger_mt("daily_mt", "logs/daily_mt", auto_flush); bench_mt(howmany, daily_mt, threads); bench(howmany, spdlog::create("null_mt")); cout << "\n*******************************************************************************\n"; - cout << "async logging.. " << threads << " threads sharing same logger, " << format(howmany) << " iterations, flush every " << flush_interval << " lines" << endl; -e cout << "*******************************************************************************\n"; - */ + cout << "async logging.. " << threads << " threads sharing same logger, " << format(howmany) << " iterations, auto_flush=" << auto_flush << endl; + cout << "*******************************************************************************\n"; + spdlog::set_async_mode(2500); - auto daily_st_async = spdlog::daily_logger_st("daily_async", "logs/daily_async", flush_interval); - bench_mt(howmany, daily_st_async, threads); - - + auto daily_st_async = spdlog::daily_logger_st("daily_async", "logs/daily_async", auto_flush); + bench_mt(howmany, daily_st_async, threads); + spdlog::stop(); } diff --git a/include/spdlog/details/file_helper.h b/include/spdlog/details/file_helper.h index 505d6083..db2c9da2 100644 --- a/include/spdlog/details/file_helper.h +++ b/include/spdlog/details/file_helper.h @@ -26,7 +26,7 @@ // Helper class for file sink // When failing to open a file, retry several times(5) with small delay between the tries(10 ms) -// Flush to file every X writes (or never if X==0) +// Can be set to auto flush on every line // Throw spdlog_ex exception on errors #include @@ -49,10 +49,10 @@ public: const int open_tries = 5; const int open_interval = 10; - explicit file_helper(const std::size_t flush_inverval): + explicit file_helper(bool auto_flush): _fd(nullptr), - _flush_inverval(flush_inverval), - _flush_countdown(flush_inverval) {}; + _auto_flush(auto_flush) + {}; file_helper(const file_helper&) = delete; file_helper& operator=(const file_helper&) = delete; @@ -104,11 +104,9 @@ public: if(std::fwrite(buf.data(), sizeof(char), size, _fd) != size) throw spdlog_ex("Failed writing to file " + _filename); - if(--_flush_countdown == 0) - { + if(_auto_flush) std::fflush(_fd); - _flush_countdown = _flush_inverval; - } + } const std::string& filename() const @@ -133,8 +131,8 @@ public: private: FILE* _fd; std::string _filename; - const std::size_t _flush_inverval; - std::size_t _flush_countdown; + bool _auto_flush; + }; } diff --git a/include/spdlog/details/spdlog_impl.h b/include/spdlog/details/spdlog_impl.h index a0f4917d..140b66a0 100644 --- a/include/spdlog/details/spdlog_impl.h +++ b/include/spdlog/details/spdlog_impl.h @@ -39,24 +39,24 @@ inline std::shared_ptr spdlog::get(const std::string& name) // Create multi/single threaded rotating file logger -inline std::shared_ptr spdlog::rotating_logger_mt(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, size_t flush_inverval) +inline std::shared_ptr spdlog::rotating_logger_mt(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, bool auto_flush) { - return create(logger_name, filename, "txt", max_file_size, max_files, flush_inverval); + return create(logger_name, filename, "txt", max_file_size, max_files, auto_flush); } -inline std::shared_ptr spdlog::rotating_logger_st(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, size_t flush_inverval) +inline std::shared_ptr spdlog::rotating_logger_st(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, bool auto_flush) { - return create(logger_name, filename, "txt", max_file_size, max_files, flush_inverval); + return create(logger_name, filename, "txt", max_file_size, max_files, auto_flush); } // Create file logger which creates new file at midnight): -inline std::shared_ptr spdlog::daily_logger_mt(const std::string& logger_name, const std::string& filename, size_t flush_inverval) +inline std::shared_ptr spdlog::daily_logger_mt(const std::string& logger_name, const std::string& filename, bool auto_flush) { - return create(logger_name, filename, "txt", flush_inverval); + return create(logger_name, filename, "txt", auto_flush); } -inline std::shared_ptr spdlog::daily_logger_st(const std::string& logger_name, const std::string& filename, size_t flush_inverval) +inline std::shared_ptr spdlog::daily_logger_st(const std::string& logger_name, const std::string& filename, bool auto_flush) { - return create(logger_name, filename, "txt", flush_inverval); + return create(logger_name, filename, "txt", auto_flush); } diff --git a/include/spdlog/sinks/file_sinks.h b/include/spdlog/sinks/file_sinks.h index 13c1248a..25325b1b 100644 --- a/include/spdlog/sinks/file_sinks.h +++ b/include/spdlog/sinks/file_sinks.h @@ -45,8 +45,8 @@ class simple_file_sink : public base_sink { public: explicit simple_file_sink(const std::string &filename, - const std::size_t flush_inverval=0): - _file_helper(flush_inverval) + bool auto_flush=false): + _file_helper(auto_flush) { _file_helper.open(filename); } @@ -72,13 +72,13 @@ class rotating_file_sink : public base_sink public: rotating_file_sink(const std::string &base_filename, const std::string &extension, std::size_t max_size, std::size_t max_files, - std::size_t flush_inverval=0): + bool auto_flush=false): _base_filename(base_filename), _extension(extension), _max_size(max_size), _max_files(max_files), _current_size(0), - _file_helper(flush_inverval) + _file_helper(auto_flush) { _file_helper.open(calc_filename(_base_filename, 0, _extension)); } @@ -158,11 +158,11 @@ class daily_file_sink:public base_sink public: explicit daily_file_sink(const std::string& base_filename, const std::string& extension, - const std::size_t flush_inverval=0): + bool auto_flush=false): _base_filename(base_filename), _extension(extension), _midnight_tp (_calc_midnight_tp() ), - _file_helper(flush_inverval) + _file_helper(auto_flush) { _file_helper.open(calc_filename(_base_filename, _extension)); } diff --git a/include/spdlog/spdlog.h b/include/spdlog/spdlog.h index 35fd4323..a2025290 100644 --- a/include/spdlog/spdlog.h +++ b/include/spdlog/spdlog.h @@ -70,14 +70,14 @@ void set_sync_mode(); // // Create multi/single threaded rotating file logger // -std::shared_ptr rotating_logger_mt(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, size_t flush_inverval = 0); -std::shared_ptr rotating_logger_st(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, size_t flush_inverval = 0); +std::shared_ptr rotating_logger_mt(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, bool auto_fush = false); +std::shared_ptr rotating_logger_st(const std::string& logger_name, const std::string& filename, size_t max_file_size, size_t max_files, bool auto_fush = false); // // Create file logger which creates new file at midnight): // -std::shared_ptr daily_logger_mt(const std::string& logger_name, const std::string& filename, size_t flush_inverval = 0); -std::shared_ptr daily_logger_st(const std::string& logger_name, const std::string& filename, size_t flush_inverval = 0); +std::shared_ptr daily_logger_mt(const std::string& logger_name, const std::string& filename, bool auto_fush = false); +std::shared_ptr daily_logger_st(const std::string& logger_name, const std::string& filename, bool auto_fush = false); //