This shows you the differences between two versions of the page.
| ep:labs:09:contents:tasks:ex1 [2021/10/09 12:41] cezar.craciunoiu | ep:labs:09:contents:tasks:ex1 [2023/10/21 14:45] (current) cezar.craciunoiu [01. [30p] RAM Monitoring] | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| - | ⠀ | + | ==== 01. [30p] RAM Monitoring ==== | 
| + | |||
| + | === RAM Investigation === | ||
| + | |||
| + | <note warning> | ||
| + | For this task we will use //**MemoryLeak.sln**// inside the //**Task-01**// folder. | ||
| + | </note> | ||
| + | |||
| + | :!: Using **Windows Performance Recorder**, run a program (//MemoryLeak.exe//) that allocates 1MB of memory every 100 milliseconds for a while and then stops. After the program stops, save the capture, open it in **Windows Performance Analyzer** and analyze the //Virtual Memory Snapshots// graph. What conclusion can you draw by looking at the memory usage of the process that is running our program? | ||
| + | |||
| + | :!: Using **VMMap**, inspect the memory spikes generated by running the same program. | ||
| + | |||
| + | <hidden> | ||
| + | * It can be noticed the steep line representing the increase of our process's memory usage. This leads to the conclusion that this process is the cause of the problem since all the other ones seem stable. | ||
| + | * So far, it was identified the process that causes problems. If this process is not written by you, you can check who is launching it. If you don't need it, you can deactivate it. If you need it, check if there are any updates to fix it. If there aren't any updates to fix the problem, you can try reporting the problem to the producer and hope they will fix it. | ||
| + | </hidden>⠀ | ||
| + | |||
| + | === RAM Cleaning === | ||
| + | |||
| + | <note warning> | ||
| + | For this task we will a tool called **RAMMap**. Download it from [[https://learn.microsoft.com/en-us/sysinternals/downloads/rammap | Microsoft]]. | ||
| + | </note> | ||
| + | |||
| + | Previously we identified that a given program allocated memory and did not free it, which started exhausting our resources. | ||
| + | If we still want to run that program, and we do not want to leave it running uninterrupted, we can try "cleaning" our RAM memory during its execution and hope that it helps. | ||
| + | Similar with Linux, where we drop caches, in Windows we can use a tool called **RAMMap** to inspect our memory in detail and free space in RAM. | ||
| + | |||
| + | |||
| + | :!: **After starting the program you should see something similar to the image below.** | ||
| + | |||
| + | {{ :ep:laboratoare:ep9_ex1_2.png?500 |}} | ||
| + | |||
| + | Let's now try to use RAMMap to free memory. | ||
| + | In the document you can add just two images, a before-after of running all empty routines. | ||
| + | Follow the steps below: | ||
| + | |||
| + | <note tip> | ||
| + | - Start RAMMap and position it on the left side of your screen | ||
| + | - Start Task Manager and position it on the right side of your screen | ||
| + | - Start several applications to get your RAM up to at least ~70% | ||
| + | - From the highlighted **Empty** tab, run every empty routine from top to bottom and inspect the total in Task Manager | ||
| + | </note> | ||
| + | |||
| + | <solution -hidden> | ||
| + | There is a chance some of them will not see differences after 1-2 runs. | ||
| + | Ask them to reopen the Memory-Heavy applications. | ||
| + | </solution> | ||
| + | |||
| + | :!: Sounds good, but what is a disadvantage of cleaning our RAM too often? Think about performance. | ||
| + | |||
| + | <solution -hidden> | ||
| + | Cleaning too often is similar to swapping all our unused data. | ||
| + | The system will have to fetch the data back from the disk. | ||
| + | </solution> | ||