diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2005-05-02 18:53:16 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2005-05-02 18:53:16 +0000 |
commit | 8f9a7390f83dc60cdaac42bf0108313b2d39f1df (patch) | |
tree | 0d44c8acfe254e3ad5191de526569f4a1b4fbc0d | |
parent | 5ff28570f16d72a868adb254c3dc8fe5279a68f5 (diff) |
Added new /stats z (warning - this is UNTESTED on linux!)
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@1282 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r-- | src/commands.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/src/commands.cpp b/src/commands.cpp index 7a17070c8..f66cc1594 100644 --- a/src/commands.cpp +++ b/src/commands.cpp @@ -39,6 +39,11 @@ #include <errno.h> #include <unistd.h> #include <sched.h> +#include <sys/types.h> +#include <sys/time.h> +#include <sys/resource.h> +#define RUSAGE_SELF 0 +#define RUSAGE_CHILDREN -1 #include "connection.h" #include "users.h" #include "servers.h" @@ -205,7 +210,6 @@ extern userrec* fd_ref_table[65536]; extern int statsAccept,statsRefused,statsUnknown,statsCollisions,statsDns,statsDnsGood,statsDnsBad,statsConnects,statsSent,statsRecv; - void handle_join(char **parameters, int pcnt, userrec *user) { chanrec* Ptr; @@ -1421,6 +1425,7 @@ void handle_stats(char **parameters, int pcnt, userrec *user) /* stats z (debug and memory info) */ if (*parameters[0] == 'z') { + rusage R; WriteServ(user->fd,"249 %s :Users(HASH_MAP) %d (%d bytes, %d buckets)",user->nick,clientlist.size(),clientlist.size()*sizeof(userrec),clientlist.bucket_count()); WriteServ(user->fd,"249 %s :Channels(HASH_MAP) %d (%d bytes, %d buckets)",user->nick,chanlist.size(),chanlist.size()*sizeof(chanrec),chanlist.bucket_count()); WriteServ(user->fd,"249 %s :Commands(VECTOR) %d (%d bytes)",user->nick,cmdlist.size(),cmdlist.size()*sizeof(command_t)); @@ -1429,6 +1434,14 @@ void handle_stats(char **parameters, int pcnt, userrec *user) WriteServ(user->fd,"249 %s :Modules(VECTOR) %d (%d)",user->nick,modules.size(),modules.size()*sizeof(Module)); WriteServ(user->fd,"249 %s :ClassFactories(VECTOR) %d (%d)",user->nick,factory.size(),factory.size()*sizeof(ircd_module)); WriteServ(user->fd,"249 %s :Ports(STATIC_ARRAY) %d",user->nick,boundPortCount); + if (!getrusage(RUSAGE_SELF,&R)) + { + WriteServ(user->fd,"249 %s :Total allocation: %luK (0x%lx)",user->nick,R.ru_maxrss,R.ru_maxrss); + WriteServ(user->fd,"249 %s :Signals: %lu (0x%lx)",user->nick,R.ru_nsignals,R.ru_nsignals); + WriteServ(user->fd,"249 %s :Page faults: %lu (0x%lx)",user->nick,R.ru_majflt,R.ru_majflt); + WriteServ(user->fd,"249 %s :Swaps: %lu (0x%lx)",user->nick,R.ru_nswap,R.ru_nswap); + WriteServ(user->fd,"249 %s :Context Switches: %lu (0x%lx)",user->nick,R.ru_nvcsw+R.ru_nivcsw,R.ru_nvcsw+R.ru_nivcsw); + } } if (*parameters[0] == 'T') |