linugb118--java space

          Java

          jolokia 剛認(rèn)識

          一直以來,經(jīng)常看到JMX這個keyword,于是就想什么時候研究一下,看了半天的材料,看得云里霧里,大概的意思好像就是說,各式可以的系統(tǒng)
          分布在任何地方,如何統(tǒng)一去管理,去監(jiān)控,于是sun就引入了jmx的概念。
          但是具體怎么,如何使用,心里不清楚,直接看jms spec很吃力,忽然之間想,可以先從現(xiàn)有的jmx 框架去一個個研究,或許就能慢慢理解他的含義。

          首先選擇Jolokia:
          http://www.jolokia.org。

          他們的官方描述是:
          Jolokia is a JMX-HTTP bridge giving an alternative to JSR-160 connectors. It is an agent based approach with support for many platforms. In addition to basic JMX operations it enhances JMX remoting with unique features like bulk requests or fine grained security policies.

          廢話少說,先下載安裝再說。

          在jolokia的Artifact 里面有面向不同框架方面的相關(guān)產(chǎn)品,
          我下載了jolokia.war  他應(yīng)該表示j2ee 應(yīng)用服務(wù),將 war部署到tomcat后
          訪問http://127.0.0.1:8080/jolokia
          發(fā)現(xiàn)輸出為
          {"timestamp":1298621555,"status":200,"request":{"type":"version"},"value":{"protocol":"4.1","agent":"0.83","info":{"product":"tomcat","vendor":"Apache","version":"6.0.18"}}}

          這是一串json字符串,里面是jmx信息,其中有我放入的容器是tomcat以及它的版本。
          我想 如果我將war放入weblogic 或者其他j2ee 容器,應(yīng)該對象的輸出會有相關(guān)的j2ee的信息。


          Artifact里面還有osgi和jvm的,因為osgi不是很熟,暫時就不研究,那么在開始jvm對應(yīng)的jar
          研究jvm 首先要了解javaAgent 參數(shù)的含義,為此先補一下-javaAgent 參數(shù)的知識。
          具體可以參考
          http://i-giraffe.com/2010/12/javaagent-example/
          這里簡要概括一下這個參數(shù)的含義,javaAgent 在main方法執(zhí)行之前,執(zhí)行agent的代碼;必須實現(xiàn)premain這個方法。
          因為是在main之前執(zhí)行,那么可以運用在不修改現(xiàn)有程序來增強或修改軟件,或者熱啟動等等。

          接下來我們再回到j(luò)olokia jvm版本
          首先我們下載這個jolokia_jvm_agent.jar 改為agent.jar, 下面我們需要寫一個java application;
          代碼如下
          public class FirstThread extends Thread{//繼承Thread重寫run方法
          @Override
          public void run(){
             for (int i = 0; i < 300000; i++) {
              System.out.println(i);
           
             try {
              Thread.sleep(100);//停100毫秒
             } catch (InterruptedException e) {
              e.printStackTrace();
              }
             }
          }
          }

          //////////////////main
          public class MyProgram{
           public static void main(String[] args) {
            
            FirstThread fThread=new FirstThread();
               fThread.start();
               for (int i = 0; i < 300; i++) {
           
                try {
              Thread.sleep(100);
             } catch (InterruptedException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
             }
           }
          }
          }

          我們打包為demo.jar
          在cmd 命令下執(zhí)行 java -javaagent:agent.jar -jar demo.jar
          執(zhí)行后我們訪問
          http://127.0.0.1:8778/jolokia/
          會出現(xiàn)json的jmx 信息
          {"timestamp":1299226883,"status":200,"request":{"type":"version"},"value":{"protocol":"4.1","agent":"0.83","info":{}}}

          這里需要注意兩點
          如果我訪問
          http://127.0.0.1:8778/jolokia 則會出現(xiàn)404

          另外如果上面的線程循環(huán)很小,一會兒就結(jié)束了,那么這個時候再訪問就會找不到服務(wù)器。
          另外agent的端口和host都可以通過參數(shù)來設(shè)定,具體可以查看jolokia jvm 相關(guān)的網(wǎng)頁。
          到目前為止,jolokia for jvm也演示結(jié)束了。

           

           

           

           

           

           


           

          posted on 2011-03-04 16:40 linugb118 閱讀(1743) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           

          My Links

          Blog Stats

          常用鏈接

          留言簿(1)

          隨筆檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 鄂托克旗| 汽车| 夏邑县| 会宁县| 桂阳县| 雷波县| 汨罗市| 奉贤区| 资讯 | 桐城市| 射洪县| 建始县| 仙游县| 美姑县| 昌江| 宁陵县| 达孜县| 克山县| 滨海县| 涡阳县| 常熟市| 沙洋县| 米易县| 拉萨市| 义马市| 宜春市| 连江县| 锦屏县| 游戏| 固安县| 凉城县| 乌兰浩特市| 白沙| 陵川县| 水城县| 梧州市| 霸州市| 鲁山县| 平原县| 茂名市| 正宁县|