Admin server info improvements and minor font tag corrections.
Thanks to Trance.
This commit is contained in:
@@ -12,15 +12,15 @@
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Owner:</td>
|
||||
<td><font color="LEVEL">%ownerName%<font></td>
|
||||
<td><font color="LEVEL">%ownerName%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Clan:</td>
|
||||
<td><font color="LEVEL">%ownerClan%<font></td>
|
||||
<td><font color="LEVEL">%ownerClan%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Castle Side:</td>
|
||||
<td><font color="LEVEL">%castleSide%<font></td>
|
||||
<td><font color="LEVEL">%castleSide%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Siege Info:</td>
|
||||
|
@@ -9,7 +9,7 @@
|
||||
</table>
|
||||
<br>
|
||||
<br>
|
||||
<font color="LEVEL">Antharas<font><br>
|
||||
<font color="LEVEL">Antharas</font><br>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Status:</td>
|
||||
|
@@ -9,7 +9,7 @@
|
||||
</table>
|
||||
<br>
|
||||
<br>
|
||||
<font color="LEVEL">Baium<font><br>
|
||||
<font color="LEVEL">Baium</font><br>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Status:</td>
|
||||
|
@@ -9,7 +9,7 @@
|
||||
</table>
|
||||
<br>
|
||||
<br>
|
||||
<font color="LEVEL">Core<font><br>
|
||||
<font color="LEVEL">Core</font><br>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Status:</td>
|
||||
|
@@ -9,7 +9,7 @@
|
||||
</table>
|
||||
<br>
|
||||
<br>
|
||||
<font color="LEVEL">Orfen<font><br>
|
||||
<font color="LEVEL">Orfen</font><br>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Status:</td>
|
||||
|
@@ -9,7 +9,7 @@
|
||||
</table>
|
||||
<br>
|
||||
<br>
|
||||
<font color="LEVEL">Queen ant<font><br>
|
||||
<font color="LEVEL">Queen ant</font><br>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Status:</td>
|
||||
|
@@ -9,7 +9,7 @@
|
||||
</table>
|
||||
<br>
|
||||
<br>
|
||||
<font color="LEVEL">Valakas<font><br>
|
||||
<font color="LEVEL">Valakas</font><br>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Status:</td>
|
||||
|
@@ -12,11 +12,11 @@
|
||||
<table width="270" align=center border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Player Name:</td>
|
||||
<td><font color="00FF00">%targetName%<font></td>
|
||||
<td><font color="00FF00">%targetName%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Player Points:</td>
|
||||
<td><font color="00FF00">%points%<font></td>
|
||||
<td><font color="00FF00">%points%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
|
@@ -12,11 +12,11 @@
|
||||
<table width="270" align=center border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Player Name:</td>
|
||||
<td><font color="00FF00">%targetName%<font></td>
|
||||
<td><font color="00FF00">%targetName%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Player Points:</td>
|
||||
<td><font color="00FF00">%points%<font></td>
|
||||
<td><font color="00FF00">%points%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
|
@@ -1,79 +1,129 @@
|
||||
<html><title>Admin Server Info</title><body>
|
||||
<center>
|
||||
<table width=270>
|
||||
<tr>
|
||||
<td width=45><button value="Main" action="bypass -h admin_admin" width=45 height=21 back="L2UI_CT1.Button_DF_Down" fore="L2UI_CT1.Button_DF"></td>
|
||||
<td width=180><center>Server Info</center></td>
|
||||
<td width=45><button value="Back" action="bypass -h admin_admin4" width=45 height=21 back="L2UI_CT1.Button_DF_Down" fore="L2UI_CT1.Button_DF"></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">General:<font><br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>OS:</td>
|
||||
<td><font color="00FF00">%os_name%</font></td>
|
||||
</tr>
|
||||
<html>
|
||||
<title>Admin Server Info</title>
|
||||
<body>
|
||||
<center>
|
||||
<table width=270>
|
||||
<tr>
|
||||
<td width=45><button value="Main" action="bypass admin_admin" width=45 height=21 back="L2UI_CT1.Button_DF_Down" fore="L2UI_CT1.Button_DF"></td>
|
||||
<td width=180>
|
||||
<center>Server Info</center>
|
||||
</td>
|
||||
<td width=45><button value="Back" action="bypass admin_admin4" width=45 height=21 back="L2UI_CT1.Button_DF_Down" fore="L2UI_CT1.Button_DF"></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">Memory:</font>
|
||||
<br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>OS version:</td>
|
||||
<td><font color="00FF00">%os_ver%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Server slots:</td>
|
||||
<td><font color="00FF00">%slots%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Server UpTime:</td>
|
||||
<td><font color="00FF00">%serverUpTime%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Server Time:</td>
|
||||
<td><font color="00FF00">%serverTime%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Game Time:</td>
|
||||
<td><font color="00FF00">%gameTime% (%dayNight%)</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Pathfinding:</td>
|
||||
<td><font color="00FF00">%geodata%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">Players:<font><br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Total players count:</td>
|
||||
<td><font color="00FF00">%onlineAll%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Offline trade count:</td>
|
||||
<td><font color="00FF00">%offlineTrade%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Online GM count:</td>
|
||||
<td><font color="00FF00">%onlineGM%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Real player count:</td>
|
||||
<td><font color="00FF00">%onlineReal%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">Memory:<font><br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Used Memory:</td>
|
||||
<td><font color="00FF00">%usedMem% MB</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Free Memory:</td>
|
||||
<td><font color="00FF00">%freeMem% MB</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Total Memory:</td>
|
||||
<td><font color="00FF00">%totalMem% MB</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
</center>
|
||||
</body></html>
|
||||
<td>Used Memory:</td>
|
||||
<td><font color="00FF00">%usedMem%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Free Memory:</td>
|
||||
<td><font color="00FF00">%freeMem%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Total Memory:</td>
|
||||
<td><font color="00FF00">%totalMem%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">Threads:</font>
|
||||
<br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Live:</td>
|
||||
<td><font color="00FF00">%live%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Non-Daemon:</td>
|
||||
<td><font color="00FF00">%nondaemon%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Daemon:</td>
|
||||
<td><font color="00FF00">%daemon%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Peak:</td>
|
||||
<td><font color="00FF00">%peak%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Total started:</td>
|
||||
<td><font color="00FF00">%totalstarted%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">Garbage Collector:</font>
|
||||
<br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Type:</td>
|
||||
<td><font color="00FF00">%gcol%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Count:</td>
|
||||
<td><font color="00FF00">%colcount%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Time:</td>
|
||||
<td><font color="00FF00">%coltime%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">Players:</font>
|
||||
<br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>Total players count:</td>
|
||||
<td><font color="00FF00">%onlineAll%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Offline trade count:</td>
|
||||
<td><font color="00FF00">%offlineTrade%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Online GM count:</td>
|
||||
<td><font color="00FF00">%onlineGM%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Real player count:</td>
|
||||
<td><font color="00FF00">%onlineReal%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
<br>
|
||||
<font color="LEVEL">General:</font>
|
||||
<br1>
|
||||
<table width="270" border="0" bgcolor="444444">
|
||||
<tr>
|
||||
<td>OS:</td>
|
||||
<td><font color="00FF00">%os_name%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>OS version:</td>
|
||||
<td><font color="00FF00">%os_ver%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Server slots:</td>
|
||||
<td><font color="00FF00">%slots%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Server UpTime:</td>
|
||||
<td><font color="00FF00">%serverUpTime%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Server Time:</td>
|
||||
<td><font color="00FF00">%serverTime%</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Game Time:</td>
|
||||
<td><font color="00FF00">%gameTime% (%dayNight%)</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Pathfinding:</td>
|
||||
<td><font color="00FF00">%geodata%</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
</center>
|
||||
</body>
|
||||
</html>
|
@@ -1,6 +1,6 @@
|
||||
<html><body>Marksman Basil:<br>
|
||||
May you be blessed as you depart on your journey!<br>This is an exciting time, but take care that you do not forget your roots. We will always remember you!<br>
|
||||
When you go below the <FONT>Cave of Souls</FONT>, Kamael Village will appear.<br>
|
||||
When you go below the <font color="LEVEL">Cave of Souls</font>, Kamael Village will appear.<br>
|
||||
<Button ALIGN=LEFT ICON="NORMAL" action="bypass -h npc_%objectId%_TerritoryStatus">See information on permanent residence and tax rates.</Button>
|
||||
<Button ALIGN=LEFT ICON="QUEST" action="bypass -h npc_%objectId%_Quest">Quest.</Button>
|
||||
</body></html>
|
@@ -16,6 +16,11 @@
|
||||
*/
|
||||
package handlers.admincommandhandlers;
|
||||
|
||||
import java.lang.management.GarbageCollectorMXBean;
|
||||
import java.lang.management.ManagementFactory;
|
||||
import java.lang.management.MemoryMXBean;
|
||||
import java.lang.management.MemoryUsage;
|
||||
import java.lang.management.ThreadMXBean;
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.Collection;
|
||||
import java.util.Date;
|
||||
@@ -40,6 +45,8 @@ import org.l2jmobius.gameserver.taskmanager.GameTimeTaskManager;
|
||||
public class AdminServerInfo implements IAdminCommandHandler
|
||||
{
|
||||
private static final SimpleDateFormat SDF = new SimpleDateFormat("hh:mm a");
|
||||
private static final MemoryMXBean MEMORY_MX_BEAN = ManagementFactory.getMemoryMXBean();
|
||||
private static final ThreadMXBean THREAD_MX_BEAN = ManagementFactory.getThreadMXBean();
|
||||
|
||||
private static final String[] ADMIN_COMMANDS =
|
||||
{
|
||||
@@ -51,9 +58,15 @@ public class AdminServerInfo implements IAdminCommandHandler
|
||||
{
|
||||
if (command.equals("admin_serverinfo"))
|
||||
{
|
||||
final MemoryUsage heapMemoryUsage = MEMORY_MX_BEAN.getHeapMemoryUsage();
|
||||
final long freeMemory = heapMemoryUsage.getMax() - heapMemoryUsage.getUsed();
|
||||
final int threadCount = THREAD_MX_BEAN.getThreadCount();
|
||||
final int daemonCount = THREAD_MX_BEAN.getThreadCount();
|
||||
final int nonDaemonCount = threadCount - daemonCount;
|
||||
final int peakCount = THREAD_MX_BEAN.getPeakThreadCount();
|
||||
final long totalCount = THREAD_MX_BEAN.getTotalStartedThreadCount();
|
||||
|
||||
final NpcHtmlMessage html = new NpcHtmlMessage();
|
||||
final Runtime runTime = Runtime.getRuntime();
|
||||
final int mb = 1024 * 1024;
|
||||
html.setHtml(HtmCache.getInstance().getHtm(activeChar, "data/html/admin/serverinfo.htm"));
|
||||
html.replace("%os_name%", System.getProperty("os.name"));
|
||||
html.replace("%os_ver%", System.getProperty("os.version"));
|
||||
@@ -67,9 +80,20 @@ public class AdminServerInfo implements IAdminCommandHandler
|
||||
html.replace("%offlineTrade%", getPlayersCount("OFF_TRADE"));
|
||||
html.replace("%onlineGM%", getPlayersCount("GM"));
|
||||
html.replace("%onlineReal%", getPlayersCount("ALL_REAL"));
|
||||
html.replace("%usedMem%", (runTime.maxMemory() / mb) - (((runTime.maxMemory() - runTime.totalMemory()) + runTime.freeMemory()) / mb));
|
||||
html.replace("%freeMem%", ((runTime.maxMemory() - runTime.totalMemory()) + runTime.freeMemory()) / mb);
|
||||
html.replace("%totalMem%", Runtime.getRuntime().maxMemory() / 1048576);
|
||||
html.replace("%usedMem%", (MEMORY_MX_BEAN.getHeapMemoryUsage().getUsed() / 0x100000) + " Mb");
|
||||
html.replace("%freeMem%", (freeMemory / 0x100000) + " Mb");
|
||||
html.replace("%totalMem%", (MEMORY_MX_BEAN.getHeapMemoryUsage().getMax() / 0x100000) + " Mb");
|
||||
html.replace("%live%", threadCount);
|
||||
html.replace("%nondaemon%", nonDaemonCount);
|
||||
html.replace("%daemon%", daemonCount);
|
||||
html.replace("%peak%", peakCount);
|
||||
html.replace("%totalstarted%", totalCount);
|
||||
for (GarbageCollectorMXBean gcBean : ManagementFactory.getGarbageCollectorMXBeans())
|
||||
{
|
||||
html.replace("%gcol%", gcBean.getName());
|
||||
html.replace("%colcount%", gcBean.getCollectionCount());
|
||||
html.replace("%coltime%", gcBean.getCollectionTime());
|
||||
}
|
||||
activeChar.sendPacket(html);
|
||||
}
|
||||
return true;
|
||||
|
Reference in New Issue
Block a user