Skip to content

Releases: parca-dev/parca

v0.22.0

09 Aug 12:24
Compare
Choose a tag to compare

What's Changed

Highlights

Changes

  • Filter profiling data using binary name by @yomete in #4554

Features

  • pkg/parca: Add forwarder mode by @brancz in #4531
  • ui: Add a timezone parameter to Parca context by @yomete in #4549
  • Retrieve sources from debuginfod server if debuginfo is from there by @brancz in #4602
  • Add support for Iceberg storage by @thorfour in #4650
  • ui: Change the compare button to be within the navbar by @yomete in #4784
  • ui: CRA -> Vite migration by @manojVivek in #4796
  • Introduce Apache Arrow-based ingestion protocol by @brancz in #4834

Enhancements

  • pkg: change trace print to debug log by @alxric in #4310
  • ui: Extendable flamegraph color profiles by @manojVivek in #4328
  • ui: Pnpm migration by @manojVivek in #4566
  • pkg/config: support seconds in pprof configuration by @alperkokmen in #4623
  • Use new Filter API to filter by function by @yomete in #4714
  • ui: Make handling of selections more robust by @brancz in #4725
  • normalizer: build arrow records directly without converting to parquet by @asubiotto in #4740
  • pkg/normalizer: Support named profiles by @brancz in #4760
  • pkg/normalizer: Sanitize all labels by @brancz in #4844
  • ui: Configuring step count as a derivative of screen size such that there are 10px gap per point by @manojVivek in #4847
  • Only request debuginfod with GNU build ID by @brancz in #4865
  • ui/packages/profile: Always sent the profile type along for Labels and Values by @metalmatze in #4863
  • Add build ID type to initiate upload request by @brancz in #4866
  • ui: URL State hook revamp by @manojVivek in #4864
  • area/ui: Temporarily hide the callgraph viz by @yomete in #4927
  • ui: Add text showing the timeframe of the query by @brancz in #4955

