summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2005-05-02 18:53:16 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2005-05-02 18:53:16 +0000
commit8f9a7390f83dc60cdaac42bf0108313b2d39f1df (patch)
tree0d44c8acfe254e3ad5191de526569f4a1b4fbc0d
parent5ff28570f16d72a868adb254c3dc8fe5279a68f5 (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.cpp15
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')