Sandbox

1. 介绍

1.1 简介

JVM-SANDBOX(沙箱)实现了一种在不重启、不侵入目标JVM应用的AOP解决方案。Sandbox仅仅是提供一个无侵入的入口,至于将Sandbox作用于何处,是需要额外去定义的,例如Sandbox-Repeater就是集成Sandbox使用的流量回放框架(坑)。

1.2 特性

  • 无侵入:目标应用无需重启也无需感知沙箱的存在
  • 类隔离:沙箱以及沙箱的模块不会和目标应用的类相互干扰
  • 可插拔:沙箱以及沙箱的模块可以随时加载和卸载,不会在目标应用留下痕迹
  • 多租户:目标应用可以同时挂载不同租户下的沙箱并独立控制
  • 高兼容:支持JDK[6,11]

1.3 原理

1.3.1  Java agent介绍

(1)什么是Java agent

java agent本质上可以理解为一个插件,该插件就是一个精心提供的jar包,这个jar包通过JVMTI(JVM Tool Interface)完成加载,最终借助JPLISAgent(Java Programming Language Instrumentation Services Agent)完成对目标代码的修改。

(2)功能

  • 可以在加载java文件之前做拦截把字节码做修改

  • 可以在运行期将已经加载的类的字节码做变更

  • 还有其他的一些小众的功能

    • 获取所有已经被加载过的类

    • 获取所有已经被初始化过了的类

    • 获取某个对象的大小

    • 将某个jar加入到bootstrapclasspath里作为高优先级被bootstrapClassloader加载

    • 将某个jar加入到classpath里供AppClassloard去加载

    • 设置某些native方法的前缀,主要在查找native方法的时候做规则匹配

(3) 实现agent启动方法

Java Agent支持目标JVM启动时加载,也支持在目标JVM运行时加载,这两种不同的加载模式会使用不同的入口函数,如果需要在目标JVM启动的同时加载Agent,那么可以选择实现下面的方法:

[1] public static void premain(String agentArgs, Instrumentation inst); 
[2] public static void premain(String agentArgs);

JVM将首先寻找[1],如果没有发现[1],再寻找[2]。如果希望在目标JVM运行时加载Agent,则需要实现下面的方法:

[1] public static void agentmain(String agentArgs, Instrumentation inst); 
[2] public static void agentmain(String agentArgs);

(4)指定Main-Class

<build>
        <finalName>xxx-${project.version}</finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-assembly-plugin</artifactId>
                <executions>
                    <execution>
                        <goals>
                            <goal>attached</goal>
                        </goals>
                        <phase>package</phase>
                        <configuration>
                            <descriptorRefs>
                                <descriptorRef>jar-with-dependencies</descriptorRef>
                            </descriptorRefs>
                            <archive>
                                <manifestEntries>
                                    <Premain-Class>com.alibaba.jvm.sandbox.agent.AgentLauncher</Premain-Class>
                                    <Agent-Class>com.alibaba.jvm.sandbox.agent.AgentLauncher</Agent-Class>
                                    <Can-Redefine-Classes>true</Can-Redefine-Classes>
                                    <Can-Retransform-Classes>true</Can-Retransform-Classes>
                                </manifestEntries>
                            </archive>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

(5)agent加载

  • 启动时加载

    • 启动参数增加-javaagent:[path],其中path为对应的agent的jar包路径

  • 运行中加载

    • 使用com.sun.tools.attach.VirtualMachine加载

try {
  String jvmPid = 目标进行的pid;
  logger.info("Attaching to target JVM with PID: " + jvmPid);
  VirtualMachine jvm = VirtualMachine.attach(jvmPid);
  jvm.loadAgent(agentFilePath);//agentFilePath为agent的路径
  jvm.detach();
  logger.info("Attached to target JVM and loaded Java agent successfully");
} catch (Exception e) {
  throw new RuntimeException(e);
}

 1.4 Sandbox和Arthas

TBD

2. 源码

3. FAQ

3.1 jar-with-dependencies

 

4. 参考资料

jvm-sandbox