Bug Fixes

  • pkg/query: Don't filter unsymbolized when no function name is provided by @brancz in #4333
  • Update index to not use /* anymore for Go 1.22 by @metalmatze in #4404
  • ui: Fixed the bug that was resetting the profile selection state on page load by @manojVivek in #4476
  • pkg/parcacol: Correctly handle delta non cpu/ns profiles by @metalmatze in #4592
  • ui: Profile info section fixed by @manojVivek in #4629
  • ui: Fixed the build id truncation on tooltip by @manojVivek in #4653
  • pkg/query: Fix panic when diffing two profiles by @yomete in #4681
  • pkg/query: Only fetch mappings from profileB when in compare mode by @yomete in #4713
  • pkg/debuginfo: Loosen build ID validation by @brancz in #4741
  • fix(snap): store profiles in SNAP_COMMON by default by @jnsgruk in #4797
  • don't perform a merge query when report type is metadata only by @thorfour in #4886
  • ui: Auto query redirect fix when there is pathPrefix set by @manojVivek in #4948
  • pkg/symbol: Fix DWARF panic by @brancz in #4947
  • ui: Encoding the values before setting it to the URL by @manojVivek in #4962

New Contributors

Full Changelog: v0.21.0...v0.22.0

v0.21.0

27 Feb 16:50
089e780
Compare
Choose a tag to compare

What's Changed

Highlights

The UI has seen many improvements in this release, including a redesign of the time range picker,
a new feature to highlight similar stacks when hovering on a node,
and the replacement of loading spinners with skeleton placeholders.
Now, the UI also displays CPU cores per second for sample count profiles to make them comparable with different underlying profiling durations.

Changes

Features

Enhancements

  • ui: Allow copying system name if different from the function name by @brancz in #4022
  • ui: Fixing useURLState to be SSR proof by @manojVivek in #4027
  • Add additional snap configuration options by @morphis in #4069
  • ui: Minor auto suggestion improvements to eliminate pauses in query builder by @manojVivek in #4155
  • refactor: separate Normalizer and Ingester by @Cluas in #4170
  • ui: Unify date time format in Metrics graph by @yomete in #4247
  • ui: Added support for now keyword in time range selector by @manojVivek in #4248
  • pkg: Move the uiFS out of the server package by @metalmatze in #4105
  • ui: Considering diffs less than 0.1% as no change in flamegraph compare mode by @manojVivek in #4297
  • proto: Added http path annotations for debuginfo endpoints by @manojVivek in #4301
  • ui: Add week and year to presets in DateTimeRangePicker by @metalmatze in #4303
  • ui: Migrating from babel to swc for js transpiling by @manojVivek in #4315
  • Improve filter profile data by @thorfour in #4313
  • Add new flag to use an on-disk index by @thorfour in #4323

Bug Fixes

New Contributors

Full Changelog: v0.20.0...v0.21.0

v0.20.0

20 Oct 11:23
d2b3947
Compare
Choose a tag to compare

What's Changed

This release features tons of performance improvements, this is the lowest CPU and memory usage Parca server yet!

Highlights:

  • All interactions that previously required holding shift and interacting, are now replaced with right-clicks.
  • Icicle graphs can now be grouped by binary, filename and address in addition to previously only function name and labels.
  • Display function inlining information in the UI.

Changes

Apache Arrow is now the one and only format to read and write data in the internal storage.

Features

  • UI: Show whether function was inlined in hover bubble. by @brancz in #3896
  • UI: Allow aggregating icicle graph by binary, filename and address by @brancz in #3897
  • UI: Add visibility dropdown for columns by @metalmatze in #3780
  • scrape: Support parsing executable info out of pprof comments by @brancz in #3911

Enhancements

Bug fixes

  • query: Fix nil panic when building flat flamegraph by @brancz in #3892
  • ingestion: Ensure base address normalizaton only happens once by @brancz in #3903

Full Changelog: v0.19.0...v0.20.0

v0.19.0

21 Sep 14:57
302a192
Compare
Choose a tag to compare

v0.19.0 is the biggest and most exciting Parca release yet!

Highlights:

  • A complete re-design of the UI. ✨
  • All APIs are now served in Apache Arrow format. This completes the migration to being fully Apache Arrow based for ingestion and querying. 📈
  • Queries can now filter by arbitrary profile labels (trace ID, customer ID, or whatever else is added to profiling data). 🔍
  • Icicle graphs can now group by profile labels (such as thread ID or name). 📊

Aside from that, there are countless performance improvements and bug fixes.

Full Changelog:

Read more

v0.18.0

14 Jun 16:36
Compare
Choose a tag to compare

We're happy to release Parca v0.18.0!

This release comes packed with performance improvements, enhancements and so many fixes to the UI and CI!

  • Parca will now automatically use the system settings for light or dark themes.
  • gRPC Prometheus histograms are now exposed as native histograms giving them a much higher fidelity.
  • If running with a custom path prefix, all API endpoints will now be served under this prefix.

Happy profiling!

What's Changed

Enhancements

Bug fixes

Docker images

docker pull ghcr.io/parca-dev/parca:v0.18.0

Thanks!

Join our Discord server;
Follow us on Twitter;
Read the documentation.

New Contributors

Full Changelog: v0.17.0...v0.18.0

v0.17.0

29 Mar 08:58
v0.17.0
fa84a70
Compare
Choose a tag to compare

Features

  • EXPERIMENTAL arrow ingestion: create the arrow record from the sorted buffer by @thorfour in #2696
  • introduce deterministic metrics graph coloring by @monicawoj in #2826

Enhancements

Fixes

Full Changelog: v0.16.0...v0.17.0

Docker images

docker pull ghcr.io/parca-dev/parca:v0.17.0

Thanks!

Join our Discord server;
Follow us on Twitter;
Read the documentation.

v0.16.2

07 Mar 04:13
9cd53ec
Compare
Choose a tag to compare

Bug fixes

  • ui: User preferences icon and release notes viewer bugfix by @manojVivek in #2694

Full Changelog: v0.16.1...v0.16.2

v0.16.1

02 Mar 13:21
501bf54
Compare
Choose a tag to compare

Bug fixes

  • Fix link sharing and updating queries when changing time selection. @monicawoj in #2677

Full Changelog: v0.16.0...v0.16.1

v0.16.0

01 Mar 14:48
8123277
Compare
Choose a tag to compare

This release is a major milestone for the Parca project. We have removed the Merge button, as we are now comfortable with the performance of these queries being run by default when querying data. We now felt comfortable after months of work improving the performance of the storage.

Many many more awesome changes, below is a more exhaustive changelog.

Happy profiling!

What's Changed

Enhancements

  • Various components: Merges with Step Duration instead of Single Profile requests. @monicawoj and @metalmatze in #2516
  • api: Skip returning data to the frontend that will never be possible to be visualized in an Icicle graph. @manojVivek in #2299
  • api: Ensure pprof download is compatible with Go PGO. @brancz in #2520
  • ui: Add Github Star button and Release Notes Viewer which show the release notes within Parca UI. @manojVivek in #2366
  • ui: Persist even more of what is on-screen into the URL for shareability. @monicawoj in #2115
  • ui: Visualization Panels drag n drop feature. @monicawoj in #2403
  • ui: Binary based colored stack. @manojVivek in #2381
  • ui: Icicle graph - Hiding the mappingPrefix when there is only one mapping. @manojVivek in #2564
  • ui: Added screen with info when no data is received on the server. @manojVivek in #2567
  • ui: Add a tooltip when a MetricsGraph tooltip label is hovered over. @yomete in #2571
  • ui: Flamegraph tooltip improvements by @manojVivek in #2600
  • storage: Improve performance through schema changes. @asubiotto in #2391
  • symbolization: Add priority for symtab search and support plt symbol. @zdyj3170101136 in #2491
  • symbolization: Use symbols liner either HasSymtab or HasDynsym. @zdyj3170101136 in #2637

Bug fixes

  • ui: Fix displaying targets error and handle scraper-only mode correctly. @brancz in #2325
  • ui: Fix false positive Profile has no samples message in visualisations. @yomete in #2511
  • ui: Add a button to clear search string after clicking on a table row. @yomete in #2501
  • ui: Fixed the unnecessary re-rendering of flamegraph. @manojVivek in #2644
  • scrape: Handle HTTP redirects with specific error correctly. @ShubhamPalriwala in #2270
  • debuginfo: Fix instantiation of upstream debuginfod servers. @brancz in #2497
  • api: Translate empty "" matcher values to NULL. @metalmatze in #2616

New Contributors

Full Changelog: v0.15.0...v0.16.0

v0.15.0

20 Dec 10:51
287d49e
Compare
Choose a tag to compare

Breaking changes

This release has a breaking change in the debuginfo upload protocol, which is only compatible with Parca Agent v0.11.0 or higher (more details in #2248).

Changelog

Changes

Enhancements

  • ft: Filter by function functionality added to ProfileView by @manojVivek in #2062 #2156 #2236
  • pkg/debuginfo: Always attempt to reupload corrupted files by @brancz in #2101
  • pkg/debuginfo: Better errors in uploads by @brancz in #2113
  • pkg/scrape: Allow profiles to be treated as already normalized by @brancz in #2124
  • ui: UI user preferences by @manojVivek in #2158
  • ui: Suggestion list scrolls with active suggestion by @manojVivek in #2164
  • ui: Query data caching on the Frontend by @manojVivek in #2173
  • ui: Add a reset zoom button for the call graph by @yomete in #2249
  • ui: Flamegraph tooltip performance fix by @manojVivek in #2265
  • pkg/debuginfo: Allow uploads to be done via signed URLs by @brancz in #2248
  • grafana-pugin: Grafana plugin updated to use flamegraph_table report by @manojVivek in #2271
  • pkg/debuginfo: Validate size of upload is set by @brancz in #2282
  • ui: Using a virtual table component to improve TopTable performance and compare option added to benchmark runner by @manojVivek in #2225
  • parcacol: change stacktrace column to plain encoding by @asubiotto in #2283
  • Use scrape interval correctly by @fabxc in #2220
  • pkg/symbolizer: Improved caching in symbolization by @brancz in #2311
  • ui/packages/app/web: Hide agent or scraper target sections if non-existing by @metalmatze in #2227
  • pkg/profilestore: Reduce allocs in writeSeries by @marselester in #2176
  • pkg/parcacol: Improve sparse labelset ingestion by @metalmatze in #2201
  • pkg/parcacol: Group all profiles of a write request into one buffer by @brancz in #2202
  • symbolizer: Log addresses in hexadecimal by @javierhonduco in #2226
  • querydiff: perform the profile selections concurrently by @thorfour in #2242

Bug fixes

New Contributors

Full Changelog: v0.14.0...v0.15.0