2011-11-22 00:04:02 +01:00
/** ==========================================================================
* 2011 by KjellKod . cc . This is PUBLIC DOMAIN to use at your own risk and comes
* with no warranties . This code is yours to share , use and modify with no
* strings attached and no restrictions or obligations .
* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
2011-11-05 17:36:07 +01:00
// through CMakeLists.txt #define of GOOGLE_GLOG_PERFORMANCE and G2LOG_PERFORMANCE
# include "performance.h"
# include <thread>
# if defined(G2LOG_PERFORMANCE)
const std : : string title = " G2LOG " ;
# elif defined(GOOGLE_GLOG_PERFORMANCE)
const std : : string title = " GOOGLE__GLOG " ;
# else
2011-11-07 12:04:32 +01:00
# error G2LOG_PERFORMANCE or GOOGLE_GLOG_PERFORMANCE was not defined
2011-11-05 17:36:07 +01:00
# endif
2011-11-17 22:46:38 +01:00
# if (defined(WIN32) || defined(_WIN32) || defined(__WIN32__))
const std : : string g_path = " ./ " ;
# else
const std : : string g_path = " /tmp/ " ;
# endif
2011-11-05 17:36:07 +01:00
using namespace g2_test ;
int main ( int argc , char * * argv )
{
2011-11-15 01:46:07 +01:00
size_t number_of_threads = 0 ;
if ( argc = = 2 )
{
number_of_threads = atoi ( argv [ 1 ] ) ;
}
if ( argc ! = 2 | | number_of_threads = = 0 )
{
std : : cerr < < " USAGE is: " < < argv [ 0 ] < < " number_threads " < < std : : endl ;
return 1 ;
}
std : : ostringstream thread_count_oss ;
thread_count_oss < < number_of_threads ;
const std : : string g_prefix_log_name = title + " -performance- " + thread_count_oss . str ( ) + " threads-MEAN_LOG " ;
2011-11-17 22:46:38 +01:00
const std : : string g_measurement_dump = g_path + g_prefix_log_name + " _RESULT.txt " ;
2011-11-15 01:46:07 +01:00
2011-11-05 17:36:07 +01:00
std : : ostringstream oss ;
2011-11-15 01:46:07 +01:00
oss < < " \n \n " < < title < < " performance " < < number_of_threads < < " threads MEAN times \n " ;
2011-11-05 17:36:07 +01:00
oss < < " Each thread running #: " < < g_loop < < " * " < < g_iterations < < " iterations of log entries " < < std : : endl ; // worst mean case is about 10us per log entry
const size_t xtra_margin = 2 ;
2011-11-17 22:46:38 +01:00
oss < < " *** It can take som time. Please wait: Approximate wait time on MY PC was: " < < number_of_threads * ( long long ) ( g_iterations * 10 * xtra_margin / 1000000 ) < < " seconds " < < std : : endl ;
2011-11-05 17:36:07 +01:00
writeTextToFile ( g_measurement_dump , oss . str ( ) , kAppend ) ;
oss . str ( " " ) ; // clear the stream
# if defined(G2LOG_PERFORMANCE)
2011-11-16 22:23:47 +01:00
g2LogWorker * logger = new g2LogWorker ( g_prefix_log_name , g_path ) ;
2011-11-05 17:36:07 +01:00
g2 : : initializeLogging ( logger ) ;
# elif defined(GOOGLE_GLOG_PERFORMANCE)
google : : InitGoogleLogging ( argv [ 0 ] ) ;
# endif
auto start_time = std : : chrono : : steady_clock : : now ( ) ;
2011-11-15 01:46:07 +01:00
std : : thread * threads = new std : : thread [ number_of_threads ] ;
// kiss: just loop, create threads, store them then join
// could probably do this more elegant with lambdas
for ( size_t idx = 0 ; idx < number_of_threads ; + + idx )
{
std : : ostringstream count ;
count < < idx + 1 ;
std : : string thread_name = title + " _T " + count . str ( ) ;
std : : cout < < " Creating thread: " < < thread_name < < std : : endl ;
threads [ idx ] = std : : thread ( doLogWrites , thread_name ) ;
}
for ( size_t idx = 0 ; idx < number_of_threads ; + + idx )
{
threads [ idx ] . join ( ) ;
}
2011-11-05 17:36:07 +01:00
auto application_end_time = std : : chrono : : steady_clock : : now ( ) ;
2011-11-15 01:46:07 +01:00
delete [ ] threads ;
2011-11-05 17:36:07 +01:00
# if defined(G2LOG_PERFORMANCE)
delete logger ; // will flush anything in the queue to file
# elif defined(GOOGLE_GLOG_PERFORMANCE)
google : : ShutdownGoogleLogging ( ) ;
# endif
auto worker_end_time = std : : chrono : : steady_clock : : now ( ) ;
auto application_time_us = std : : chrono : : duration_cast < microsecond > ( application_end_time - start_time ) . count ( ) ;
auto total_time_us = std : : chrono : : duration_cast < microsecond > ( worker_end_time - start_time ) . count ( ) ;
oss < < " \n " < < g_iterations < < " log entries took: [ " < < total_time_us / 1000000 < < " s] to write to disk " < < std : : endl ;
2011-11-16 22:23:47 +01:00
oss < < " [Application( " < < number_of_threads < < " ): \t \t : " < < application_time_us / 1000 < < " ms] " < < std : : endl ;
2011-11-05 17:36:07 +01:00
oss < < " [Background thread to finish \t : " < < total_time_us / 1000 < < " ms] " < < std : : endl ;
oss < < " \n Average time per log entry: " < < std : : endl ;
2011-11-15 01:46:07 +01:00
oss < < " [Application: " < < application_time_us / ( number_of_threads * g_iterations ) < < " us] " < < std : : endl ;
oss < < " [Background+Application: " < < total_time_us / ( number_of_threads * g_iterations ) < < " us] " < < std : : endl ;
2011-11-05 17:36:07 +01:00
writeTextToFile ( g_measurement_dump , oss . str ( ) , kAppend ) ;
std : : cout < < " Result can be found at: " < < g_measurement_dump < < std : : endl ;
return 0 ;
}