#结论:通过脚本sandbox.sh 向目标jvm注入模块
一.运行的sandbox目录如下:
xxxdeMBP:sandbox xxx$ tree
.
├── bin
│ └── sandbox.sh
├── cfg
│ ├── sandbox-logback.xml
│ ├── sandbox.properties
│ └── version
├── example
│ └── sandbox-debug-module.jar
├── install-local.sh
├── lib
│ ├── sandbox-agent.jar
│ ├── sandbox-core.jar
│ └── sandbox-spy.jar
├── module
│ ├── chaosblade-java-agent-1.2.0.jar
│ └── sandbox-mgr-module-1.3.3-jar-with-dependencies.jar
├── provider
│ └── sandbox-mgr-provider.jar
├── sandbox-module
└── tools.jar
二: 在jvm-sandbox工程里添加了一些输出,打包
mvn clean package -Dmaven.test.skip=true
把jvm-sandbox/sandbox-core/target/sandbox-core-1.3.3-jar-with-dependencies.jar 拷到"上面一"的sandbox/lib/sandbox-core.jar
把jvm-sandbox/sandbox-mgr-module/target/sandbox-mgr-module-1.3.3-jar-with-dependencies.jar 拷到"上面一"的sandbox/module/sandbox-mgr-module-1.3.3-jar-with-dependencies.jar
三:启动jvm
运行attachdemo工程里的GdMyTestMain.java
import java.util.concurrent.TimeUnit;
public class GdMyTestMain {
public static void main(String[] args) throws InterruptedException {
while (true) {
System.out.println(GetAge());
TimeUnit.SECONDS.sleep(4);
}
}
public static int GetAge() {
return 100; // 修改后 return 60;
}
}
四:向jvm挂载模块
sandbox/bin/sandbox.sh -p 15023 -m debug -l
-p 15023:GdMyTestMain的进程号。
chaosblade:是chaosblade-exec-jvm工程jar包里的SandboxModule.java的id,是chaosblade-java-agent-1.2.0.jar。
说明1: 其实执行的是:java -jar sandbox-core.jar -p xxx sanbox-agent.jar “home=xx;ip=xx;port…”
说明2: module/是实现了如下的描述才会被加载的。
@MetaInfServices(Module.class)
@Information(id = "sandbox-info", version = "0.0.4", author = "wendy@163.com")
public class InfoModule implements Module{}
这时GdMyTestMain的输出如下:
若有新的模块需要加载,需重启目标jvm 或是 再分析一下看是否有其它命令。
五:查看具体的模块
./sandbox.sh -p 15023 -d 'sandbox-module-mgr/detail?id=sandbox-info'
结果输出
备注:
./sandbox.sh -p 15023 -d ‘sandbox-module-mgr/list’ 相当于 ./sandbox.sh -p 15023 -l