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)类类型向字 ...
随机推荐
- objective-c 语法快速过(2)
oc类的声明和定义的常见错误 1.只有类的声明,没有类的实现 2.漏了@end 3.@interface和@implementation嵌套,也就是@interface或者@implementatio ...
- 1Z0-053 争议题目解析175
1Z0-053 争议题目解析175 考试科目:1Z0-053 题库版本:V13.02 题库中原题为: 175.You are peer reviewing a fellow DBAs backup p ...
- (十二) WebGIS中矢量图层的设计
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.前言 在前几章中我们已经了解了什么是矢量查询.屏幕坐标与地理坐标之 ...
- Android TextView中显示图片
Android官方给我们提供的Html类下面的fromHtml方法 当你需要转换的HTML代码是带图片的,比如<IMG/>,那么你就需要使用到重载的第二个方法了,这个方法里面有个Image ...
- MySQL4.0命令操作学习笔记
声明:下列内容并非原创,仅仅是最近学习笔记整理. -------------------------------------- 进入mysql安装路径bin目录下: 1.开启服务 winmysqlad ...
- Linux 学习笔记
Linux学习笔记 请切换web视图查看,表格比较大,方法:视图>>web板式视图 博客园不能粘贴图片吗 http://wenku.baidu.com/view/bda1c3067fd53 ...
- 实际案例:在现有代码中通过async/await实现并行
一项新技术或者一个新特性,只有你用它解决实际问题后,才能真正体会到它的魅力,真正理解它.也期待大家能够多分享解一些解决实际问题的内容. 在我们遭遇“黑色30秒”问题的过程中,切身体会到了异步的巨大作用 ...
- Effective java笔记(十),序列化
将一个对象编码成字节流称作将该对象「序列化」.相反,从字节流编码中重新构建对象被称作「反序列化」.一旦对象被「序列化」后,它的编码就可以从一台虚拟机传递到另一台虚拟机,或被存储到磁盘上,供以后「反序列 ...
- Devexpress Gantt 应用
甘特图属于甘特系列浏览次数(也称为时间或时间轴图表).此视图显示横条沿时间轴.每个条形代表一个单独的事件的开始和结束的值, 因此,这些图是用来跟踪各种活动的时间范围内(例如计划,利用各种资源,审查该项 ...
- 高效的SQLSERVER分页查询的几种示例分析
Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...