惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

Datadog | The Monitor blog

Reduce CVE noise with OpenVEX assessments in Datadog How we made a SQL query optimization agent 59% more accurate using autoresearch and LLM Observability How to audit and clean up monitors effectively Diagnose slow PostgreSQL queries faster with explain plan correlation Explore Datadog metrics with Natural Language Queries Toto 2.0: Time series forecasting enters the scaling era Simplify micro-frontend observability with Datadog RUM Attribute AI costs across providers with Datadog Cloud Cost Management Diagnose and resolve database performance issues faster with Database Investigator Datadog for Government achieves FedRAMP® High certification Analyze cloud costs with flexible spreadsheets in Datadog Sheets Inside Datadog’s AI Research Lab: Meet two PhD candidates behind Toto Connect triage and investigation in a single workflow with Datadog Cloud SIEM This Month in Datadog - April 2026 Monitor and optimize Supabase query performance with Datadog Database Monitoring Add dynamically updating context to logs with Reference Tables and Observability Pipelines Introducing ARFBench: A time series question-answering benchmark based on real incidents The product signal latency gap slowing your growth Test network paths with TCP, UDP, and ICMP in Datadog Turn developer feedback into operational insight with Datadog Forms and Sheets How to investigate cloud credential compromise with Bits AI Security Analyst Evaluate, optimize, and secure your Google Cloud AI stack with Datadog Bringing observability data hosting to the UK on AWS Identify and fix code issues faster with Datadog’s Azure DevOps Source Code integration Steganography at scale: Embedding share URLs in Datadog widget screenshots Every team should be A/B testing Centralize observability management with Datadog Governance Console Spotting CI/CD misconfigurations before the bots do: Securing GitHub Actions with Datadog IaC Security Route OTel data from AI apps to ClickHouse and Datadog using Observability Pipelines Manage service tracing across hosts with Single Step Instrumentation rules Offline evaluation for AI agents: Best practices Detect runtime threats in Python Lambda functions with Datadog AAP Introducing our open source AI-native SAST Instrument and monitor Boomi integration flows with OpenTelemetry and Datadog Not all index scans are equal: How we cut query latency by over 99% Platform engineering metrics: What to measure and what to ignore Integrate Recorded Future threat intelligence with Datadog Cloud SIEM CI/CD security: threat modeling using a MITRE-style threat matrix CI/CD security: How to secure your GitHub ecosystem Ingress NGINX is EOL: A practical guide for migrating to Kubernetes Gateway API How we built a real-world evaluation platform for autonomous SRE agents at scale Operating agentic AI with Amazon Bedrock AgentCore and Datadog LLM Observability: Lessons from NTT DATA Introducing the Datadog Code Security MCP Capture and analyze custom heatmaps in Session Replay Understand session replays faster with AI summaries and smart chapters Monitor ClickHouse query performance with Datadog Database Monitoring How we designed empathetic alert sounds for on-call engineers Search and act across Datadog to resolve issues faster with Bits Assistant Measure the business impact of every product change with Datadog Experiments Analyzing round trip query latency Configuring JavaScript caches for better performance Introducing Bits AI Dev Agent for Code Security Datadog achieves ISO 42001 certification for responsible AI Monitor Nutanix clusters, hosts, and VMs with Datadog Monitor Juniper Mist in Datadog A new Host Map for modern infrastructure When upserts don't update but still write: Debugging Postgres performance at scale Annotate traces to improve LLM quality with Datadog LLM Observability What's new in Cloud SIEM: AI-powered investigations, enhanced threat intelligence, and scalable security operations Explore Kubernetes with native OpenTelemetry data Monitor Oracle Fusion Cloud Applications with Datadog Announcing the Datadog Terraform provider v4.0.0 Scaling Kubernetes workloads on custom metrics How to design cloud environments for AI-powered threat analysis Monitor Aruba Central in Datadog How we centralize and remediate risks with Datadog Case Management Accelerate incident response with Datadog and ServiceNow Monitor your application and network load balancer logs Understanding Karpenter architecture for Kubernetes autoscaling Tools for collecting metrics and logs from Karpenter Monitor Karpenter with Datadog What your product data is actually saying Key metrics for monitoring Karpenter Securing Datadog's platform in the AI age: The role of observability data Closing the verification loop: Observability-driven harnesses for building with agents When an AI agent came knocking: Catching malicious contributions in Datadog’s open source repos Closing the verification loop, Part 2: Fully autonomous optimization Four ways engineering teams use the Datadog MCP Server to power AI agents Approaching your observability migration with the right mindset Meet the new Bits AI SRE: Deeper reasoning, twice as fast Designing MCP tools for agents: Lessons from building Datadog's MCP server Key learnings from the 2026 State of DevSecOps study Use plain English to query your multi-cloud infrastructure in Resource Catalog Simplifying troubleshooting across the user journey with Datadog Synthetic Monitoring Protect your OCI resources with Datadog Cloud Security This Month in Datadog - February 2026 Fine-tune Toto for turbocharged forecasts Amazon EC2 security: How misconfigured and public AMIs expand your cloud attack surface Enable end-to-end visibility into your Java apps with a single command Measure and improve mobile app startup performance with Datadog RUM Evaluating our AI Guard application to improve quality and control cost Identify untested code across every level of your codebase Make use of guardrail metrics and stop babysitting your releases Monitor Versa Networks SD-WAN performance in Datadog How we reduced the size of our Agent Go binaries by up to 77% Improve performance and reliability with APM Recommendations Remediate transitive vulnerabilities faster with Datadog Software Composition Analysis Generate audit-ready vulnerability and compliance reports with Datadog Sheets Monitor Fortinet FortiManager performance in Datadog Improve test coverage across codebases with Datadog Code Coverage
Why continuous profiling is the fourth pillar of observability
2025-07-25 · via Datadog | The Monitor blog
Marcus Hirt

Marcus Hirt

JC Mackin

JC Mackin

Developers have long used profilers to diagnose performance bottlenecks and improve the efficiency of their code. But a modern version of profiling, continuous profiling, is quietly redefining what profiling is and what it can do. By running nonstop in production with very low overhead, continuous profilers give teams always-on visibility into how their code behaves in the real world. And when that data is correlated with other telemetry signals like metrics, traces, and logs, it helps teams troubleshoot complex issues, speed up investigations, and improve release velocity.

In this post, we’ll explore how profiling has evolved from a rarely used troubleshooting technique into a core observability practice. We’ll discuss how, in using Datadog Continuous Profiler internally, we’re seeing new benefits from profiling that are echoed in reports from many of our customers. Along the way, we’ll make the case that continuous profiling is becoming a fourth pillar of observability, an essential tool that helps teams quickly build, maintain, and iterate on applications in today’s competitive environment.

Continuous profiling != traditional profiling

Most people understand software profiling to refer to the practice of using tools to examine how software behaves during execution. While many associate it specifically with CPU profiling, it encompasses a range of techniques (including various forms of memory and off-CPU profiling) that are designed to solve different performance problems.

Continuous profiling is a powerful new type of profiling that is not as well understood, and that is sometimes even misunderstood. To understand why it represents such an important development for profiling, it helps to look at the history of profiling to see how it was originally used.

The challenges of early profiling

In the early days of computing, profiling was a niche activity, undertaken only when a serious performance issue arose. With profilers like gprof (GNU profiler, introduced in 1982), profiling was a manual process that required you to compile a special, instrumented version of your binary. However, the overhead of these profilers was significant. Every function was instrumented to generate information about the number of invocations (how many times each function was called) and to record the caller/callee relationship (which functions called which).

Later, with sampling profiling tools like VTune, profiling was still very much a manual undertaking. You would typically run your application locally with the profiling application, start the profiler, collect data, and then stop the profiler to analyze the collected data. For engineering teams, the common way to use these profilers was to run the instrumented binary in a testing environment and gather as much profiling data as possible.

But applications don’t behave in testing environments like they do in production environments, especially when the execution is slowed down by old-school, resource-intensive instrumentation in the code. As a result, if performance issues were experienced in production, developers would have to devote unusually extensive efforts to reproduce them in an accurate way in testing and capture them with a profiler.

The challenging nature of early profiling helps explain why it came to be seen as a high-effort, high-overhead, and low-reward task. And while that outdated perception might still linger, profiling has now evolved into something fundamentally new.

Profiling in the modern software landscape

Fast-forward to the present day, and the software landscape has changed dramatically. The software we analyze today is typically not a monolithic program running on a single machine. Most applications now consist of many services communicating with each other, sometimes developed by different teams or even different companies. With CI/CD, releases often happen several times a week or even several times per day instead of a few times a year.

Though CPU utilization is still a concern, it is no longer the only profiling information developers track to improve software performance. What can be even more important is to understand why the program is not scheduled on CPU. This can be determined through techniques like wall clock profiling, and by gaining visibility into the usage of limited resources, such as locks and monitors, stop-the world operations (e.g., garbage collection–related activity, the global interpreter lock), and other execution model constructs that vary based on the programming model, language, and runtime. Surfacing all this data makes profiling useful for detailed problem resolution, not just for improving CPU efficiency.

The advantages of continuous profiling

Enter today’s continuous profiling. Continuous profilers continuously collect information about the runtime behavior of your application, even if it is composed of thousands of microservices. Because they run in production, continuous profilers provide more accurate data about the actual behavior of the application being profiled. What’s more, profiling data is always available when application behavior changes. There’s no longer a need to painstakingly reproduce the issue; you simply need to look at the profiling data to diagnose what has gone wrong.

Because they are running all the time, a design requirement of continuous profilers is that their overhead needs to be low. Low overhead means that continuous profilers can be used alongside other monitoring tools, which is a crucial advantage. Unlike traditional code profilers, continuous profilers capture telemetry data that can be combined and correlated with any metrics, traces, and logs that are captured in production at the same time. The result is a more comprehensive view into real-world application performance, which ultimately broadens the range of problems that teams can solve.

As an example of how profiling data can be combined with other telemetry data, the following screenshot shows an APM trace for a specific request (GET /correlate) being associated with profiling data from Continuous Profiler. The tracing data for the GET /correlate request is shown at the top, and the profiling data associated with the trace is shown at the bottom.

Datadog APM trace for GET /correlate linked with continuous profiling data. The top portion shows a trace timeline with spans across services, while the bottom highlights Java monitor blocking across several threads in the flame graph view. A tooltip displays stack trace details showing thread contention during the request.

Let’s say you are trying to diagnose latency within the trace. The correlation with profiling data lets you direct your investigation to the exact runtime behavior during that request. In this case, it reveals that threads were blocked on monitors (marked by the prevalence of yellow). This correlation of traces with profiling data provides a clear pathway to move your investigation from high-level APM signals to low-level performance diagnostics as you try to resolve the latency issue. Without continuous profiling’s low overhead, it would not be possible to have all this different telemetry data available or, as a result, transition your investigation from traces to profiles so easily.

After the example above showing how profiles can shed light on traces, below you can see an example showing how trace data can shed light on profiling data. In this case, to the right of the flame graph, you can see the CPU time for the product-recommendation service broken down and aggregated by endpoint (connecting the profiling data back to trace data). You could use this information as a launching point, for example, to study the CPU characteristics for any particular endpoint by filtering on the data for that endpoint.

Profiling data for the product-recommendation service, showing average CPU time aggregated by endpoint.

These are just two examples of how providing the context of distributed operations to the profiling samples can help make the profiling data much more useful and easier to reason about.

Industry adoption and standardization

Because of its obvious advantages and low resource demands, continuous profiling is becoming mainstream. One sign of its growing importance is seen in developments within OpenTelemetry. Traditionally, OpenTelemetry has had three main signals for observability: metrics, logs, and tracing. But significantly, it now also has a signal group for continuous profiling and is working to make continuous profiling the fourth signal. Datadog is actively assisting OpenTelemetry in this effort by helping establish standardized formats for profiling data and contributing to improvements in profiler implementations.

Continuous profiling at Datadog

At Datadog, we have had great success implementing continuous profiling across our own services, including saving $17.5 million in annually recurring costs by using Continuous Profiler, along with other Datadog tools. Thanks to continuous profiling, we also save millions of dollars every year by detecting performance regressions early and improving the way our services execute. We also save time, along with development costs, by resolving problems quickly. This helps us move faster and provide a better customer experience.

Thousands of Datadog customers that are running Continuous Profiler in their production systems have had similar successes. One interesting fact is that many of them aren’t even listing cost savings or performance gains as the main reasons for using continuous profiling. The benefits we’re hearing about from them, in fact, are typically about release velocity and mean time to resolution (MTTR).

Continuous profiling is a core component of observability

Thanks to continuous profiling, profiling has evolved into a key observability practice, used alongside metrics, logs, and traces to help teams understand and improve application behavior. Importantly, as the quantity of AI-generated code in services increases, tools like Continuous Profiler will play an increasingly vital role in helping teams gain visibility into the runtime behavior of their production code. Moving forward, we believe the growing importance of profiling alongside traditional observability practices will lead to more efficient and better-designed systems that will be easier than ever to maintain.

To learn more, see our Continuous Profiler documentation. If you’re not yet a Datadog customer, sign up for a 14-day free trial.