Skip to content

Latest commit

 

History

History
102 lines (84 loc) · 4.08 KB

README.md

File metadata and controls

102 lines (84 loc) · 4.08 KB

Graal Prophet Utils

This repository is a version of the prophet-utils repository, adapted to the GraalVM static analysis of microservice applications project.

For the high-level overview and instructions how to perform the analysis, please go to Graal MVP.

Running MicroGraal

  • Build graal
    • git clone https://github.com/cloudhubs/graal.git
    • Install mx
    • Install jdk with jvmci and set JAVA_HOME
      • cd graal/substratevm && mx fetch-jdk
    • Compile graal
      • cd graal/substratevm && mx build
      • export GRAAL_PROPHET_HOME=$(mx -p graal/substratevm graalvm-home)
  • Build graal-utils
    • Install Maven
    • Compile project
      • cd graal-prophet-utils && mvn clean package -DskipTests=true -X
  • Analyze a project
    • Clone microservice project to be analyzed (e.g. train-ticket)
    • Create microservice metadata file
    • Compile microservice project
      • cd train-ticket && mvn install -DskipTests=true
    • Unzip jars
      • Example:
        • Set env. MS_ROOT
        • Run the help script ./microservice-setup.sh config/trainticket-microservice.json (requires jq json parser tool)
    • Run the analysis
      • $JAVA_HOME/bin/java -jar target/graal-prophet-utils-0.0.8.jar ./config/trainticket-microservices.json
    • Output will be in output_SYSTEMNAME

Note:

  • This program only currently accepts Java microservices on Spark
  • Program only runs on Linux machines
  • This program depends on cloudhubs/graal repository

Setup:

  1. Install or build your every microservice

  2. Run microservice-setup.sh

    • You will need to configure the 'directory' variable to contain the path to your system for your machine. It currently contains all train-ticket microservices, but for the bash script to unzip all microservice jars for another project, you must replace the current list with one of all their names.
    • This script unzips all of the project jars to expose the BOOT-INF directory. It also deletes the SnakeYAML jar from the projects target if it exists.
  3. ProphetUtils first argument is: the path to the microservices JSON. The format of the microservices JSON is as follows

    •   {
            "systemName": "systemnameHere",
            "microservices":[
                {
                "baseDir": "/home/person/work/microservice_system/microservice_root/",
                "basePackage": "edu.baylor.ecs.cms",
                "microserviceName": "cms"
            },
            {
                "baseDir": "/home/person/work/microservice_system/microservice_root/",
                "basePackage": "edu.baylor.ems",
                "microserviceName": "ems"
            },
            .
            .
            . etc
            ]
        }
      
    • Other options are dependant on the version below

TWO VERSIONS

main branch

  1. This is a generalized approach and implementation for all microservice systems
  2. Uses Levenshtein distance and approximates the distance for service dependancy linking
  3. OPTIONS: <percent_match>
    • percent_match: integer value, similarity matching threshold

Austin-adding-new-params-for-requests branch

  1. This branch is for analysis of train ticket
  2. This one is not recommended for generalized approach as it parses patterns specific to train ticket
    • Parses destination microservice from URI and or host name depending on version of train ticket
  3. Uses partial signature matching for the URI, body param, and HTTP method
  4. OPTIONS: <is_train_ticket> <percent_match>
    • is_train_ticket: specify option if it is train ticket or not
    • percent_match: integer value, similarity matching threshold

NOTE: Both approaches parse by body param and HTTP method

FUTURE IMPROVEMENT RECOMMENDATIONS:

  • Partial signature matching for the URI could be implemented for the generalized approach in the main branch instead of approximating with distance
  • Partial signature matching is defined as only matching hard coded parts for the URI and ignoring path params