You've already forked mariadb-columnstore-engine
							
							
				mirror of
				https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
				synced 2025-10-30 07:25:34 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			231 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			231 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright (C) 2014 InfiniDB, Inc.
 | |
| 
 | |
|    This program is free software; you can redistribute it and/or
 | |
|    modify it under the terms of the GNU General Public License
 | |
|    as published by the Free Software Foundation; version 2 of
 | |
|    the License.
 | |
| 
 | |
|    This program is distributed in the hope that it will be useful,
 | |
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|    GNU General Public License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU General Public License
 | |
|    along with this program; if not, write to the Free Software
 | |
|    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
 | |
|    MA 02110-1301, USA. */
 | |
| 
 | |
| /*******************************************************************************
 | |
| * $Id: we_stats.cpp 4450 2013-01-21 14:13:24Z rdempsey $
 | |
| *
 | |
| *******************************************************************************/
 | |
| /** @file */
 | |
| 
 | |
| #include <we_stats.h>
 | |
| 
 | |
| using namespace std;
 | |
| 
 | |
| namespace WriteEngine
 | |
| {
 | |
| #ifdef PROFILE
 | |
|    /* static */ bool                            Stats::fProfiling = false;
 | |
|    /* static */ boost::mutex                    Stats::fRegisterReaderMutex;
 | |
|    /* static */ boost::mutex                    Stats::fRegisterParseMutex;
 | |
|    /* static */ std::vector<pthread_t>          Stats::fReadProfThreads;
 | |
|    /* static */ std::vector<pthread_t>          Stats::fParseProfThreads;
 | |
|    /* static */ std::vector<logging::StopWatch> Stats::fReadStopWatch;
 | |
|    /* static */ std::vector<logging::StopWatch> Stats::fParseStopWatch;
 | |
| #endif
 | |
| 
 | |
|    struct IoStats Stats::m_ioStats = { 0, 0 };
 | |
|    bool Stats::m_bUseStats = false;
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Increase the counter for block read
 | |
|     * PARAMETERS:
 | |
|     *    blockNum - the number of blocks
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void  Stats::incIoBlockRead( const int blockNum )
 | |
|    {
 | |
|       if( !m_bUseStats )
 | |
|          return;
 | |
|       m_ioStats.blockRead += blockNum;
 | |
|    }
 | |
| 
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Increase the counter for block write
 | |
|     * PARAMETERS:
 | |
|     *    blockNum - the number of blocks
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void  Stats::incIoBlockWrite( const int blockNum )
 | |
|    {
 | |
|       if( !m_bUseStats )
 | |
|          return;
 | |
|       m_ioStats.blockWrite += blockNum;
 | |
|    }
 | |
| 
 | |
| #ifdef PROFILE
 | |
| //-------------------------------------------------------------------------------
 | |
| // Functions that follow are used for profiling using the StopWatch class
 | |
| //-------------------------------------------------------------------------------
 | |
| 
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Enable/Initialize the profiling functions
 | |
|     * PARAMETERS:
 | |
|     *    nReadThreads  - number of read threads to be profiled
 | |
|     *    nParseThreads - number of parse threads to be profiled
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void Stats::enableProfiling(int nReadThreads, int nParseThreads)
 | |
|    {
 | |
|       fProfiling = true;
 | |
| 
 | |
|       // @bug 2625: pre-reserve space for our vectors; else we could have a race
 | |
|       // condition whereby one parsing thread is adding itself to the vectors
 | |
|       // and thus "growing" the vector (in registerParseProfThread), at the
 | |
|       // same time that another parsing thread is reading the vector in parse-
 | |
|       // Event().  By pre-reserving the space, the vectors won't be growing,
 | |
|       // thus eliminating the problem with this race condition.
 | |
|       fReadProfThreads.reserve ( nReadThreads  );
 | |
|       fReadStopWatch.reserve   ( nReadThreads  );
 | |
|       fParseProfThreads.reserve( nParseThreads );
 | |
|       fParseStopWatch.reserve  ( nParseThreads );
 | |
|    }
 | |
| 
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Register the current thread as a Read thread to be profiled
 | |
|     * PARAMETERS:
 | |
|     *    none
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void  Stats::registerReadProfThread( )
 | |
|    {
 | |
|       boost::mutex::scoped_lock lk(fRegisterReaderMutex);
 | |
| 
 | |
|       fReadProfThreads.push_back( pthread_self() );
 | |
|       logging::StopWatch readStopWatch;
 | |
|       fReadStopWatch.push_back  ( readStopWatch  );
 | |
|    }
 | |
| 
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Register the current thread as a Parse thread to be profiled
 | |
|     * PARAMETERS:
 | |
|     *    none
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void  Stats::registerParseProfThread( )
 | |
|    {
 | |
|       boost::mutex::scoped_lock lk(fRegisterParseMutex);
 | |
| 
 | |
|       fParseProfThreads.push_back( pthread_self() );
 | |
|       logging::StopWatch parseStopWatch;
 | |
|       fParseStopWatch.push_back  ( parseStopWatch );
 | |
|    }
 | |
| 
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Track the specified Read event in the current Read thread.
 | |
|     * PARAMETERS:
 | |
|     *    eventString - string that identifies the event.
 | |
|     *    start       - boolean indicating whether the is the start or the
 | |
|     *                  end of the event.  TRUE=>start FALSE=>end
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void  Stats::readEvent ( const std::string& eventString, bool start )
 | |
|    {
 | |
|       if (fProfiling)
 | |
|       {
 | |
|          pthread_t thread = pthread_self();
 | |
|          for (unsigned i=0; i<fReadProfThreads.size(); i++)
 | |
|          {
 | |
|             if (fReadProfThreads[i] == thread)
 | |
|             {
 | |
|                if (start)
 | |
|                   fReadStopWatch[i].start( eventString );
 | |
|                else
 | |
|                   fReadStopWatch[i].stop ( eventString );
 | |
|                break;
 | |
|             }
 | |
|          }
 | |
|       }
 | |
|    }
 | |
| 
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Track the specified Parse event in the current Parse thread.
 | |
|     * PARAMETERS:
 | |
|     *    eventString - string that identifies the event.
 | |
|     *    start       - boolean indicating whether the is the start or the
 | |
|     *                  end of the event.  TRUE=>start FALSE=>end
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void  Stats::parseEvent ( const std::string& eventString, bool start )
 | |
|    {
 | |
|       if (fProfiling)
 | |
|       {
 | |
|          pthread_t thread = pthread_self();
 | |
|          for (unsigned i=0; i<fParseProfThreads.size(); i++)
 | |
|          {
 | |
|             if (fParseProfThreads[i] == thread)
 | |
|             {
 | |
|                if (start)
 | |
|                   fParseStopWatch[i].start( eventString );
 | |
|                else
 | |
|                   fParseStopWatch[i].stop ( eventString );
 | |
|                break;
 | |
|             }
 | |
|          }
 | |
|       }
 | |
|    }
 | |
| 
 | |
|    /***********************************************************
 | |
|     * DESCRIPTION:
 | |
|     *    Print profiling results.
 | |
|     * PARAMETERS:
 | |
|     *    none
 | |
|     * RETURN:
 | |
|     *    none
 | |
|     ***********************************************************/
 | |
|    void  Stats::printProfilingResults ( )
 | |
|    {
 | |
|       if (fProfiling)
 | |
|       {
 | |
|          std::cout << endl;
 | |
|          for (unsigned j=0; j<fReadStopWatch.size(); j++)
 | |
|          {
 | |
|             std::cout << "Execution Stats for Read Thread " << j << " (" <<
 | |
|                          fReadProfThreads[j] << ")"         << std::endl <<
 | |
|                          "-------------------------------"  << std::endl;
 | |
|             fReadStopWatch[j].finish();
 | |
|             std::cout << std::endl;
 | |
|          }
 | |
| 
 | |
|          for (unsigned j=0; j<fParseStopWatch.size(); j++)
 | |
|          {
 | |
|             std::cout << "Execution Stats for Parse Thread "<< j << " (" <<
 | |
|                          fParseProfThreads[j] << ")"        << std::endl <<
 | |
|                          "--------------------------------" << std::endl;
 | |
|             fParseStopWatch[j].finish();
 | |
|             std::cout << std::endl;
 | |
|          }
 | |
| 
 | |
|       }
 | |
|    }
 | |
| #endif
 | |
| 
 | |
| } //end of namespace
 | |
| 
 |