ferros VS pprof

Compare ferros vs pprof and see what are their differences.

ferros

A Rust-based userland which also adds compile-time assurances to seL4 development. (by auxoncorp)

pprof

pprof is a tool for visualization and analysis of profiling data (by google)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
ferros pprof
9 12
102 7,483
1.0% 1.6%
0.0 7.9
9 months ago 3 days ago
Rust Go
Apache License 2.0 Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

ferros

Posts with mentions or reviews of ferros. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-07-25.
  • Unix-like OS in Rust inspired by xv6-riscv
    7 projects | news.ycombinator.com | 25 Jul 2023
    My company, https://www.auxon.io. We created https://github.com/auxoncorp/ferros originally to enable a customer project early in the company's life cycle.

    Some time later we had another customer interested in using it and having us add some features to it (e.g. some device drivers and a persistence layer utilizing https://docs.rs/tickv/latest/tickv/). It was becoming a massive pain in the neck to work out source code sharing agreements with them, so we decided to just open source it.

    There are quite a number of things that we would do differently if we had to build it again, and at some point will likely do that work to revise it. The biggest one of those is root task synthesis. The other is to build and bring in facilities for running tasks that are compiled to WASM.

  • Writing an OS in Rust to run on RISC-V
    8 projects | news.ycombinator.com | 1 Mar 2023
    When we add WASM support to https://github.com/auxoncorp/ferros it'll sorta be like what you're angling at there in your description.
  • My Fear of Commitment to the First CPU Core
    2 projects | news.ycombinator.com | 12 Feb 2023
    We've built things on seL4 (https://github.com/auxoncorp/ferros). We like to joke that it's the most perfect piece of nearly featureless software ever made.

    There's... A LOT... of work to do before seL4 is going to be anywhere near usability parity with something like Linux, unfortunately.

    Rather than make a general purpose OS, we decided to use it more like a unikernel or "library OS" where you're trying to make a well defined kind of "appliance" image to deploy to specific hardware rather than try to fake being a POSIX-y shaped OS.

  • FerrOS: Rust-y unikernels on seL4
    2 projects | /r/rust | 9 Nov 2022
    For what it's worth, here's FerrOS's repo as well as the underlying selfe repo
  • Tokio Console
    11 projects | news.ycombinator.com | 17 Dec 2021
    That's basically what we did with https://github.com/auxoncorp/ferros, Bundle Rust programs together as tasks to run atop the formally verified seL4 microkernel.
  • Hubris – An OS from Oxide Computer
    7 projects | news.ycombinator.com | 30 Nov 2021
    We also built a Rust framework called FerrOS (https://github.com/auxoncorp/ferros) atop the formally-verified seL4 microkernel.

    It has a similar set of usage idioms to Hubris it looks like in terms of trying to setup as much as possible ahead of time to assemble what's kind of an application specific operating system where everything your use case needs is assembled at build-time as a bunch of communicating tasks running on seL4.

    We recently added a concise little persistence interface that pulls in TicKV (https://docs.tockos.org/tickv/index.html) from the Tock project you referenced above, and some provisions are being added for some more dynamic task handling based on some asks from an automotive OEM.

  • Genode – Sculpt Operating System 21.10
    1 project | news.ycombinator.com | 16 Oct 2021
    We built a thing to enable combining Rust applications together to be hosted on the seL4 microkernel. The developer experience is more akin to that of something like an RTOS where the OS and your applications are built and deployed together. The whole premise of it is decidedly non-POSIX-like. The current point is for assembling software for use-case-specific/appliance computing, not general purpose computing. (https://github.com/auxoncorp/ferros)

    We're looking both for contributors and also actively hiring for a couple engineering positions for the above and for or mainline product.

  • OSv Unikernel – Optimizing Guest OS to Run Stateless and Serverless Apps
    4 projects | news.ycombinator.com | 9 Oct 2021
    I tried and failed to bring unikernels to my former work when I was at Visa. Specifically, LING.

    At my current company, Auxon, we recently open sourced[1] some work we did a couple years back which is more or less an attempt at the basic foundations for blending the seL4 microkernel with fairly normal no_std Rust application development and assembling them all together to make a purpose built OS/application to deploy directly to hardware or within a VM. We have some work to do to keep building it up as a foundation for broader use, but we're looking into partnering with the seL4 Foundation (now under the Linux Foundation) to iterate on it further with some of our other mutual partners. The developer experience is much closer to that of developing for an RTOS than it is like typical general purpose computing development.

    I'm of course biased, but I think there's a lot of room to innovate in the space of use case specific software stacks where the domain and constraints are well understood and too many degrees of freedom are actually a hindrance and a liability, not an advantage.

    [1] https://github.com/auxoncorp/ferros

  • Open sourced: Easier builds and stronger types for seL4 with Rust
    2 projects | /r/rust | 10 Sep 2021
    On top of that is ferros (no relation to to ferrous-systems), a higher-level userland of unreasonably strong types for compile-time resource tracking. No more discovering you need more memory, or capability slots or IPC rights at runtime. These types help you fit the right seL4 screw to the right seL4 screwdriver.

pprof

Posts with mentions or reviews of pprof. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-01-25.
  • Profiling Caddy
    1 project | news.ycombinator.com | 15 Feb 2024
    The pprof format is not tied to Go. From my understanding, it's used within Google across multiple languages. The format is defined in the pprof repository[0], and the visualization tool is source-language agnostic. I've seen libraries in numerous languages (e.g. Python, Java) to publish profiles in pprof format. This is an indicator the pprof format has become de-facto. Grafana Pyroscope[1] is a tool that's capable of parsing the pprof format, agnostic to the source programming language, and has instructions for Go, Java, Python, Ruby, node.js, Rust, and .NET.

    My understanding is that you're searching for a combination of the profiles, metrics, and tracing. Caddy supports all 3.

    [0] https://github.com/google/pprof/blob/main/doc/README.md

    [1] https://grafana.com/docs/pyroscope/latest/

    metrics and tracing need to be manually enabled (for now, perhaps)

  • Why So Slow? Using Profilers to Pinpoint the Reasons of Performance Degradation
    2 projects | dev.to | 25 Jan 2023
    Because we couldn't identify the issue using the results we got from Callgrind, we reached for another profiler, gperftools. It's a sampling profiler and therefor it has a smaller impact on the application's performance in exchange for less accurate call statistics. After filtering out the unimportant parts and visualizing the rest with pprof, it was evident that something strange was happening with the send function. It took only 71 milliseconds with the previous implementation and more than 900 milliseconds with the new implementation of our Bolt server. It was very suspicious, but based on Callgrind, its cost was almost the same as before. We were confused as the two results seemed to conflict with each other.
  • Improving the performance of your code starting with Go
    4 projects | dev.to | 9 Dec 2022
    github.com - google/pprof
  • Proposal to Support Timestamps and Labels in Pprof Events
    1 project | news.ycombinator.com | 24 Oct 2022
  • A Generic Approach to Troubleshooting
    4 projects | dev.to | 20 Sep 2022
    The application performances in a specific code path (e.g. gdb, pprof, …).
  • Does rust have a visual analysis tool for memory and performance like pprof of golang?
    11 projects | /r/rust | 14 May 2022
    pprof is https://github.com/google/pprof, it's a very useful tool in golang , and really really really convenient
  • pprof - tool for visualization and analysis of profiling data
    1 project | /r/github_trends | 2 May 2022
  • Tokio Console
    11 projects | news.ycombinator.com | 17 Dec 2021
    Go also has pretty good out of the box profiling (pprof[0]) and third-party runtime debugging (delv[1]) that can be used both remotely and local.

    These tools also have decent editor integration and can be use hand in hand:

    https://blog.jetbrains.com/go/2019/04/03/profiling-go-applic...

    https://blog.jetbrains.com/go/2020/03/03/how-to-find-gorouti...

    [0] https://github.com/google/pprof

    [1] https://github.com/go-delve/delve

  • Cats and Clouds – There Are No Pillars in Observability with Yoshi Yamaguchi
    8 projects | dev.to | 3 Nov 2021
    And what we do in Google Cloud is that we still use the pprof. But it's a kind of forked version of the pprof because the visualization part is totally different. So we give that tool as the Cloud Profiler. So that is the product name. And then, the difference between the pprof and a Cloud Profiler is that Cloud Profiler provides the agent library for each famous programming language such as Java, Python, Node.js, and Go. And then what you need to do is to just write 5 to 10 lines of code in a new application. That launches the profile agent in your application as a subsidiary thread of the main thread. And then, that thread periodically collects the profile data of the application and then sends that data back to Google Cloud and the Cloud Profiler.
  • Is there a way I can visualize all the function calls made while running the project(C++) in a graphical way?
    8 projects | /r/cpp | 15 Jun 2021
    gprftools (https://github.com/gperftools/gperftools) can be easily plugged in using LD_PRELOAD and signal, and has nice go implemented visualization tool https://github.com/google/pprof.

What are some alternatives?

When comparing ferros and pprof you can also consider the following projects:

nanos - A kernel designed to run one and only one application in a virtualized environment

gperftools - Main gperftools repository

hubris - A lightweight, memory-protected, message-passing kernel for deeply embedded systems.

prometheus - The Prometheus monitoring system and time series database.

Trusted-CGI - Lightweight runner for lambda functions/apps in CGI like mode

jaeger - CNCF Jaeger, a Distributed Tracing Platform

rust - Empowering everyone to build reliable and efficient software.

tracy - Frame profiler

tracing - Application level tracing for Rust.

parca - Continuous profiling for analysis of CPU and memory usage, down to the line number and throughout time. Saving infrastructure cost, improving performance, and increasing reliability.

console - a debugger for async rust!

massif-visualizer - Visualizer for Valgrind Massif data files