Fl4m3Ph03n1x

Fl4m3Ph03n1x

Get machine memory in elixir/erlang

Background

I have a module that saves data into an ETS without ever releasing it. Obviously, this is is a terrible idea. If you are not sure why, just ask yourself what happens when the machine no longer has memory to store data :smiley:

Solution

The obvious solution would be to periodically clean the data from the table, but I have orders to not do it, it has been decided another process in another application will do it. This process doesn’t exist yet and may never even exist, depending on who implements the other application.

Since I can’t rely on this, I decided to add a fallback mechanism. Dam’s have a fallback mechanism for excess water to flow, Nuclear Reactors have a mechanism for sea water to enter the reactors and cool them down (and then they release the heated, radioactive water back to the sea), so it only makes sense that if I want to build a reliable system, instead of waiting for the machine to crash catastrophically and restart, I should follow the example of such systems and decide what to do in case the system faces load it can’t cope with.

I decided I want to ditch requests upon a certain memory usage threshold. Let’s say, if the machine has 10GB of memory and BEAM is using 9GB already, I want to stop saving data into my ETS table.

Problem

To implement said solution, I made some research and found :memsup:

So, I rushed to open a iex terminal and test it out. But I can’t.

:memsup.start_link()
{:ok, #PID<0.142.0>}
iex(3)> [os_mon] memory supervisor port (memsup): Erlang has closed

16:17:12.618 [error] GenServer :memsup terminating
** (ArgumentError) argument error
    (stdlib) gen_event.erl:269: :gen_event.send/2
    memsup.erl:994: :memsup.set_alarm/2
    memsup.erl:375: :memsup.handle_info/2
    (stdlib) gen_server.erl:637: :gen_server.try_dispatch/4
    (stdlib) gen_server.erl:711: :gen_server.handle_msg/6
    (stdlib) proc_lib.erl:249: :proc_lib.init_p_do_apply/3
Last message: {:collected_sys, {7173283840, 8235118592}}
State: {:state, {:unix, :linux}, true, :undefined, :undefined, false, 60000, 30000, 0.8, 0.05, #PID<0.143.0>, #Reference<0.2483620304.3371171843.48667>, :undefined, [:reg], []}
** (EXIT from #PID<0.136.0>) shell process exited with reason: an exception was raised:
    ** (ArgumentError) argument error
        (stdlib) gen_event.erl:269: :gen_event.send/2
        memsup.erl:994: :memsup.set_alarm/2
        memsup.erl:375: :memsup.handle_info/2
        (stdlib) gen_server.erl:637: :gen_server.try_dispatch/4
        (stdlib) gen_server.erl:711: :gen_server.handle_msg/6
        (stdlib) proc_lib.erl:249: :proc_lib.init_p_do_apply/3

I get this cryptic error when trying to start_link the process so I can use it. What am I doing wrong?

Extra

I know that comparing BEAM’s total memory usage against the machine’s memory usage is not perfect, processes or atoms could be taking 99% of the used memory and I would still punish the ets tables. However, I still think this would make sense, since if that is the problem, I still don’t want my ETS tables to save anything until the issue is solved.

Marked As Solved

josevalim

josevalim

Creator of Elixir

You shouldn’t start it directly. You should start the :os_mon application which will start it for you. Generally speaking, always make sure to start an application before invoking any of its modules:

iex(2)> Application.ensure_all_started(:os_mon)
{:ok, [:sasl, :os_mon]}
iex(3)> :memsup.get_system_memory_data
[
  total_memory: 12652220416,
  free_memory: 23302144,
  system_total_memory: 12652220416
]

Also Liked

Fl4m3Ph03n1x

Fl4m3Ph03n1x

So I need to add :os_mon to:

def application do
    [
      extra_applications: [:logger, :runtime_tools, :os_mon],
      mod: {MyApp.Application, []}
    ]
end

In the mix.exs file, right ?

josevalim

josevalim

Creator of Elixir

Yes!!!

Fl4m3Ph03n1x

Fl4m3Ph03n1x

Thanks !

Where Next?

Popular in Questions Top

JorisKok
I have a server on AWS, and was running a load test using artillery. When looking at the Phoenix dashboard I see the Ports going to 100% ...
New
gshaw
What is the idiomatic way of matching for not nil in Elixir? E.g., First way: defp halt_if_not_signed_in(conn, signed_in_account) when...
New
beno
I will often find my self writing things similar to: case some_value do nil -&gt; something() "" -&gt; something() _ -&gt; somethi...
New
New
RisingFromAshes
I’ve read in another post that it may be possible with a router helper - but I couldn’t find an appropriate one, and tbh, I’m still just ...
New
fayddelight
I tried installing elixir 1.11.2 erlang 23.3.4 via asdf in my zsh shell. Enabled the versions locally and globally. When I list them ...
New
SoCreat
i’m a new one to elixir which editor can i use vs code? or atom? Thanks! :smiley:
New
srinivasu
How to handle excepions in elixir? Suppose i have A, B, C ,D, E modules. and each module has get() function. A.get() method will call t...
New
romenigld
I am trying to run a deploy with docker and I successfully runned with this command: docker build -t romenigld/blog-prod . but when I t...
New
vonH
In asking this question I am more interested about the expressiveness of the language itself and less concerned about the availability of...
New

Other popular topics Top

TunkShif
This post is an instruction guide to help you setup your Neovim for Elixir development from scratch. It includes general information on h...
274 41539 114
New
JorisKok
I have a server on AWS, and was running a load test using artillery. When looking at the Phoenix dashboard I see the Ports going to 100% ...
New
lessless
I believe there are people here who are dealing with CSV files import on the daily basis, and since Excel is a really popular tool there ...
New
ovidiubadita
Hey all, I discovered Elixir and I love it. I always wanted to learn a functional programming and I intended to go for Haskell, but afte...
New
stefanluptak
Hello everybody, usually, I use a 29" ultra-wide monitor for VSCode which can easily accomodate explorer (files panel) + file with code ...
New
jay1
Why is it that the mnesia database isn’t the most preferred database for use in Elixir/Phoenix?
New
saif
Hello everyone, Long time lurker first time poster here. I’ve recently begun working on Elixir full-time again! :raised_hands: It’s been...
New
KronicDeth
Elixir plugin for JetBrain’s IntelliJ Platform (including Rubymine) This is a plugin that adds support for Elixir to JetBrains IntelliJ...
289 36128 110
New
Qqwy
Update: How to use the Blogs &amp; Podcasts section You can post links to your blog posts or podcasts either in one of the Official Blog...
3271 126479 1222
New
dogweather
I wrote this comment on r/haskell, and it’s not popular there. :wink: But I think I’m on to something… Haskell reminds me of Java, and e...
New

We're in Beta

About us Mission Statement