conducting-memory-forensics-with-volatility
Performs memory forensics analysis using Volatility 3 to extract evidence of malware execution, process injection, network connections, and credential theft from RAM dumps captured during incident response. Covers memory acquisition, process analysis, DLL inspection, and malware detection. Activates for requests involving memory forensics, RAM analysis, Volatility framework, memory dump investigation, volatile evidence analysis, or live memory acquisition.
What this skill does
# Conducting Memory Forensics with Volatility ## When to Use - An endpoint has been contained during an active incident and volatile evidence must be preserved - EDR alerts suggest process injection or fileless malware that only exists in memory - Encryption keys need to be recovered from a ransomware-infected system before shutdown - Credential theft (Mimikatz, LSASS dumping) is suspected and evidence must be confirmed - A rootkit or kernel-level compromise is suspected and disk-based analysis is insufficient **Do not use** for analyzing disk images or file system artifacts; use disk forensics tools (Autopsy, FTK) for those tasks. ## Prerequisites - Memory acquisition tool deployed or available: WinPmem, Magnet RAM Capture, DumpIt, or AVML (Linux) - Volatility 3 installed with Python 3.8+ and required symbol tables - Sufficient storage for memory dumps (equal to system RAM size, typically 8-64 GB) - YARA rules for malware detection in memory (Florian Roth's signature-base, custom rules) - Reference baseline of normal processes and DLLs for the OS version being analyzed - Chain of custody documentation for evidence handling ## Workflow ### Step 1: Acquire Memory Image Capture RAM from the target system using a forensically sound method: **Windows (WinPmem):** ``` winpmem_mini_x64.exe output.raw ``` **Windows (Magnet RAM Capture):** ``` MagnetRAMCapture.exe # GUI-based, select output path, generates .raw file ``` **Windows (DumpIt):** ``` DumpIt.exe # Creates memory dump in current directory automatically ``` **Linux (AVML - Acquire Volatile Memory for Linux):** ``` ./avml output.lime ``` Document acquisition metadata: ``` Acquisition Record: ━━━━━━━━━━━━━━━━━ Target Host: WKSTN-042 RAM Size: 16 GB Dump File: WKSTN-042_20251115_1445.raw Dump Size: 16,843,612,160 bytes SHA-256: a4b3c2d1e5f6... Acquisition Tool: WinPmem 4.0 Acquired By: [Analyst Name] Timestamp: 2025-11-15T14:45:00Z ``` ### Step 2: Identify the Operating System and Profile Volatility 3 automatically identifies the OS, but verify: ```bash # Get system information vol -f WKSTN-042_20251115_1445.raw windows.info # Output includes: # OS: Windows 10 22H2 (Build 19045.3693) # Kernel Base: 0xf8066c200000 # DTB: 0x1aa000 # Symbols: ntkrnlmp.pdb ``` ### Step 3: Analyze Running Processes Examine the process tree for suspicious activity: ```bash # List all running processes vol -f memory.raw windows.pslist # Show process tree (parent-child relationships) vol -f memory.raw windows.pstree # Scan for hidden/unlinked processes (rootkit detection) vol -f memory.raw windows.psscan # Compare pslist vs psscan to find hidden processes # Processes in psscan but NOT in pslist may be hidden by rootkits ``` Key indicators of compromise in process analysis: - `svchost.exe` running without `-k` parameter or with wrong parent (should be `services.exe`) - `csrss.exe` or `lsass.exe` with abnormal parent process - Processes with misspelled names (`scvhost.exe`, `lssas.exe`) - Unusual processes spawned by `outlook.exe`, `winword.exe`, or `excel.exe` - Multiple instances of processes that should be singletons (`lsass.exe`, `smss.exe`) ### Step 4: Investigate Network Connections Extract active and recently closed network connections: ```bash # List all network connections vol -f memory.raw windows.netscan # Focus output fields: # Offset Proto LocalAddr LocalPort ForeignAddr ForeignPort State PID Owner # 0xe10... TCPv4 10.1.5.42 49721 185.220.101.42 443 ESTAB 3847 update.exe ``` Cross-reference suspicious connections with the process tree to identify C2 communications. Look for: - Connections to external IPs from unexpected processes - High port numbers connecting to port 443/80 from non-browser processes - Connections from `svchost.exe` or system processes to external IPs ### Step 5: Detect Process Injection and Malware Use malfind to identify injected code and memory-resident malware: ```bash # Detect injected code in processes vol -f memory.raw windows.malfind # Output shows: # PID Process Start End Tag Protection Hexdump/Disassembly # 3847 explorer.exe 0x2a10000 0x2a14000 VadS PAGE_EXECUTE_READWRITE # MZ header detected - injected PE # Dump suspicious process memory vol -f memory.raw windows.memmap --pid 3847 --dump # List DLLs loaded by a suspicious process vol -f memory.raw windows.dlllist --pid 3847 # Scan memory with YARA rules vol -f memory.raw windows.yarascan --yara-file malware_rules.yar ``` ### Step 6: Extract Credentials and Artifacts Recover sensitive data from memory: ```bash # Dump registry hives from memory (for password hash extraction) vol -f memory.raw windows.registry.hivelist vol -f memory.raw windows.hashdump # Extract command line history vol -f memory.raw windows.cmdline # List handles (files, registry keys, mutexes) vol -f memory.raw windows.handles --pid 3847 # Extract clipboard contents vol -f memory.raw windows.clipboard # Dump cached files from memory vol -f memory.raw windows.dumpfiles --pid 3847 ``` ### Step 7: Generate Forensic Report Compile findings into a structured analysis report documenting all evidence extracted from memory: - Process anomalies with PIDs, parent processes, and timestamps - Network connections with associated process context - Injected code regions with memory protection flags - Extracted IOCs (hashes, IPs, domains, mutexes, registry keys) - YARA rule matches with rule names and match offsets - Credential exposure (hashes found, accounts at risk) ## Key Concepts | Term | Definition | |------|------------| | **Volatile Evidence** | Data that exists only in RAM and is lost when a system is powered off; includes running processes, network connections, encryption keys | | **Process Injection** | Technique where malware inserts code into a legitimate process's memory space to evade detection (malfind detects this) | | **EPROCESS** | Windows kernel data structure representing a process; psscan searches for these structures even when unlinked from the active process list | | **VAD (Virtual Address Descriptor)** | Windows kernel structure tracking memory regions allocated to a process; malfind examines VADs for executable but non-file-backed regions | | **Symbol Tables** | OS-specific data structures that Volatility 3 uses to parse memory; downloaded automatically based on detected OS version | | **PAGE_EXECUTE_READWRITE** | Memory protection flag indicating a region is readable, writable, and executable; common indicator of injected malicious code | | **Memory-Resident Malware** | Malware that operates entirely in RAM without writing persistent files to disk, making it invisible to traditional disk-based antivirus | ## Tools & Systems - **Volatility 3**: Primary open-source memory forensics framework; Python 3 rewrite with automatic symbol resolution - **WinPmem / DumpIt / Magnet RAM Capture**: Memory acquisition tools for Windows systems - **AVML (Acquire Volatile Memory for Linux)**: Microsoft's open-source Linux memory acquisition tool - **YARA**: Pattern matching engine for scanning memory dumps against malware signatures and behavioral rules - **MemProcFS**: Memory analysis tool that presents memory as a virtual file system for intuitive browsing ## Common Scenarios ### Scenario: Detecting Cobalt Strike Beacon in Memory **Context**: EDR detects suspicious named pipe activity but cannot identify the source. A memory dump is acquired from the suspect endpoint for analysis. **Approach**: 1. Run `windows.pstree` to identify the process hierarchy and spot abnormal parent-child relationships 2. Run `windows.malfind` to detect injected code regions, particularly in `svchost.exe` or `rundll32.exe` 3. Dump the injected memory region and scan with YARA rules for Cobalt Strike beacon signatures 4. Run `windows.netscan` to identify C2 connections and correlate with the injected process PID 5. Extract the beaco
Related in General
modeling-omnistudio-epc-catalog
IncludedSalesforce Industries CME EPC product-modeling skill for Product2-based catalog creation. Use when creating EPC products, configuring product attributes, building offer bundles with Product Child Items, or reviewing EPC DataPack JSON metadata for product catalog changes. TRIGGER when: user creates or updates Product2 EPC records, AttributeAssignment payloads, AttributeMetadata/AttributeDefaultValues, Offer bundles, or ProductChildItem relationships. DO NOT TRIGGER when: designing OmniScripts/FlexCards/Integration Procedures (use building-omnistudio-omniscript, building-omnistudio-flexcard, or building-omnistudio-integration-procedure), implementing Apex business logic (use generating-apex), or troubleshooting deployment pipelines (use deploying-metadata).
relationship-science-coach
IncludedUse this skill for direct, practical adult relationship coaching: couples conflict, repair, trust, marriage, dating, flirting, attachment patterns, emotional connection, sex, desire differences, eroticism, kink negotiation, affection, love languages, breakups, and long-term passion. Draw on Gottman, EFT and Hold Me Tight, attachment science, modern sex research, Perel, Nagoski, Kerner, Schnarch, Love and Stosny, and flexible love-language tools. Be concrete and low-hedge. Redirect only for imminent danger, abuse, coercive control, minors, non-consent, self-harm, stalking, or medical/legal/psychiatric decisions.
building-sf-integrations
IncludedSalesforce integration architecture and runtime plumbing with 120-point scoring. Use this skill to set up Named Credentials, External Credentials, External Services, REST/SOAP callout patterns, Platform Events, and Change Data Capture. TRIGGER when: user sets up Named Credentials, External Services, REST/SOAP callouts, Platform Events, CDC, or touches .namedCredential-meta.xml files. DO NOT TRIGGER when: Connected App/OAuth config (use configuring-connected-apps), Apex-only logic (use generating-apex), or data import/export (use handling-sf-data).
venue-templates
IncludedAccess comprehensive LaTeX templates, formatting requirements, and submission guidelines for major scientific publication venues (Nature, Science, PLOS, IEEE, ACM), academic conferences (NeurIPS, ICML, CVPR, CHI), research posters, and grant proposals (NSF, NIH, DOE, DARPA). This skill should be used when preparing manuscripts for journal submission, conference papers, research posters, or grant proposals and need venue-specific formatting requirements and templates.
let-fate-decide
IncludedDraws the 12 Houses of the Zodiac Tarot spread to inject entropy into planning when prompts are vague, ambiguous, or casually delegated. Interprets the spread to guide next steps. Use when the user says 'let fate decide', 'YOLO', 'whatever', 'idk', or other nonchalant phrases, makes Yu-Gi-Oh references, or when you are about to arbitrarily pick between multiple reasonable approaches. Prefer over ask-questions-if-underspecified when the user's tone is casual or playful rather than precision-seeking.
net-ops
IncludedCross-platform network troubleshooting (Windows, macOS, Linux) via local or remote shell. Use for: DNS broken, can't resolve hostnames, nslookup/dig works but apps fail, NRPT, WFP, scutil, /etc/resolver, systemd-resolved, /etc/resolv.conf, NetworkManager, VPN DNS leak residue (ProtonVPN/Mullvad/WireGuard/AnyConnect), AV/firewall blocking DNS or DoH, Tailscale DNS interaction, intermittent connectivity, remote diagnostics over SSH.