Rails Is Good Enough
Onur Ozer discusses the lasting significance of Ruby on Rails, highlighting its use by startups and large companies, its productivity, and its ability to simplify web application development over two decades.
Read original articleOnur Ozer reflects on the enduring relevance of Ruby on Rails, noting its continued use by both startups and large tech companies two decades after its inception. He recounts his personal experience of learning programming later in life and choosing Rails for building a SaaS application, contrasting it with his initial attempt using React, which he found overly complex due to the fragmented JavaScript ecosystem. Ozer appreciates Rails for its monolithic structure, which provides essential features out of the box, allowing developers to focus on building their business rather than solving unnecessary problems. He highlights Rails' maturity, as it has established conventions for important tasks like authentication, making it easier for developers to collaborate and onboard new team members. Ozer also emphasizes the productivity of Rails, suggesting that it attracts developers who prioritize building over debating technology. He concludes that while Rails has a steep learning curve and can be frustrating at times, it is sufficient for the majority of modern web applications, celebrating its ability to simplify the technical aspects of business development. Ozer marks the 20th anniversary of Rails, acknowledging its battle-tested nature and the peace of mind it offers developers.
Related
JRuby funding at Red Hat stopped – call for sponsors
JRuby gains independence post Red Hat sponsorship end. Updates 9.3.15.0 and 9.4.8.0 released, with plans for JRuby 10 supporting Ruby 3.4 and Rails 7.1. Community urged for GitHub sponsorship or commercial support for continued development.
Why We Build Simple Software
Simplicity in software development, likened to a Toyota Corolla's reliability, is crucial. Emphasizing straightforward tools and reducing complexity enhances reliability. Prioritizing simplicity over unnecessary features offers better value and reliability.
Mastering Ruby Code Navigation: Ruby LSP Enhancements in the First Half of 2024
In early 2024, the Ruby Language Server Protocol improved code navigation, enhancing features like hover and go-to-definition. Rails addon updates facilitate navigation in models, views, and controllers, with ongoing experimental features.
Top Ruby Companies Around the World
The article highlights 51 public companies using Ruby, with a combined market cap of $361 billion and revenue of $66.7 billion, including notable firms like Airbnb and Shopify.
DHH: Make Software Simple Again
David Heinemeier Hansson emphasized simplicity in software development at the We Are Developers World Congress, criticizing profit-driven complexity and advocating for one-time purchases over SaaS, while promoting Ruby on Rails.
This is possibly the absolute worst combination of factors possible. The learning curve makes it bad to ramp up with, and the magic makes it bad in the long term.
It's a framework that wants to be used for monoliths, and tooling is essential to manage the complexity of large monoliths, but you're stuck with a language that's extremely hostile to tooling, using patterns that make it even more hostile to tooling.
So, really, what you're left with is a framework that's only actually good for the early-mid stages of a project, and only if you're an existing Rails user who doesn't have to pay the ramp up price.
It just feels so much more productive than anything else I’ve ever worked with.
So what are your options... Sorbet? Does this feel like Ruby?
sig do
params(x: Integer)
.returns(String)
end
How about RBS? Does writing the equivalent of header files for every function and class feel like Ruby?So unfortunately I'm no longer an evangelist or practitioner.
I love Rails. Every investment I've made in learning it has yielded returns for years. Everytime I learn a new JS framework, its obsolete two years later.
ActiveRecord has many limitations when trying to get efficiency from infrastructure (either because you've grown/scaled, or to minimize costs while growing). The main problem is with model instances having actions attached to them, you have to make and jump through hoops to batch the individual callbacks.
Working on a performance improvement project, we discovered that doing ModelClass.new (not doing any I/O and even if that class is empty with no callbacks) is about 400x slower than doing MyClass.new for a plain Ruby class that holds a table's attributes. Processing a thousand of these things in a request with a handful of associated models for each can eat up 100s of ms before doing anything useful.
And even dropping down to using ModelClass.insert_all(array_of_hashes) which bypasses ActiveRecord model instantiation is still slow in the way it generates the SQL before executing it.
You can scale throughput by having many webapp servers (at the cost/constraint of many database connections) but that doesn't help latency per request.
Working at a Rails and MySQL shop is about as close to guaranteed employment as I know as there's always tough problems to solve as a company continues to expand in scope and scale, and always new devs doing their best but still introducing patterns that don't age well.
That's absolutely meant as a compliment!
However, convention over configuration means quicker delivery for small(er) teams, but more discussions once more opinionated developers join.
1. Code is loaded automatically and globally. I’ve had weird bugs caused by someone creating a function with the same name in a completely different file.
2. The module system is strange. Why do my file names and class names need to match? Why can’t i just import the files i want like other languages?
3. Includes (aka mixins) are a bad idea. See below.
4. Many of the language features are designed to hide how code works. Quite often i wonder to myself “where does this variable/function come from?” #1 is also a good example of this.
5. Coming from a typed language, the lack of types makes me feel naked and more prone to screw something up.
6. The strange and elitist opinions of ruby fanboys. Sorry but code terseness is not a panacea and “unless” is terrible. It seems like code readability and understandability are less important to this crowd.
Related
JRuby funding at Red Hat stopped – call for sponsors
JRuby gains independence post Red Hat sponsorship end. Updates 9.3.15.0 and 9.4.8.0 released, with plans for JRuby 10 supporting Ruby 3.4 and Rails 7.1. Community urged for GitHub sponsorship or commercial support for continued development.
Why We Build Simple Software
Simplicity in software development, likened to a Toyota Corolla's reliability, is crucial. Emphasizing straightforward tools and reducing complexity enhances reliability. Prioritizing simplicity over unnecessary features offers better value and reliability.
Mastering Ruby Code Navigation: Ruby LSP Enhancements in the First Half of 2024
In early 2024, the Ruby Language Server Protocol improved code navigation, enhancing features like hover and go-to-definition. Rails addon updates facilitate navigation in models, views, and controllers, with ongoing experimental features.
Top Ruby Companies Around the World
The article highlights 51 public companies using Ruby, with a combined market cap of $361 billion and revenue of $66.7 billion, including notable firms like Airbnb and Shopify.
DHH: Make Software Simple Again
David Heinemeier Hansson emphasized simplicity in software development at the We Are Developers World Congress, criticizing profit-driven complexity and advocating for one-time purchases over SaaS, while promoting Ruby on Rails.