监控Tomcat解决方案(监控应用服务器系列文章分享)
使用JMX接口開發(fā)監(jiān)控程序
? ◆ 全部代碼需要從零開始,代碼量較大
? ◆ 支持各不同版本比較麻煩,每個(gè)版本可能有差異
? ◆ 可支配性強(qiáng)
? ◆ 最重要的一個(gè)缺點(diǎn)是,配置比較麻煩
Tomcat激活JMX遠(yuǎn)程配置
① ■?先修改Tomcat的啟動(dòng)腳本,window下tomcat的bin/catalina.bat(linux為catalina.sh),添加以下內(nèi)容,8999是jmxremote使用的端口號(hào),第二個(gè)false表示不需要鑒權(quán):
set JMX_REMOTE_CONFIG=-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=falseset CATALINA_OPTS=%CATALINA_OPTS% %JMX_REMOTE_CONFIG%
?
可以加在if "%OS%" == "Windows_NT" setlocal 一句后的大段的注釋后面。
參考官方說明:
????http://tomcat.apache.org/tomcat-6.0-doc/monitoring.html#Enabling_JMX_Remote
② ■?上面的配置是不需要鑒權(quán)的,如果需要鑒權(quán)則添加的內(nèi)容為:
set CATALINA_OPTS=%CATALINA_OPTS% %JMX_REMOTE_CONFIG%
?
? 然后復(fù)制并修改授權(quán)文件,$JAVA_HOME/jre/lib/management下有jmxremote.access和jmxremote.password的模板文件,將兩個(gè)文件復(fù)制到$CATALINA_BASE/conf目錄下
? ● 修改$CATALINA_BASE/conf/jmxremote.access 添加內(nèi)容:
???? monitorRole readonly
???? controlRole readwrite
? ● 修改$CATALINA_BASE/conf/jmxremote.password 添加內(nèi)容:
???? monitorRole tomcat
???? controlRole tomcat
注意:如果只做第一步?jīng)]有問題,進(jìn)行了第二步Tomcat就啟動(dòng)不了,那么很可能是密碼文件的權(quán)限問題
??? 需要修改jmxremote.password文件的權(quán)限,只有運(yùn)行Tomcat的用戶有訪問權(quán)限
??? Windows的NTFS文件系統(tǒng)下,選中文件,點(diǎn)右鍵 -->“屬性”-->“安全”--> 點(diǎn)“高級(jí)”--> 點(diǎn)“更改權(quán)限”--> 去掉“從父項(xiàng)繼承....”--> 彈出窗口中選“刪除”,這樣就刪除了所有訪問權(quán)限。再選“添加”--> “高級(jí)”--> “立即查找”,選中你的用戶,例administrator,點(diǎn)“確定",“確定"。來到權(quán)限項(xiàng)目窗口,勾選“完全控制”,點(diǎn)“確定”,OK了。
官方的提示:
????The password file should be read-only and only accessible by the operating system user Tomcat is running as.?
③ ■?重新啟動(dòng)Tomcat,在Windows命令行輸入“netstat -ano”查看配置的端口號(hào)是否已打開,如果打開,說明上面的配置成功了。
④ ■?使用jconsole測(cè)試JMX。
?? 運(yùn)行$JAVA_HOME/bin目錄下的jconsole.exe,打開J2SE監(jiān)視和管理控制臺(tái),然后建立連接,如果是本地的Tomcat則直接選擇然后點(diǎn)擊連接,如果是遠(yuǎn)程的,則進(jìn)入遠(yuǎn)程選項(xiàng)卡,填寫地址、端口號(hào)、用戶名、口令即可連接。Mbean屬性頁(yè)中給出了相應(yīng)的數(shù)據(jù),Catalina中是tomcat的,java.lang是jvm的。對(duì)于加粗的黑體屬性值,需雙擊一下才可看內(nèi)容。
遇到的幾個(gè)問題:
1.tomcat必須要用命令或者startup.bat啟動(dòng),jconsole才能連接成功。
2.盡量用第一種方式配置,但是要把密碼文件拷貝到tomcat-conf目錄下,設(shè)置密碼和口令。
3.tomcat必須配置環(huán)境變量,如有多個(gè)tomcat同一臺(tái)服務(wù)器上,則添加一個(gè)CATALINA_HOME2,然后把tomcat下面catalina.bat和startup.bat中所有CATALINA_HOME替換為CATALINA_HOME2.
實(shí)例代碼:
package com.gsww.jup.controller.chatShowController;
import java.lang.management.MemoryUsage;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.Formatter;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.management.MBeanServerConnection;
import javax.management.ObjectName;
import javax.management.openmbean.CompositeDataSupport;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL;
import javax.servlet.ServletRequest;
import javax.servlet.http.HttpServletRequest;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import com.gsww.jup.controller.BaseController;
@Controller
@RequestMapping(value = "/applicationServerMonitoring")
public class ApplicationServerMonitoringController extends BaseController{
@RequestMapping(value = "/serverList",method = RequestMethod.GET)
public String serverList(Model model,ServletRequest request,HttpServletRequest hrequest) {
try{
List<Map<String,Object>> list=new ArrayList<Map<String,Object>>();
Map<String,Object> map=getMap("61.178.5.73","8092");
map.put("server", "客戶端接口服務(wù)1");
Map<String,Object> map1=getMap("10.18.23.218","8088");
map1.put("server", "客戶端接口服務(wù)2");
Map<String,Object> map2=getMap("127.0.0.1","7999");
map2.put("server", "心跳接口服務(wù)");
Map<String,Object> map3=getMap("127.0.0.1","8999");
map3.put("server", "后臺(tái)服務(wù)");
list.add(map);
list.add(map1);
list.add(map2);
list.add(map3);
model.addAttribute("list", list);
}catch(Exception ex){
ex.printStackTrace();
}
return "chatShow/serverMonitor_list";
}
public Map<String, Object> getMap(String ip,String port){
Map<String, Object> serverMap=new HashMap<String, Object>();
try {
String jmxURL = "service:jmx:rmi:///jndi/rmi://"+ip+":"+port+"/jmxrmi";//tomcat jmx url
JMXServiceURL serviceURL = new JMXServiceURL(jmxURL);
Map map = new HashMap();
String[] credentials = new String[] { "monitorRole" , "QED" };
map.put("jmx.remote.credentials", credentials);
JMXConnector connector = JMXConnectorFactory.connect(serviceURL, map);
MBeanServerConnection mbsc = connector.getMBeanServerConnection();
//------------------------ JVM -------------------------
//堆使用率
ObjectName heapObjName = new ObjectName("java.lang:type=Memory");
MemoryUsage heapMemoryUsage = MemoryUsage.from((CompositeDataSupport)mbsc.getAttribute(heapObjName, "HeapMemoryUsage"));
long maxMemory = heapMemoryUsage.getMax();//堆最大
long commitMemory = heapMemoryUsage.getCommitted();//堆當(dāng)前分配
long usedMemory = heapMemoryUsage.getUsed();
System.out.println("推最大:"+maxMemory);
System.out.println("堆當(dāng)前分配:"+commitMemory);
System.out.println("堆使用:"+usedMemory);
System.out.println("heap:"+(double)usedMemory*100/commitMemory+"%");//堆使用率
serverMap.put("maxMemory", format((double)maxMemory/1000000)+"M");
serverMap.put("commitMemory", format((double)commitMemory/1000000)+"M");
serverMap.put("usedMemory", format((double)usedMemory/1000000)+"M");
serverMap.put("usedPersent", format((double)usedMemory*100/commitMemory)+"%");
return serverMap;
} catch (Exception e) {
serverMap.put("maxMemory", "--");
serverMap.put("commitMemory", "--");
serverMap.put("usedMemory", "--");
serverMap.put("usedPersent", "100.00%");
return serverMap;
}
}
public String formatTimeSpan(long span){
long minseconds = span % 1000;
span = span /1000;
long seconds = span % 60;
span = span / 60;
long mins = span % 60;
span = span / 60;
long hours = span % 24;
span = span / 24;
long days = span;
return (new Formatter()).format("%1$d天 %2$02d:%3$02d:%4$02d.%5$03d", days,hours,mins,seconds,minseconds).toString();
}
public String format(double s) {
DecimalFormat df = new DecimalFormat("#.##");
return df.format(s);
}
}
轉(zhuǎn)載于:https://www.cnblogs.com/wjwen/p/4829932.html
總結(jié)
以上是生活随笔為你收集整理的监控Tomcat解决方案(监控应用服务器系列文章分享)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: hdu 1700 (圆的内接三角形 要周
- 下一篇: iOS开发UI篇--UIScrollVi