使用java语言与Linux交互

PelicanDT(Pelican Distributed Test),是阿里云提供的一款针对 Linux 系统的测试环境模拟工具,是主要针对分布式应用提供的集成测试解决方案,用于帮助开发者简单、高效地测试分布式应用。

PelicanDT 具有以下特点:

  • 使用 Java 语言与 Linux 系统交互。
  • 本地控制远程服务器上的 Linux 系统执行命令。
  • 通过简单的操作对服务器注入异常来模拟测试环境。例如:停止应用、CPU 占用率过高、CPU 内存过高、网络中断、网络流量延时等测试环境。

安装PelicanDT

maven引入PelicanDT包

<dependency>
    <groupId>com.alibaba.pelican</groupId>
    <artifactId>PelicanDT</artifactId>
    <version>1.0.9</version>
</dependency>

执行shell命令

public static void main(String[] args) {
    String ip = "127.0.0.1";
    String username = "root";
    String password = "root";

    RemoteCmdClientConfig remoteCmdClientConfig = new RemoteCmdClientConfig();
    remoteCmdClientConfig.setIp(ip);
    remoteCmdClientConfig.setUserName(username);
    remoteCmdClientConfig.setPassword(password);
    
    RemoteCmdClient remoteCmdClient = new RemoteCmdClient(remoteCmdClientConfig);
    RemoteCmdResult cmdResult = remoteCmdClient.execCmdWithPTY(new RemoteCmd("docker ps"));
    System.out.println(cmdResult.getStdInfo());
    /**
         * 打印到的信息:
         * [root@izwz98p1f98lx99punh7ekz ~]$docker ps
         * CONTAINER ID        IMAGE                                                  COMMAND                  CREATED             STATUS              PORTS                    NAMES
         * 8dc05b78881f        hub.c.163.com/library/nginx                            "nginx -g 'daemon ..."   4 months ago        Up 5 weeks          0.0.0.0:80->80/tcp       nginx
         * a8cf4f62fc84        registry.cn-shenzhen.aliyuncs.com/sunit/nacos-server   "bin/docker-startu..."   4 months ago        Up 3 months         0.0.0.0:8858->8848/tcp   nacos
         * [root@izwz98p1f98lx99punh7ekz ~]$export HISTFILE=/dev/null
         * [root@izwz98p1f98lx99punh7ekz ~]$exit
         * logout
         */
    }

通过名称标识符停止应用

public static void main(String[] args) {
        String ip = "127.0.0.1";
        String username = "root";
        String password = "root";

        RemoteCmdClientConfig remoteCmdClientConfig = new RemoteCmdClientConfig();
        remoteCmdClientConfig.setIp(ip);
        remoteCmdClientConfig.setUserName(username);
        remoteCmdClientConfig.setPassword(password);

        RemoteCmdClient remoteCmdClient = new RemoteCmdClient(remoteCmdClientConfig);

    
    	// 通过名称把该应用停止, 其实内部执行的是下面这个命令
        // ps -ef|grep nacos| grep -v grep | awk '{print $2}' | xargs kill -9
        remoteCmdClient.killProcess("nacos");
    }

拉高服务器内存占用率

使用 PelicanDT 模拟服务器内存占用率为 75%、持续时间 1 分钟的测试环境,具体操作步骤如下:

public static void main(String[] args) {
     //服务器IP
     String ip = "";
     //服务器用户名
     String userName = "";
     //服务器登录密码
     String password = "";
     RemoteCmdClientConfig config = new RemoteCmdClientConfig();
     config.setIp(ip);
     config.setUserName(userName);
     config.setPassword(password);
     RemoteCmdClient client = new RemoteCmdClient(config);
     //内存占用单位为M
     int percent = 6144;
     //持续时间单位分钟
     int delayMinutes = 1;
     //内存占用率拉高
     MemUtils.adjustMemUsage(client, percent, delayMinutes);
 }

拉高服务器 CPU 占用率

在本示例中,将模拟 CPU 占用率为 75%,持续时间 3 分钟的环境

public static void main(String[] args) {
     //远程服务器IP
     String ip = "";
     //远程服务器用户名
     String userName = "";
     //远程服务器登录密码
     String password = "";
     RemoteCmdClientConfig config = new RemoteCmdClientConfig();
     config.setIp(ip);
     config.setUserName(userName);
     config.setPassword(password);
     RemoteCmdClient client = new RemoteCmdClient(config);
     //设置CPU占用比例
     int percent = 70;
     //设置持续时间
     int delayMinutes = 3;
     //CPU占用率拉高
     CpuUtils.adjustCpuUsage(client, percent, delayMinutes);
 }

中断服务器网络

本示例将模拟服务器网络中断 30s 的环境,具体操作步骤如下:

public static void main(String[] args) {
      //远程服务器IP
      String ip = "";
      //远程服务器用户名
      String userName = "";
      //远程服务器登录密码
      String password = "";
      RemoteCmdClientConfig config = new RemoteCmdClientConfig();
      config.setIp(ip);
      config.setUserName(userName);
      config.setPassword(password);
      RemoteCmdClient client = new RemoteCmdClient(config);
      //设置blockIP,即需要设置网络中断的服务器 IP。
      String blockIP = "";
      //持续时间s
      int delaySecond = 30;
      //网络中断
      NetAccessUtils.blockIPInput(client, blockIP, delaySecond);
  }

延时服务器网络

本示例将模拟服务器网络延时为 1000 ms 且持续 10s 的测试环境,具体操作步骤如下:

public static void main(String[] args) {
      //远程服务器IP
      String ip = "";
      //远程服务器用户名
      String userName = "";
      //远程服务器登录密码
      String password = "";
      RemoteCmdClientConfig config = new RemoteCmdClientConfig();
      config.setIp(ip);
      config.setUserName(userName);
      config.setPassword(password);
      RemoteCmdClient client = new RemoteCmdClient(config);
      //延时时间 ms
      int delayTime = 1000;
      //持续时间s
      int delaySecond = 10;
      //网络延时
      NetTrafficUtils.setNetworkDelay(client, delayTime, delaySecond);
  }