Celluloid VS Akka

Compare Celluloid vs Akka and see what are their differences.

Celluloid

Actor-based concurrent object framework for Ruby (by celluloid)
Our great sponsors
  • Mergify - Updating dependencies is time-consuming.
  • InfluxDB - Collect and Analyze Billions of Data Points in Real Time
  • SonarLint - Clean code begins in your IDE with SonarLint
Celluloid Akka
2 32
3,884 12,787
-0.1% 0.4%
0.0 9.2
8 months ago 6 days ago
Ruby Scala
MIT License GNU General Public License v3.0 or later
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.

Celluloid

Posts with mentions or reviews of Celluloid. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-05-01.

Akka

Posts with mentions or reviews of Akka. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-05-08.
  • What are the current hot topics in type theory and static analysis?
    15 projects | /r/ProgrammingLanguages | 8 May 2023
    First-class distributed and multicore computing. Swift has first-class “actors” and “distributed” methods. Unison, Erlang, and Elixir are built with distributed being one of the #1 concerns. Though first-class is not super common and I don't really expect it to be because usually libraries are enough (e.g. Scala has Akka and is used WIDELY for distributed); whereas something like linear types and typed effects, you can't emulate in a library.
  • Anything close beam/otp for other languages?
    7 projects | /r/elixir | 7 Apr 2023
    Akka is a library that implements the actor model for JVM languages. Mainly in Scala, but you can use it in Java too, and maybe others. It doesn't feel as ergonomic as Elixir, but if Elixir is too "out there" for the decision makers in your case, this might be a friendlier alternative.
  • Carl Hewitt has died [pdf]
    5 projects | news.ycombinator.com | 6 Jan 2023
  • About Elixir and the microservices architecture
    3 projects | dev.to | 14 Dec 2022
    Note Akka, the Java & friends framework, is working with the actor model and have as main inspiration Erlang to mimic some features of the BEAM on top of the JVM.
  • Akka will no longer be Open Source
    2 projects | dev.to | 10 Sep 2022
    If I hear about Actor model, the first thing that comes to my mind is the popular Open Source library Akka.
    2 projects | dev.to | 10 Sep 2022
    Lightbend, the company owning Akka, recently shared a blog post signed by the CEO announcing a license change from Apache 2.0 to Business Source License 1.1, a proprietary license. You can already find it in this PR, merged a couple days ago.
  • Why We Are Changing the License for Akka
    2 projects | /r/scala | 7 Sep 2022
    Akka 2.6 is on the open source Apache license, that is unchanged (its not possible for Lightbend to change an existing license). Its only the new Akka 2.7 which has the BSL license, so as long as you don't upgrade you are fine. See https://github.com/akka/akka/pull/31561.
  • We Are Changing the License for Akka
    6 projects | news.ycombinator.com | 7 Sep 2022
    Here is Akka's dependency specification: https://github.com/akka/akka/blob/main/project/Dependencies....

    How many of these would have to opt for this source available approach before Akka would no longer be sustainable?

    6 projects | news.ycombinator.com | 7 Sep 2022
    I don't think that the Akka change is aimed at cloud providers. Akka is a toolkit for building highly concurrent, distributed, and resilient message-driven applications for Java and Scala [1]. It's not possible for AWS to offer their own "Akka service" the way they offered Redis through ElastiCache. This change affects companies that build software using Akka, many of which may not be software-focused. For example, here's a case study of an oilfield services company that uses Akka:

    https://www.lightbend.com/blog/low-cpu-utilization-fortune-5...

    [1] As found on https://akka.io/

    6 projects | news.ycombinator.com | 7 Sep 2022
    > So Amazon can take free code, sell it as a slickly-packaged service, and not need to share anything.

    Right, because they didn't change it. So what would there be to share anyway? 'Go to https://github.com/akka/akka'?

    > but it does mean that at least every user has access to the code to make their "Akka Service" as good as Amazon's.

    That code is meaningless. In this scenario we already established that Amazon is selling an unmodified copy of Akka as a Service (which, by the way, we will revisit this point later). And we already established, in your own words, that it's not about the code:

    > Their secret sauce is "we have a Borg Cube's worth of datacenters, so we can run the same code as you at a lower price".

    So what would the SSPL require, they publish their deployment scripts to their cloud datacentres? Like I said, that's meaningless.

    > "Akka Service"

    Final point. There's no such thing as an 'Akka Service'. Akka is a bunch of libraries. You link it into your JVM application. You don't run Akka separately, so by definition you can't offer it as a service (even if you're Amazon).

    Hence my suggestion of AGPL, and heck let's be generous, let's add a commercial use exception for businesses with less than $20m revenue, similar to what they're doing now with the BSL. Except with my suggestion the software would stay as strong copyleft, most businesses would be happy with the commercial use exception, and a few would have to pay their fair share.

    [1] https://news.ycombinator.com/item?id=32751373

What are some alternatives?

When comparing Celluloid and Akka you can also consider the following projects:

Vert.x - Vert.x is a tool-kit for building reactive applications on the JVM

Apache ZooKeeper - Apache ZooKeeper

Hazelcast - Hazelcast is a unified real-time data platform combining stream processing with a fast data store, allowing customers to act instantly on data-in-motion for real-time insights.

Hystrix - Hystrix is a latency and fault tolerance library designed to isolate points of access to remote systems, services and 3rd party libraries, stop cascading failure and enable resilience in complex distributed systems where failure is inevitable.

JGroups - The JGroups project

Concurrent Ruby - Modern concurrency tools including agents, futures, promises, thread pools, supervisors, and more. Inspired by Erlang, Clojure, Scala, Go, Java, JavaScript, and classic concurrency patterns.

Atomix - A Kubernetes toolkit for building distributed applications using cloud native principles

Lagom - Reactive Microservices for the JVM

EventMachine - EventMachine: fast, simple event-processing library for Ruby programs

Finagle - A fault tolerant, protocol-agnostic RPC system

Apache Storm - Apache Storm

Elixir - Elixir is a dynamic, functional language for building scalable and maintainable applications