This demo was made for my diploma project for the Faculty of Automation and Computers, Polytechnic University of Bucharest.
Unikernel is a virtualization method that encompasses all the positive aspects of other virtualization solutions, low memory consumption and speed of containers, but also the level of security that virtual machines offer through isolation.
Unikraft is a unikernel that creates an image of the application together with all its dependencies, in an executable, through an easy and fast process for the user, having a configuration mechanism. Measuring the performance of applications is becoming an increasingly important step, and Unikraft does not have a tool to measure any bottleneck that may occur inside the application.
The objective of my thesis was to integrate a performance measurement utility for unikernels, Uniprof, with Unikraft and to display the data in a pretty format using Flame Graph. At this moment, you can measure the performance and you can see the possible bottlenecks for an application running on a Xen platform.
To generate stack traces and the flame graph, I use the script that I created which does the following:
- Start Unikraft application
- Start Uniprof to get stack traces
- Run nm to find symbol table
- Use symbolize to map addresses
- Run stack collapse to format stack trace for Flame Graph
- Generate Flame Graph representation
For this test you can see the source code in apps/app-test-1.
As you can see, we called each function 50.000, and in the flame graph they appear on the same level with rectangles of equal size.
Also, here I changed the color palette, but I got the same output.
Here we have two main functions (function_1 and function_2). From the first function we call function_3 50.000 times and from the second function we call function_4 50.000 times and function_5 100.000 times.
You can see that the rectangle for function_5 is 2 times larger than function_3 and function_4, and the rectangle for function_2 is 3 times larger than function_1, because it was in stack traces only for function_3, called by 50.000 compared to 200.000 calls in total.
For this test you can see the source code in apps/app-test-2.
To make these graphics I built the generateFlameGraph.sh script and you can use it with the following arguments for test application 1:
bash generateFlameGraph.sh -f 5 -t 120 \
-n app-test-1 \
-c /root/gmocanu/Uniprof-FlameGraph/apps/app-test-1/app-test-1.cfg \
-x /root/gmocanu/Uniprof-FlameGraph/apps/app-test-1/build/app-test-1_xen-x86_64.dbg
Also you can try help argument for more information:
bash generateFlameGraph.sh --help
Usage: generateFlameGraph.sh -f freq -t time -n domain -c path_to_conf -x path_to_exec
-f | --frequency : Frequency(Optional)
-t | --time : Time(Optional)
-n | --domain : Domain name(Mandatory)
-c | --conf : Path to configuration file(Mandatory)
-x | --exec : Path to executable(Mandatory)
-h | --help : Help argument
For more information about this project you can check out my documentation for my Diploma Project.