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

📄 memory_aix4.c

📁 snmp的源代码,已经在我的ubuntu下编译通过
💻 C
字号:
/* * AIX4 memory statistics module for net-snmp * * Version 0.1 - Initial release - 05/Jun/2003 * * Derived from memory_solaris2.c * Using libperfstat for statistics (Redbook SG24-6039) * * Ported to AIX by Michael Kukat <michael.kukat@to.com> * Thinking Objects Software GmbH * Lilienthalstra遝 2 * 70825 Stuttgart-Korntal * http://www.to.com/ * * Thanks go to Jochen Kmietsch for the solaris2 support and * to DaimlerChrysler AG Stuttgart for making this port possible */#include <net-snmp/net-snmp-config.h>   /* local SNMP configuration details */#if HAVE_STRING_H#include <string.h>#endif#if HAVE_STDLIB_H#include <stdlib.h>#endif#include <sys/types.h>#if HAVE_DMALLOC_H#include <dmalloc.h>#endif#include <net-snmp/net-snmp-includes.h>#include <net-snmp/agent/net-snmp-agent-includes.h>#include <net-snmp/agent/auto_nlist.h>#include "util_funcs.h"         /* utility function declarations */#include "memory.h"             /* the module-specific header */#include "memory_aix4.h"    /* the module-specific header */#include <libperfstat.h>#include <sys/stat.h>#include <unistd.h>#define MAXSTRSIZE	80int             minimumswap;static char     errmsg[1024];static FindVarMethod var_extensible_mem;static long     getFreeSwap(void);static long     getTotalFree(void);static long     getTotalSwap(void);static long     getFreeReal(void);static long     getTotalReal(void);voidinit_memory_aix4(void){    struct variable2 extensible_mem_variables[] = {        {MIBINDEX, ASN_INTEGER, RONLY, var_extensible_mem, 1, {MIBINDEX}},        {ERRORNAME, ASN_OCTET_STR, RONLY, var_extensible_mem, 1,         {ERRORNAME}},        {MEMTOTALSWAP, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMTOTALSWAP}},        {MEMAVAILSWAP, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMAVAILSWAP}},        {MEMTOTALREAL, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMTOTALREAL}},        {MEMAVAILREAL, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMAVAILREAL}},        {MEMTOTALSWAPTXT, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMTOTALSWAPTXT}},        {MEMUSEDSWAPTXT, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMUSEDSWAPTXT}},        {MEMTOTALREALTXT, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMTOTALREALTXT}},        {MEMUSEDREALTXT, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMUSEDREALTXT}},        {MEMTOTALFREE, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMTOTALFREE}},        {MEMSWAPMINIMUM, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMSWAPMINIMUM}},        {MEMSHARED, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMSHARED}},        {MEMBUFFER, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMBUFFER}},        {MEMCACHED, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {MEMCACHED}},        {ERRORFLAG, ASN_INTEGER, RONLY, var_extensible_mem, 1,         {ERRORFLAG}},        {ERRORMSG, ASN_OCTET_STR, RONLY, var_extensible_mem, 1, {ERRORMSG}}    };    /*     * Define the OID pointer to the top of the mib tree that we're     * registering underneath      */    oid             mem_variables_oid[] = { UCDAVIS_MIB, MEMMIBNUM };    /*     * register ourselves with the agent to handle our mib tree      */    REGISTER_MIB("ucd-snmp/memory", extensible_mem_variables, variable2,                 mem_variables_oid);    snmpd_register_config_handler("swap", memory_parse_config,                                  memory_free_config, "min-avail");}static u_char  *var_extensible_mem(struct variable *vp,                   oid * name,                   size_t * length,                   int exact,                   size_t * var_len, WriteMethod ** write_method){    static long     long_ret;    /*     * Initialize the return value to 0      */    long_ret = 0;    if (header_generic(vp, name, length, exact, var_len, write_method))        return (NULL);    switch (vp->magic) {    case MIBINDEX:        long_ret = 0;        return ((u_char *) (&long_ret));    case ERRORNAME:            /* dummy name */        sprintf(errmsg, "swap");        *var_len = strlen(errmsg);        return ((u_char *) (errmsg));    case MEMTOTALSWAP:        long_ret = getTotalSwap() * (getpagesize() / 1024);        return ((u_char *) (&long_ret));    case MEMAVAILSWAP:        long_ret = getFreeSwap() * (getpagesize() / 1024);        return ((u_char *) (&long_ret));    case MEMSWAPMINIMUM:        long_ret = minimumswap;        return ((u_char *) (&long_ret));    case MEMTOTALREAL:		  long_ret = getTotalReal() * (getpagesize() / 1024);		  return ((u_char *) (&long_ret));    case MEMAVAILREAL:		  long_ret = getFreeReal() * (getpagesize() / 1024);		  return ((u_char *) (&long_ret));    case MEMTOTALFREE:        long_ret = getTotalFree() * (getpagesize() / 1024);        return ((u_char *) (&long_ret));    case ERRORFLAG:        long_ret = getTotalFree() * (getpagesize() / 1024);        long_ret = (long_ret > minimumswap) ? 0 : 1;        return ((u_char *) (&long_ret));    case ERRORMSG:        long_ret = getTotalFree() * (getpagesize() / 1024);        if ((long_ret > minimumswap) ? 0 : 1)            sprintf(errmsg, "Running out of swap space (%ld)", long_ret);        else            errmsg[0] = 0;        *var_len = strlen(errmsg);        return ((u_char *) (errmsg));    }    return (NULL);}#define DEFAULTMINIMUMSWAP 16000        /* kilobytes */voidmemory_parse_config(const char *token, char *cptr){    minimumswap = atoi(cptr);}voidmemory_free_config(void){    minimumswap = DEFAULTMINIMUMSWAP;}static longgetTotalSwap(void){    long            total_mem = -1;	 perfstat_memory_total_t mem;	 if(perfstat_memory_total((perfstat_id_t *)NULL, &mem, sizeof(perfstat_memory_total_t), 1) >= 1) {		 total_mem = mem.pgsp_total;	 }    return (total_mem);}static longgetFreeSwap(void){    long            free_mem = -1;	 perfstat_memory_total_t mem;	 if(perfstat_memory_total((perfstat_id_t *)NULL, &mem, sizeof(perfstat_memory_total_t), 1) >= 1) {		 free_mem = mem.pgsp_free;	 }    return (free_mem);}static longgetTotalFree(void){    long            free_mem = -1;	 perfstat_memory_total_t mem;	 if(perfstat_memory_total((perfstat_id_t *)NULL, &mem, sizeof(perfstat_memory_total_t), 1) >= 1) {		 free_mem = mem.pgsp_free + mem.real_free;	 }    return (free_mem);}static longgetTotalReal(void){    long            total_mem = -1;	 perfstat_memory_total_t mem;	 if(perfstat_memory_total((perfstat_id_t *)NULL, &mem, sizeof(perfstat_memory_total_t), 1) >= 1) {		 total_mem = mem.real_total;	 }    return (total_mem);}static longgetFreeReal(void){    long            free_mem = -1;	 perfstat_memory_total_t mem;	 if(perfstat_memory_total((perfstat_id_t *)NULL, &mem, sizeof(perfstat_memory_total_t), 1) >= 1) {		 free_mem = mem.real_free;	 }    return (free_mem);}

⌨️ 快捷键说明

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