<think>好的,用户想了解如何使用和配置Windows Sandbox。首先,我需要回顾一下Windows Sandbox的基本信息。Windows Sandbox是Windows 10和11专业版及企业版中的一个功能,允许用户在隔离的临时环境中运行应用程序,确保主系统安全。用户可能需要知道系统要求、启用步骤、配置方法以及使用技巧。 首先,系统要求。用户需要确认他们的Windows版本是否符合,比如是否专业版或企业版,版本号是否1903或更高。然后,虚拟化是否在BIOS中启用。这点很重要,如果虚拟化没开启,Sandbox可能无法运行。接下来,内存和存储空间的需求,至少4GB内存和1GB可用空间。 然后是如何启用Windows Sandbox。步骤大致是通过控制面板或PowerShell启用功能。可能需要重启系统。这部分需要详细说明,用户可能对启用Windows功能不太熟悉,特别是通过PowerShell命令。 配置部分,用户可能需要创建配置文件,比如.wsb文件来调整参数,比如内存分配、网络设置等。这里需要给出示例配置文件的内容,说明各个参数的作用,比如vGPU、网络、映射文件夹等。用户可能希望自定义这些设置以适应他们的需求。 使用指南方面,启动Sandbox后如何安装软件,复制文件,以及关闭后数据丢失的特性需要强调。安全注意事项也很重要,比如不处理敏感数据,防止恶意软件等。 引用现有的资料,比如引用1和2提到的项目,可能对用户进一步定制或扩展功能有帮助,比如使用开源工具增强Sandbox的功能。此外,常见问题解答,比如无法启动的问题,需要检查虚拟化和Hyper-V服务。 需要确保回答结构清晰,分步骤说明,并给出具体的命令和配置示例。同时,要提醒用户注意系统版本和可能的兼容性问题。最后,生成相关问题,帮助用户深入探索,比如优化配置、解决启动问题、与第三方沙盒比较等。</think>### Windows Sandbox 使用指南 #### 一、系统要求 1. **操作系统版本**:Windows 10/11 专业版或企业版(版本 1903 或更高)[^1] 2. **硬件虚拟化支持**:需在 BIOS/UEFI 中启用虚拟化技术(Intel VT-x 或 AMD-V) 3. **内存**:推荐 8GB 以上(Sandbox 默认占用 4GB) 4. **存储**:至少 1GB 可用空间 #### 二、启用 Windows Sandbox 1. **通过控制面板启用**: - 打开“控制面板 → 程序 → 启用或关闭 Windows 功能” - 勾选“Windows Sandbox”并重启系统 2. **通过 PowerShell 启用**: ```powershell Enable-WindowsOptionalFeature -FeatureName "Containers-DisposableClientVM" -All -Online ``` 重启后生效[^1] #### 三、基本使用 1. **启动 Sandbox**: - 在开始菜单搜索“Windows Sandbox”并以管理员身份运行 - 启动后会生成一个干净的 Windows 临时实例 2. **文件交互**: - 直接从主机拖放文件到 Sandbox 窗口 - 支持剪贴板共享(文本/图像) 3. **关闭 Sandbox**: - 关闭窗口后所有数据和修改自动清除 #### 四、高级配置(通过 .wsb 文件) 创建配置文件 `MySandbox.wsb`: ```xml <Configuration> <vGPU>Enable</vGPU> <MemoryInMB>8192</MemoryInMB> <Networking>Disable</Networking> <MappedFolders> <MappedFolder> <HostFolder>C:\Shared</HostFolder> <ReadOnly>true</ReadOnly> </MappedFolder> </MappedFolders> </Configuration> ``` - **参数说明**: - `vGPU`: 启用虚拟 GPU 加速 - `MemoryInMB`: 自定义内存分配 - `Networking`: 禁用网络访问(增强隔离) - `MappedFolders`: 映射主机文件夹(设置只读更安全)[^2] #### 五、安全注意事项 1. 不要在 Sandbox 中处理未加密的敏感数据 2. 运行未知程序时建议禁用网络映射 3. 避免同时运行多个 Sandbox 实例(可能导致资源争用) #### 六、常见问题解决 - **无法启动 Sandbox**: 1. 检查 BIOS 中虚拟化是否启用 2. 确认 Hyper-V 服务正在运行 3. 执行系统文件检查:`sfc /scannow` - **性能优化**: ```xml <Configuration> <MemoryInMB>4096</MemoryInMB> <ClipboardRedirection>Disable</ClipboardRedirection> </Configuration> ``` 减少内存分配并禁用剪贴板重定向可提升性能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值