Settings

Theme

Skylight, a Ruby profiler, free for open source applications

blog.skylight.io

120 points by chancancode 8 years ago · 33 comments

Reader

Dangeranger 8 years ago

The Rust language community has recently released a case study on Skylight and how Rust has been a competitive advantage for them.[0]

[0] https://www.rust-lang.org/pdfs/Rust-Tilde-Whitepaper.pdf

sergiotapia 8 years ago

If you're building a Rails app, you should be using Skylight. It gives you:

1. What's slow.

2. What's hit frequently.

This combined gives their "agony" ranking for you to fix problems that impact the most. In a very clean UI!

Terrific product. I wish I had Skylight for my Phoenix/Elixir stack.

wasd 8 years ago

Has anyone used New Relic and switched to Skylight or vice versa? Been looking for some comparisons [1].

[1]: https://twitter.com/sunnyrjuneja/status/951973556170215424

  • snowpalmer 8 years ago

    I could never find anything actionable in NewRelic. Seems like interesting data, but nothing I could optimize for. Skylight has identified slow performing areas where we've worked on and watched a downward trend.

    • desireco42 8 years ago

      Come on, I love Skylight, but really! Slowest queries, slowest requests, breakdown of every hit into details how much time everything took. It gives you too much actionable data if you ask me. You can constantly optimize some slow-pokes, I have to remind myself to not optimize pages that are not most used.

danmaz74 8 years ago

Note to the Skylight marketing team: I had never heard of your service in 10 years of using Rails, even if it was something that could very valuable to me. But if I open the homepage what I see is:

"DO THE ANSWER DANCE". Cool looking weirdo characters dancing. Generic charts-filled dashboard screenshots. Comparatively very small text saying "learn why your app is slow".

If you hadn't been vouched by this HN thread, I would have never read below the fold to learn that you allow profiling Rails apps.

drewda 8 years ago

I see that the logs and analysis will be open to everyone. I guess that's equivalent to using Travis, CircleCI, etc. on their free/open tiers. But API logs and analysis like Skylight performs can have much more unpredictable and sensitive info in them than test/build logs.

Does this mean that all private fields needs be scrubbed in-app, before Skylight? For example, a hosted OSS service that includes e-mail addresses or location data in API query strings.

FanaHOVA 8 years ago

Been using this on production for ~1 year now, no complaints so far!

avtar 8 years ago

“Skylight is a smart profiler for Ruby on Rails applications.”

  • wycats 8 years ago

    For clarity, we also support almost all Rack-based frameworks in Ruby (including Sinatra):

    https://www.skylight.io/support/advanced-setup

    We should probably update our copy to clarify this point in the prominent places where it isn't already clear.

  • kibwen 8 years ago

    As a further historical note that may interest HN users specifically, Skylight was the world's first production user of Rust (the Ruby gem they ship is written in it), dating back to well before Rust was even stable.

    • atarian 8 years ago

      Which is mainly because Yehuda Katz (Rust core member) works at Skylight.

      • steveklabnik 8 years ago

        To be clear about the chronology here, wycats made the decision to go with Rust, then did a lot of work in Rust, then became a core team member. He chose Rust because of his needs in Skylight, not because he was already invested in Rust.

        https://blog.rust-lang.org/2014/12/12/Core-Team.html

        > Yehuda Katz will be known to many in the Rust community for his work on the initial design and implementation of the Cargo project. He is also a co-founder of Tilde, which has been using Rust commercially in their Skylight product for quite some time

        • wycats 8 years ago

          For slightly more context, I wrote the first lines of Rust code for Skylight as a spike at the end of 2013, and joined the Rust core team more than a year later. :)

          I was largely inspired by a blog post in June 2013 by Patrick Walton: Removing Garbage Collection From the Rust Language[1]

          [1]: http://pcwalton.github.io/blog/2013/06/02/removing-garbage-c...

          • igravious 8 years ago

            Do you code in Ruby any more or is it all Rust these days? If you had to build a web app what would you use?

            • wycats 8 years ago

              I split my time between Ruby, JavaScript (mostly with TypeScript) and Rust, with occasional Java and devops work. Of those, JavaScript (with TypeScript) is my predominant language at the moment, but the mix changes pretty often.

              Skylight's stack is Rust and Ruby for the agent, Rails for the backend, Java for our data processing pipeline (essentially a custom data store) and Ember for virtually the entire front end. The graphs in Skylight are Ember components written in d3.

              I still think that Rails is a great choice for most web apps, since (to this day) it provides an extremely productive baseline for building account management and working with third-party integrations, which turn out to be a surprising percentage of the total code (and an even higher percentage of backend code changes) in even an ambitious project like Skylight.

              I also think it's reasonable to use something like Java or Rust for any heavy data-crunching your app might do, but I think people over-estimate which aspects of their application are truly performance and efficiency critical.

              • igravious 8 years ago

                Interesting. I see, thanks. From your list Ember stands out, was not expecting that. Rails and Ember integration looks painful? Maybe using Rails 5 and API mode is the way to go.

  • Cyberdog 8 years ago

    Darn, you beat me to it.

    Product blog operators, please see: https://news.ycombinator.com/item?id=16278142

  • dang 8 years ago

    Ok we've attempted to integrate that into the title.

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection