fastglobal VS nmoo

Compare fastglobal vs nmoo and see what are their differences.

fastglobal

Fast no copy globals for Elixir & Erlang. (by discord)

nmoo

An enhanced LambdaMOO-like MOO (by sid-code)
Nim
WorkOS - The modern identity platform for B2B SaaS
The APIs are flexible and easy-to-use, supporting authentication, user identity, and complex enterprise features like SSO and SCIM provisioning.
workos.com
featured
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
fastglobal nmoo
2 1
1,126 10
0.0% -
0.0 8.2
about 1 year ago 29 days ago
Elixir Nim
MIT License MIT License
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.

fastglobal

Posts with mentions or reviews of fastglobal. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-09-23.
  • Show HN: I rewrote the 1990's LambdaMOO server from scratch
    8 projects | news.ycombinator.com | 23 Sep 2023
    > State has to be owned by a process - who owns the state of the world? ... Keep in mind, when data is passed "between" processes it is deep copied.

    The Erlang runtime has other stateful things besides processes, and manipulating data within these and/or getting a handle on data in these places doesn't necessarily involve copying.

    • ETS tables, which hold state privately to themselves (with copying in/out) in a similar way to how processes do. If you manipulate data inside ETS tables by "sending compute to data" (think Redis INCR) rather than by "sending data to compute", then no copying happens.

    • "Globals" in the form of data compiled into read-only versioned modules loaded into the modules table and available to be referenced from any/all active processes, only copied if the module gets unloaded before the process dies. (Originally this was just a design pattern — https://github.com/discord/fastglobal — but it eventually became its own runtime feature in Erlang 22, https://www.erlang.org/doc/man/persistent_term).

    • Large binaries (anything over 64 bytes) aren't allocated in an actor's memory arena, but instead are allocated in a special global-per-node binaries heap, and then ref-counted, where each actor-process holds one reference to each large-binary it's using, and then each read-only slice of that binary, in turn holds a reference to the per-actor reference handle for the binary. One clever technique for sharing a large "database" of data between many actors, is to store the data encoded in a large binary in an encoding that is efficient to partwise-decode; and have the "lookup" operation just parse+decode the appropriate data out of the binary. (This is how erlang:module_info/2 used to work — the global modules-table itself holding a set of references to the loaded modules' binaries, which module_info would then parse metadata out of on demand.)

  • Issue
    1 project | /r/Pionex | 14 Dec 2021

nmoo

Posts with mentions or reviews of nmoo. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-09-23.
  • Show HN: I rewrote the 1990's LambdaMOO server from scratch
    8 projects | news.ycombinator.com | 23 Sep 2023
    I love seeing projects like this! I have one too, but it completely throws away compatibility and is very simplistic. I opted for a lisp-like language instead of a lua-like language (https://github.com/sid-code/nmoo but don't look at the code, it's embarrassing).

    I have some questions:

      - Does each verb call create a whole new world state that it mutates, and later commits to the database? That's the impression I get from reading the code. Does this come with a lot of overhead?

What are some alternatives?

When comparing fastglobal and nmoo you can also consider the following projects:

mudmixer - MUDMixer is an add-on for MUD clients that enriches the gaming experience with connection mixing functionality and a variety of other features.

mica

tinyfugue - TinyFugue - Rebirth

wireguardex - Configure WireGuard® interfaces in Elixir using Rust NIFs.

rmoo - A major mode for interacting with MOOs.

ex_hash_ring - A fast consistent hash ring implementation in Elixir.

moor - A rewrite of the classic LambdaMOO server; but in Rust and on a modern tech stack

EtaMOO - A new implementation of the LambdaMOO server