pgstatfuncs.c

来自「PostgreSQL 8.1.4的源码 适用于Linux下的开源数据库系统」· C语言 代码 · 共 579 行

C
579
字号
/*------------------------------------------------------------------------- * * pgstatfuncs.c *	  Functions for accessing the statistics collector data * * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * * IDENTIFICATION *	  $PostgreSQL: pgsql/src/backend/utils/adt/pgstatfuncs.c,v 1.26.2.1 2006/05/19 15:15:38 alvherre Exp $ * *------------------------------------------------------------------------- */#include "postgres.h"#include "access/xact.h"#include "fmgr.h"#include "funcapi.h"#include "miscadmin.h"#include "nodes/execnodes.h"#include "pgstat.h"#include "utils/hsearch.h"#include "utils/inet.h"#include "utils/builtins.h"#include "libpq/ip.h"/* bogus ... these externs should be in a header file */extern Datum pg_stat_get_numscans(PG_FUNCTION_ARGS);extern Datum pg_stat_get_tuples_returned(PG_FUNCTION_ARGS);extern Datum pg_stat_get_tuples_fetched(PG_FUNCTION_ARGS);extern Datum pg_stat_get_tuples_inserted(PG_FUNCTION_ARGS);extern Datum pg_stat_get_tuples_updated(PG_FUNCTION_ARGS);extern Datum pg_stat_get_tuples_deleted(PG_FUNCTION_ARGS);extern Datum pg_stat_get_blocks_fetched(PG_FUNCTION_ARGS);extern Datum pg_stat_get_blocks_hit(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_idset(PG_FUNCTION_ARGS);extern Datum pg_backend_pid(PG_FUNCTION_ARGS);extern Datum pg_stat_reset(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_pid(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_dbid(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_userid(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_activity(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_activity_start(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_start(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_client_addr(PG_FUNCTION_ARGS);extern Datum pg_stat_get_backend_client_port(PG_FUNCTION_ARGS);extern Datum pg_stat_get_db_numbackends(PG_FUNCTION_ARGS);extern Datum pg_stat_get_db_xact_commit(PG_FUNCTION_ARGS);extern Datum pg_stat_get_db_xact_rollback(PG_FUNCTION_ARGS);extern Datum pg_stat_get_db_blocks_fetched(PG_FUNCTION_ARGS);extern Datum pg_stat_get_db_blocks_hit(PG_FUNCTION_ARGS);Datumpg_stat_get_numscans(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->numscans);	PG_RETURN_INT64(result);}Datumpg_stat_get_tuples_returned(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->tuples_returned);	PG_RETURN_INT64(result);}Datumpg_stat_get_tuples_fetched(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->tuples_fetched);	PG_RETURN_INT64(result);}Datumpg_stat_get_tuples_inserted(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->tuples_inserted);	PG_RETURN_INT64(result);}Datumpg_stat_get_tuples_updated(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->tuples_updated);	PG_RETURN_INT64(result);}Datumpg_stat_get_tuples_deleted(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->tuples_deleted);	PG_RETURN_INT64(result);}Datumpg_stat_get_blocks_fetched(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->blocks_fetched);	PG_RETURN_INT64(result);}Datumpg_stat_get_blocks_hit(PG_FUNCTION_ARGS){	PgStat_StatTabEntry *tabentry;	Oid			relid;	int64		result;	relid = PG_GETARG_OID(0);	if ((tabentry = pgstat_fetch_stat_tabentry(relid)) == NULL)		result = 0;	else		result = (int64) (tabentry->blocks_hit);	PG_RETURN_INT64(result);}Datumpg_stat_get_backend_idset(PG_FUNCTION_ARGS){	FuncCallContext *funcctx;	int		   *fctx;	int32		result;	/* stuff done only on the first call of the function */	if (SRF_IS_FIRSTCALL())	{		/* create a function context for cross-call persistence */		funcctx = SRF_FIRSTCALL_INIT();		fctx = MemoryContextAlloc(funcctx->multi_call_memory_ctx,								  2 * sizeof(int));		funcctx->user_fctx = fctx;		fctx[0] = 0;		fctx[1] = pgstat_fetch_stat_numbackends();	}	/* stuff done on every call of the function */	funcctx = SRF_PERCALL_SETUP();	fctx = funcctx->user_fctx;	fctx[0] += 1;	result = fctx[0];	if (result <= fctx[1])	{		/* do when there is more left to send */		SRF_RETURN_NEXT(funcctx, Int32GetDatum(result));	}	else	{		/* do when there is no more left */		SRF_RETURN_DONE(funcctx);	}}Datumpg_backend_pid(PG_FUNCTION_ARGS){	PG_RETURN_INT32(MyProcPid);}/* * Built-in function for resetting the counters */Datumpg_stat_reset(PG_FUNCTION_ARGS){	pgstat_reset_counters();	PG_RETURN_BOOL(true);}Datumpg_stat_get_backend_pid(PG_FUNCTION_ARGS){	PgStat_StatBeEntry *beentry;	int32		beid;	beid = PG_GETARG_INT32(0);	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		PG_RETURN_NULL();	PG_RETURN_INT32(beentry->procpid);}Datumpg_stat_get_backend_dbid(PG_FUNCTION_ARGS){	PgStat_StatBeEntry *beentry;	int32		beid;	beid = PG_GETARG_INT32(0);	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		PG_RETURN_NULL();	/* Not initialized yet? */	if (!OidIsValid(beentry->databaseid))		PG_RETURN_NULL();	PG_RETURN_OID(beentry->databaseid);}Datumpg_stat_get_backend_userid(PG_FUNCTION_ARGS){	PgStat_StatBeEntry *beentry;	int32		beid;	beid = PG_GETARG_INT32(0);	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		PG_RETURN_NULL();	/* Not initialized yet? */	if (!OidIsValid(beentry->userid))		PG_RETURN_NULL();	PG_RETURN_OID(beentry->userid);}Datumpg_stat_get_backend_activity(PG_FUNCTION_ARGS){	PgStat_StatBeEntry *beentry;	int32		beid;	int			len;	char	   *activity;	text	   *result;	beid = PG_GETARG_INT32(0);	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		activity = "<backend information not available>";	else if (!superuser() && beentry->userid != GetUserId())		activity = "<insufficient privilege>";	else if (*(beentry->activity) == '\0')		activity = "<command string not enabled>";	else		activity = beentry->activity;	len = strlen(activity);	result = palloc(VARHDRSZ + len);	VARATT_SIZEP(result) = VARHDRSZ + len;	memcpy(VARDATA(result), activity, len);	PG_RETURN_TEXT_P(result);}Datumpg_stat_get_backend_activity_start(PG_FUNCTION_ARGS){	int32		beid = PG_GETARG_INT32(0);	TimestampTz result;	PgStat_StatBeEntry *beentry;	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		PG_RETURN_NULL();	if (!superuser() && beentry->userid != GetUserId())		PG_RETURN_NULL();	result = beentry->activity_start_timestamp;	/*	 * No time recorded for start of current query -- this is the case if the	 * user hasn't enabled query-level stats collection.	 */	if (result == 0)		PG_RETURN_NULL();	PG_RETURN_TIMESTAMPTZ(result);}Datumpg_stat_get_backend_start(PG_FUNCTION_ARGS){	int32		beid = PG_GETARG_INT32(0);	TimestampTz result;	PgStat_StatBeEntry *beentry;	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		PG_RETURN_NULL();	if (!superuser() && beentry->userid != GetUserId())		PG_RETURN_NULL();	result = beentry->start_timestamp;	if (result == 0)			/* probably can't happen? */		PG_RETURN_NULL();	PG_RETURN_TIMESTAMPTZ(result);}Datumpg_stat_get_backend_client_addr(PG_FUNCTION_ARGS){	PgStat_StatBeEntry *beentry;	SockAddr	zero_clientaddr;	int32		beid;	char		remote_host[NI_MAXHOST];	int			ret;	beid = PG_GETARG_INT32(0);	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		PG_RETURN_NULL();	/* Not initialized yet? */	if (!OidIsValid(beentry->userid))		PG_RETURN_NULL();	if (!superuser() && beentry->userid != GetUserId())		PG_RETURN_NULL();	/* A zeroed client addr means we don't know */	memset(&zero_clientaddr, 0, sizeof(zero_clientaddr));	if (memcmp(&(beentry->clientaddr), &zero_clientaddr,			   sizeof(zero_clientaddr) == 0))		PG_RETURN_NULL();	switch (beentry->clientaddr.addr.ss_family)	{		case AF_INET:#ifdef HAVE_IPV6		case AF_INET6:#endif			break;		default:			PG_RETURN_NULL();	}	remote_host[0] = '\0';	ret = pg_getnameinfo_all(&beentry->clientaddr.addr, beentry->clientaddr.salen,							 remote_host, sizeof(remote_host),							 NULL, 0,							 NI_NUMERICHOST | NI_NUMERICSERV);	if (ret)		PG_RETURN_NULL();	PG_RETURN_INET_P(DirectFunctionCall1(inet_in,										 CStringGetDatum(remote_host)));}Datumpg_stat_get_backend_client_port(PG_FUNCTION_ARGS){	PgStat_StatBeEntry *beentry;	SockAddr	zero_clientaddr;	int32		beid;	char		remote_port[NI_MAXSERV];	int			ret;	beid = PG_GETARG_INT32(0);	if ((beentry = pgstat_fetch_stat_beentry(beid)) == NULL)		PG_RETURN_NULL();	/* Not initialized yet? */	if (!OidIsValid(beentry->userid))		PG_RETURN_NULL();	if (!superuser() && beentry->userid != GetUserId())		PG_RETURN_NULL();	/* A zeroed client addr means we don't know */	memset(&zero_clientaddr, 0, sizeof(zero_clientaddr));	if (memcmp(&(beentry->clientaddr), &zero_clientaddr,			   sizeof(zero_clientaddr) == 0))		PG_RETURN_NULL();	switch (beentry->clientaddr.addr.ss_family)	{		case AF_INET:#ifdef HAVE_IPV6		case AF_INET6:#endif			break;		case AF_UNIX:			PG_RETURN_INT32(-1);		default:			PG_RETURN_NULL();	}	remote_port[0] = '\0';	ret = pg_getnameinfo_all(&beentry->clientaddr.addr,							 beentry->clientaddr.salen,							 NULL, 0,							 remote_port, sizeof(remote_port),							 NI_NUMERICHOST | NI_NUMERICSERV);	if (ret)		PG_RETURN_NULL();	PG_RETURN_DATUM(DirectFunctionCall1(int4in, CStringGetDatum(remote_port)));}Datumpg_stat_get_db_numbackends(PG_FUNCTION_ARGS){	PgStat_StatDBEntry *dbentry;	Oid			dbid;	int32		result;	dbid = PG_GETARG_OID(0);	if ((dbentry = pgstat_fetch_stat_dbentry(dbid)) == NULL)		result = 0;	else		result = (int32) (dbentry->n_backends);	PG_RETURN_INT32(result);}Datumpg_stat_get_db_xact_commit(PG_FUNCTION_ARGS){	PgStat_StatDBEntry *dbentry;	Oid			dbid;	int64		result;	dbid = PG_GETARG_OID(0);	if ((dbentry = pgstat_fetch_stat_dbentry(dbid)) == NULL)		result = 0;	else		result = (int64) (dbentry->n_xact_commit);	PG_RETURN_INT64(result);}Datumpg_stat_get_db_xact_rollback(PG_FUNCTION_ARGS){	PgStat_StatDBEntry *dbentry;	Oid			dbid;	int64		result;	dbid = PG_GETARG_OID(0);	if ((dbentry = pgstat_fetch_stat_dbentry(dbid)) == NULL)		result = 0;	else		result = (int64) (dbentry->n_xact_rollback);	PG_RETURN_INT64(result);}Datumpg_stat_get_db_blocks_fetched(PG_FUNCTION_ARGS){	PgStat_StatDBEntry *dbentry;	Oid			dbid;	int64		result;	dbid = PG_GETARG_OID(0);	if ((dbentry = pgstat_fetch_stat_dbentry(dbid)) == NULL)		result = 0;	else		result = (int64) (dbentry->n_blocks_fetched);	PG_RETURN_INT64(result);}Datumpg_stat_get_db_blocks_hit(PG_FUNCTION_ARGS){	PgStat_StatDBEntry *dbentry;	Oid			dbid;	int64		result;	dbid = PG_GETARG_OID(0);	if ((dbentry = pgstat_fetch_stat_dbentry(dbid)) == NULL)		result = 0;	else		result = (int64) (dbentry->n_blocks_hit);	PG_RETURN_INT64(result);}

⌨️ 快捷键说明

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