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

📄 staterequesthandler.java

📁 使用工具jublider开发的一个聊天室实现基本功能,
💻 JAVA
字号:
package freecs.external;

import freecs.Server;
import freecs.content.ContentContainer;
import freecs.core.GroupManager;
import freecs.core.RequestReader;
import freecs.core.UserManager;
import freecs.interfaces.IRequest;
import freecs.util.logger.LogWriter;

public class StateRequestHandler extends AbstractRequestHandler {

	public StateRequestHandler(String handlerName) {
		super(handlerName);
	}

	/**
	 * class rendering information on server internals
	 */

	public void handle(IRequest req, ContentContainer c) {
		checkAccessIp(req,c);

        if (req.getValue("gc")!=null) {
            System.gc();
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) { 
            }
        }
		
		StringBuffer sb = new StringBuffer ();
		sb.append ("<html><head><title>state query</title><meta http-equiv=\"refresh\" content=\"4\"></head><body bgcolor=ffff99 text=000000><table border=0><tr><td colspan=4 align=center>FreeCS (");
	    sb.append (Server.getVersion ());
	    sb.append (")</td></tr><tr><td width=10></td><td witdh=200 align=right>Laufzeit:</td><td width=10></td><td width=400>");
	    long sec=0, min=0, hour=0, day=0;
	    sec = (System.currentTimeMillis()-Server.startupTime)/1000;
	    min = sec/60;
	    if (min>0)
	    	sec = sec-min*60;
	    if (min >=60){
	    	hour = min/60;
	    	min = min -(hour*60);
	    }
	    if (hour >=24){
	    	day = hour/24;
	    	hour = hour -(day*24);
	    }   
	    sb.append (day);
	    sb.append (" day ");
	    sb.append (hour);
	    sb.append (" h ");
	    sb.append (min);
	    sb.append (" min ");
	    sb.append (sec);
	    sb.append (" sec");
	    sb.append ("</td></tr><tr><td colspan=4 bgcolor=000000 height=1></td></tr><tr><td width=10></td><td witdh=200 align=right>Anzahl der User:</td><td width=10></td><td width=400>");
	    UserManager umgr = UserManager.mgr;
	    sb.append (umgr.getActiveUserCount ());
	    sb.append ("(");
	    sb.append (umgr.getHighWaterMark());
	    sb.append (" max)");
	    sb.append ("</td></tr><tr><td colspan=4 bgcolor=000000 height=1></td></tr><tr><td width=10></td><td witdh=200 align=right>Anzahl der R鋟me:</td><td width=10></td><td width=400>");
	    GroupManager gmgr = GroupManager.mgr;
	    sb.append (gmgr.openGroupsCount());
	    sb.append ("(");
	    sb.append (gmgr.getHighWaterMark());
	    sb.append (" max)");
	    sb.append ("</td></tr><tr><td colspan=4 bgcolor=000000 height=1></td></tr><tr><td width=10></td><td witdh=200 align=right>Anzahl der Reader-Threads:</td><td width=10></td><td width=400>");
	    sb.append (RequestReader.activeReaders ());
	    if (!Server.srv.THREAD_PER_READ) {
	    	sb.append ("</td></tr><tr><td colspan=4 bgcolor=000000 height=1></td></tr><tr><td width=10></td><td witdh=200 align=right>Reader-Queue-Usage:</td><td width=10></td><td width=400>");
	    	double d[] = RequestReader.getOveralUsage();
	    	for (int i = 0; i < d.length; i++) {
	    		sb.append (d[i]);
	    		sb.append ("%");
	    		if (i < d.length) 
	    			sb.append (", ");
	    	}
	    }
	    sb.append ("</td></tr><tr><td colspan=4 bgcolor=000000 height=1></td></tr><tr><td width=10></td><td witdh=200 align=right>Speicher:</td><td width=10></td><td width=400>");
	    Runtime r = Runtime.getRuntime ();
	    long free = r.freeMemory ();
	    long total = r.totalMemory ();
	    long max = r.maxMemory ();
	    long used = total - free;
	    sb.append ("free: ");
	    sb.append (free);
	    sb.append ("<br>used: ");
	    sb.append (used);
	    sb.append ("<br>total/maxTotal: ");
	    sb.append (total);
	    sb.append ("/");
	    sb.append (max);
	    sb.append ("<br>Usagepercentage: ");
	    sb.append (100 - (free / (total / 100)));
	    sb.append ("</td></tr></table>");
	    sb.append ("<a href=/STATE?gc=now>run garbagecollector</a>");
        sb.append ("LogQueue: ").append (LogWriter.instance.logQueue.size());
        sb.append (" of ").append(LogWriter.instance.logQueue.capacity());
        sb.append ("<br />LogWriter priority: " + LogWriter.instance.getPriority());
	    sb.append ("</body></html>");
	    c.wrap (sb.toString());
	}

}

⌨️ 快捷键说明

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