Awesome
Nebulex.Adapters.Horde
This implements a Nebulex adapter using Horde to store in-memory distributed data, you can check Horde page to see more details about its advantages.
This is a alternative to Nebulex Partitioned Cache
that uses :pg
under the hood.
NOTE: This adapter only supports Nebulex v2.0.0 onwards.
Overall features
- In-memory data storage in GenServer, distributed relying on Horde with CRDT.
- Every cache entry is a process supervised by Horde.
- This trades off with memory, every cache entry will also have the memory from the process itself with it.
- Its good when you know that you are not going to have a huge amount of entries.
- Expired entries are lost forever (process termination).
- Processes hand-off with graceful shutdown thanks to Horde.
- Configurable primary storage adapter.
- Support for transactions via Erlang global name registration facility.
- Stats support rely on the primary storage adapter.
Installation
Add nebulex_adapters_horde
to your list of dependencies in mix.exs
:
def deps do
[
{:nebulex_adapters_horde, "~> 1.0.1"}
]
end
Usage
You can define a Cache using this adapter as follows:
defmodule MyApp.Cache do
use Nebulex.Cache,
otp_app: :my_app,
adapter: Nebulex.Adapters.Horde,
horde: [
members: :auto,
process_redistribution: :passive
# any other Horde options ...
]
end
And in the application.ex
file:
def start(_type, _args) do
children = [
{MyApp.Cache, []},
]
...
end
Roadmap
- Cache Entry
- Common Nebulex Functions
- Iteraction with
Horde.DynamicSupervisor
andHorde.Registry
- Every Cache Entry is a process supervised by
Horde
- Transaction and correct transaction locks
- Stats fallback to Primary Cache (it will only export stats inserted through Local, this is only useful when using Multilevel)
- Distributed Stats Mechanism
Testing
Since Nebulex.Adapters.Horde
uses the support modules and shared tests
from Nebulex
and by default its test folder is not included in the Hex
dependency, the following steps are required for running the tests.
First of all, make sure you set the environment variable NEBULEX_PATH
to nebulex
:
export NEBULEX_PATH=nebulex
Second, make sure you fetch :nebulex
dependency directly from GtiHub
by running:
mix nbx.setup
Third, fetch deps:
mix deps.get
Finally, you can run the tests:
mix test
Running Benchmarks
Everything related to benchmark is in benchmarks/benchmarks.exs
, to run it you can use: MIX_ENV=test mix run benchmarks/benchmarks.exs
The details of benchmark of Horde
against Partitioned
adapter is in benchmarks/details.txt
Notes
This is heavily influenced by nebulex_adapters_cache by cabol, I've used a lot of the testing method implemented there