diff options
| author | Michael Klishin <mklishin@pivotal.io> | 2017-05-27 00:45:47 +0300 |
|---|---|---|
| committer | Michael Klishin <mklishin@pivotal.io> | 2017-05-27 00:45:47 +0300 |
| commit | 8bf65e52fc2e5a6242197f8364d2ec0dd3b60145 (patch) | |
| tree | b8ee00e4d3d59376eff9fdd1a0171e5f1b260d7d /src | |
| parent | 91fc8a18225ae72e104d9fab2578f7fe56bf8e96 (diff) | |
| parent | 9084194f327275b268e64e5f9928eb1e91a50219 (diff) | |
| download | rabbitmq-server-git-8bf65e52fc2e5a6242197f8364d2ec0dd3b60145.tar.gz | |
Merge branch 'stable'
Diffstat (limited to 'src')
| -rw-r--r-- | src/vm_memory_monitor.erl | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/src/vm_memory_monitor.erl b/src/vm_memory_monitor.erl index 9b401748e0..ba324d649e 100644 --- a/src/vm_memory_monitor.erl +++ b/src/vm_memory_monitor.erl @@ -81,13 +81,20 @@ %%---------------------------------------------------------------------------- get_total_memory() -> - try - get_total_memory(os:type()) - catch _:Error -> - rabbit_log:warning( - "Failed to get total system memory: ~n~p~n~p~n", - [Error, erlang:get_stacktrace()]), - unknown + case application:get_env(rabbit, total_memory_available_override_value) of + {ok, Value} -> + case rabbit_resource_monitor_misc:parse_information_unit(Value) of + {ok, ParsedTotal} -> + ParsedTotal; + {error, parse_error} -> + rabbit_log:warning( + "The override value for the total memmory available is " + "not a valid value: ~p, getting total from the system.~n", + [Value]), + get_total_memory_from_os() + end; + undefined -> + get_total_memory_from_os() end. get_vm_limit() -> get_vm_limit(os:type()). @@ -179,6 +186,15 @@ code_change(_OldVsn, State, _Extra) -> %%---------------------------------------------------------------------------- %% Server Internals %%---------------------------------------------------------------------------- +get_total_memory_from_os() -> + try + get_total_memory(os:type()) + catch _:Error -> + rabbit_log:warning( + "Failed to get total system memory: ~n~p~n~p~n", + [Error, erlang:get_stacktrace()]), + unknown + end. set_mem_limits(State, MemLimit) -> case erlang:system_info(wordsize) of |
