⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 instrument.c

📁 PostgreSQL7.4.6 for Linux
💻 C
字号:
/*------------------------------------------------------------------------- * * instrument.c *	 functions for instrumentation of plan execution * * * Copyright (c) 2001-2003, PostgreSQL Global Development Group * * IDENTIFICATION *	  $Header: /cvsroot/pgsql/src/backend/executor/instrument.c,v 1.5 2003/08/04 23:59:37 tgl Exp $ * *------------------------------------------------------------------------- */#include "postgres.h"#include <unistd.h>#include "executor/instrument.h"/* Allocate new instrumentation structure */Instrumentation *InstrAlloc(void){	Instrumentation *instr = palloc(sizeof(Instrumentation));	memset(instr, 0, sizeof(Instrumentation));	return instr;}/* Entry to a plan node */voidInstrStartNode(Instrumentation *instr){	if (!instr)		return;	if (instr->starttime.tv_sec != 0 || instr->starttime.tv_usec != 0)		elog(DEBUG2, "InstrStartTimer called twice in a row");	else		gettimeofday(&instr->starttime, NULL);}/* Exit from a plan node */voidInstrStopNode(Instrumentation *instr, bool returnedTuple){	struct timeval endtime;	if (!instr)		return;	if (instr->starttime.tv_sec == 0 && instr->starttime.tv_usec == 0)	{		elog(DEBUG2, "InstrStopNode without start");		return;	}	gettimeofday(&endtime, NULL);	instr->counter.tv_sec += endtime.tv_sec - instr->starttime.tv_sec;	instr->counter.tv_usec += endtime.tv_usec - instr->starttime.tv_usec;	/* Normalize after each add to avoid overflow/underflow of tv_usec */	while (instr->counter.tv_usec < 0)	{		instr->counter.tv_usec += 1000000;		instr->counter.tv_sec--;	}	while (instr->counter.tv_usec >= 1000000)	{		instr->counter.tv_usec -= 1000000;		instr->counter.tv_sec++;	}	instr->starttime.tv_sec = 0;	instr->starttime.tv_usec = 0;	/* Is this the first tuple of this cycle? */	if (!instr->running)	{		instr->running = true;		instr->firsttuple = (double) instr->counter.tv_sec +			(double) instr->counter.tv_usec / 1000000.0;	}	if (returnedTuple)		instr->tuplecount += 1;}/* Finish a run cycle for a plan node */voidInstrEndLoop(Instrumentation *instr){	double		totaltime;	if (!instr)		return;	/* Skip if nothing has happened, or already shut down */	if (!instr->running)		return;	/* Accumulate statistics */	totaltime = (double) instr->counter.tv_sec +		(double) instr->counter.tv_usec / 1000000.0;	instr->startup += instr->firsttuple;	instr->total += totaltime;	instr->ntuples += instr->tuplecount;	instr->nloops += 1;	/* Reset for next cycle (if any) */	instr->running = false;	instr->starttime.tv_sec = 0;	instr->starttime.tv_usec = 0;	instr->counter.tv_sec = 0;	instr->counter.tv_usec = 0;	instr->firsttuple = 0;	instr->tuplecount = 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -