JavaSe:-javaagent,-agentlib,-agentpath
内容简述
-javaagent、-agentlib、-agentpath
-agentlib:libname[=options]
用于装载本地lib包;
其中libname为本地代理库文件名,默认搜索路径为环境变量PATH中的路径,options为传给本地库启动时的参数,多个参数之间用逗号分隔。在Windows平台上jvm搜索本地库名为libname.dll的文件,在linux上jvm搜索本地库名为libname.so的文件,搜索路径环境变量在不同系统上有所不同,比如Solaries上就默认搜索LD_LIBRARY_PATH。
比如:-agentlib:hprof
用来获取jvm的运行情况,包括CPU、内存、线程等的运行数据,并可输出到指定文件中;windows中搜索路径为JRE_HOME/bin/hprof.dll。
-agentpath:pathname[=options]
按全路径装载本地库,不再搜索PATH中的路径;其他功能和agentlib相同;更多的信息待续,在后续的JVMTI部分会详述。
-javaagent:jarpath[=options]
指定jvm启动时装入java语言基础设施代理。jarpath文件中的mainfest文件必须有Premain-Class(启动前捆绑时需要), Agent-Class(运行时捆绑时需要)属性。代理类也必须实现公共的静态public static void premain(String agentArgs, Instrumentation inst)方法(和main方法类似)。当jvm初始化时,将按代理类的说明顺序调用premain方法;具体参见java.lang.instrument软件包的描述。
具体的描述参间下面的程序中的注释:
-javaagent 示例
package com.fjn.jdk.jvm.options.javaagent;
import java.io.IOException;
import java.lang.instrument.Instrumentation;
import com.sun.tools.attach.AttachNotSupportedException;
public class CustomAgent {
/**
* 如果Agent是通过JVM选项的方式捆绑到程序中,则在JVM初化完毕后,会执行premain方法,premain执行之后才是程序的main方法。
* 清单文件中需要指定Premain-Class 12 * <p>
* premain有两种形式,默认会执行1), 如果没有1)则会执行2), 1)和2)只会执行一个<br>
* <code>
* 1) public static void premain(String agentArgs, Instrumentation instrumentation)<br/>
* 2) public static void premain(String agentArgs)
* </code></p>
*
* @param agentArgs
* @param instrumentation
*/
public static void premain(String agentArgs, Instrumentation instrumentation) {
System.out
.println("CustomAgent#premain(String agentArgs, Instrumentation instrumentation)");
parseAgentArgs(agentArgs);
}
public static void premain(String agentArgs) {
System.out.println("CustomAgent#premain(String agentArgs)");
parseAgentArgs(agentArgs);
}
/**
* 如果Agent是在程序运行过程中,动态的捆绑到程序中,则是执行agentmain方法。
* 清单文件中要指定 Agent-Class
* <p>
* agentmain有两种形式,默认会执行1), 如果没有1)则会执行2), 1)和2)只会执行一个<br>
* <code>
* 1) public static void agentmain(String agentArgs, Instrumentation instrumentation)<br/>
* 2) public static void agentmain(String agentArgs)
* </code></p>
*
* 通过程序捆绑的代码:<br/>
* <code>
* VirtualMachine vm=VirtualMachine.attach("PID"); //给指定的进程捆绑agent<br/>
* 在得到目标进程的vm后,就可以通过
* vm.loadAgent("agentjar"),vm.loadAgentLibrary(dll), and loadAgentPath(dllPath) 进行捆绑操作了 <br/>
* 其中:<br>
* loadAgent是捆绑一个jar文件,
* loadAgentLibrary,loadAgentPath则是捆绑本地方法库(动态连接库)
* </code>
*
* @param agentArgs
* @param inst
*/
public static void agentmain(String agentArgs, Instrumentation inst) {
System.out
.println("CustomAgent#agentmain(String agentArgs, Instrumentation instrumentation)");
parseAgentArgs(agentArgs);
}
public static void agentmain(String agentArgs) {
System.out.println("CustomAgent#agentmain(String agentArgs)");
parseAgentArgs(agentArgs);
}
/**
* 不论是premain,还在agentmain,都可以指定参数,参数是一个字符串,具体怎么解析,是程序自己的事
* @param agentArgs
* @return
* @throws IOException
* @throws AttachNotSupportedException
*/
private static boolean parseAgentArgs(String agentArgs) {
boolean hasArgs = false;
if (agentArgs != null && !agentArgs.isEmpty()) {
System.out.println("agentArgs is : " + agentArgs);
hasArgs = true;
} else {
System.out.println("has no agentArgs .");
}
return hasArgs;
}
}
将该类打包成customagent.jar,放到D盘根目录下,
清单文件:
Manifest-Version: 1.0 Premain-Class: com.fjn.jdk.jvm.options.javaagent.CustomAgent Sealed: true
测试代码:
package com.fjn.jdk.jvm.options.javaagent;
import org.junit.Test;
public class JavaAgentTest {
/**
* 在启动时,使用-javaagent方式加入代理
* <code>
* -javaagent:D:/customagent.jar="Here, your can input agent arguments"
* 如果要指定参数值
* </code>
*/
@Test
public void testPremain(){
System.out.println("test premain, sepcial inst...");
}
}
执行结果:
CustomAgent#premain(String agentArgs, Instrumentation instrumentation) agentArgs is : Here, your can input agent arguments test premain, sepcial inst...
想要了解动态捆绑机制,可以参考:
JavaSe:-javaagent,-agentlib,-agentpath的更多相关文章
- JVM插码之三:javaagent介绍及javassist介绍
本文介绍一下,当下比较基础但是使用场景却很多的一种技术,稍微偏底层点,就是字节码插庄技术了...,如果之前大家熟悉了asm,cglib以及javassit等技术,那么下面说的就很简单了...,因为下面 ...
- JavaSe:Properties文件格式
Properties文件格式说明 Properties继承自Hashtable,是由一组key-value的集合. 在Java中,常用properties文件作为配置文件.它的格式是什么样的呢? 下图 ...
- JavaSe:ThreadLocal
JDK中有一个ThreadLocal类,使用很方便,但是却很容易出现问题.究其原因, 就是对ThreadLocal理解不到位.最近项目中,出现了内存泄漏的问题.其中就有同事在使用ThreadLocal ...
- JavaSe:Cookie 管理的API介绍
CookieManager 在使用HttpURLConnection中,并没有关于Cookie的管理.如果使用Java程序时,怎么管理cookie呢? Cookie案例 1. User Agent - ...
- JavaSe:Comparator
今天,公司里有一个萌萌的妹子问我java 中的comparator是怎么回事.参数分别是什么,返回值又是什么,为此,我写了一个简单的程序告诉了她: public static void main (S ...
- JavaSe:代码块执行顺序
//执行顺序:(优先级从高到低.)静态代码块>mian方法>构造代码块>构造方法. 其中静态代码块只执行一次.构造代码块在每次创建对象是都会执行. //普通代码块:在方法或语句中出现 ...
- JavaSe:UncaughtExceptionHandler
Java中,出现对于异常的处理,通常是使用try{}catch()来捕获处理的.但是在使用trycatch时,未必会将所有的异常都捕获到,所以方法声明时可以有throws xxxException. ...
- JavaSE:关键字(全)
访问控制: private 访问控制方式:私有的 protected 访问控制方式:受保护的 public 访问控制方式:公共的 类.方法和变量修饰符: abstract 声明抽象,表明类或者成员方法 ...
- JavaSE:数据类型之间的转换(附常见面试题)
数据类型之间的转换 分为以下几种情况: 1)低级到高级的自动类型转换: 2)高级到低级的强制类型转换(会导致溢出或丢失精度): 3)基本类型向类类型转换: 4)基本类型向字符串的转换: 5)类类型向字 ...
随机推荐
- h5直播开发之旅总结
前言 关于直播,有很多相关技术文章,这里不多说. 作为前端,我们比较关心我们所需要的. 直播的大致流程: APP端调用摄像头 -> 拍摄视频 -> 实时上传视频 -> 服务器端获取视 ...
- 原创:微信小程序入口猜想?
昨天看到一篇文章:是有一个人逆向了微信源码,从中发现了很多关于小程序的未公开内容,然后发布了出来,不过很快作者就删掉了文章,而我也没保留,只是隐约留下来一点点印象,就是作者推测了很多个入口:作者删掉的 ...
- js修改不了input的值
奇怪的input 今天想做一个通过点击按钮,修改input值的控件,但是点击按钮后,input值变成修改的值后又变回了原来的值,百思不得其解,代码如下 <form> <div cla ...
- 让你的web程序“动”起来。
看到这里你可能会问,asp.net程序本身就是动态网站,还要如何动? 我这里所谓的动起来,是指动态加载,动态更新.好吧可能你又要问了动态网站本来就是动态加载,动态更新的.asp.net的程序依附于II ...
- 数据结构Java实现01----算法概述
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- CSS-清除浮动
什么是CSS清除浮动? 在非IE浏览器(如Firefox)下,当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高 ...
- WinFrom 公共控件 Listview 的使用
Listview绑定数据库数据展示与操作使用 1.拖一个Listview控件到项目中先将视图改为Details 2.编辑列 设置列头 添加columnHeader成员 Text 是显示的名称 3. ...
- 纯css3艺术文字样式效果代码
效果:http://hovertree.com/texiao/css3/1/ 本效果主要使用text-shadow实现.参考:http://hovertree.com/h/bjaf/css3_text ...
- MVC5中后台提供Json,前台处理Json,绑定给Dropdownlist的例子
MVC5中后台提供Json,前台处理Json,绑定给Dropdownlist的例子: 前端: 我们以前在前端定义了两个控件: <div class="row"> < ...
- LA4287--tarjan
题目大意: 在数学中,我们常常需要完成若干个命题的等价性证明.比如,有4个命题a,b,c,d,我们证明a↔b,然后b↔c,最后c↔d.注意每次证明都是双向的,因此一共完成了6次推导.另一种方法是a→b ...