Merge pull request #9418 from zhongwencool/global-gc-interval

feat: support node.global_gc_interval=disabled
This commit is contained in:
zhongwencool 2022-11-28 10:07:27 +08:00 committed by GitHub
commit 7c048081b1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 17 additions and 9 deletions

View File

@ -471,8 +471,8 @@ significant: later configuration files override the previous ones.
node_global_gc_interval {
desc {
en: """Periodic garbage collection interval."""
zh: """系统调优参数,设置节点运行多久强制进行一次全局垃圾回收。"""
en: """Periodic garbage collection interval. Set to <code>disabled</code> to have it disabled."""
zh: """系统调优参数,设置节点运行多久强制进行一次全局垃圾回收。禁用设置为 <code>disabled</code>。"""
}
label {
en: "Global GC Interval"

View File

@ -1,6 +1,6 @@
{application, emqx_conf, [
{description, "EMQX configuration management"},
{vsn, "0.1.6"},
{vsn, "0.1.7"},
{registered, []},
{mod, {emqx_conf_app, []}},
{applications, [kernel, stdlib]},

View File

@ -468,7 +468,7 @@ fields("node") ->
)},
{"global_gc_interval",
sc(
emqx_schema:duration(),
hoconsc:union([disabled, emqx_schema:duration()]),
#{
mapping => "emqx_machine.global_gc_interval",
default => "15m",

View File

@ -29,4 +29,8 @@ t_run_gc(_) ->
ok = timer:sleep(1500),
{ok, MilliSecs} = emqx_global_gc:run(),
ct:print("Global GC: ~w(ms)~n", [MilliSecs]),
emqx_global_gc:stop().
emqx_global_gc:stop(),
ok = emqx_config:put([node, global_gc_interval], disabled),
{ok, Pid} = emqx_global_gc:start_link(),
?assertMatch(#{timer := undefined}, sys:get_state(Pid)),
ok.

View File

@ -82,10 +82,10 @@ code_change(_OldVsn, State, _Extra) ->
%%--------------------------------------------------------------------
ensure_timer(State) ->
case application:get_env(emqx_machine, global_gc_interval) of
undefined ->
case application:get_env(emqx_machine, global_gc_interval, disabled) of
disabled ->
State;
{ok, Interval} ->
Interval when is_integer(Interval) ->
TRef = emqx_misc:start_timer(Interval, run),
State#{timer := TRef}
end.

View File

@ -3,7 +3,7 @@
{id, "emqx_machine"},
{description, "The EMQX Machine"},
% strict semver, bump manually!
{vsn, "0.1.0"},
{vsn, "0.1.1"},
{modules, []},
{registered, []},
{applications, [kernel, stdlib]},

View File

@ -2,6 +2,8 @@
## Enhancements
- Disable global garbage collection by `node.global_gc_interval = disabled` [#9418](https://github.com/emqx/emqx/pull/9418)。
- Improve the CLI to avoid waste atom table when typing erros [#9416](https://github.com/emqx/emqx/pull/9416).
- Start building MacOS packages for Apple Silicon hadrdware [#9423](https://github.com/emqx/emqx/pull/9423).

View File

@ -2,6 +2,8 @@
## 增强
- 通过 `node.global_gc_interval = disabled` 来禁用全局垃圾回收 [#9418](https://github.com/emqx/emqx/pull/9418)。
## 修复
- 优化命令行实现, 避免输入错误指令时, 产生不必要的原子表消耗 [#9416](https://github.com/emqx/emqx/pull/9416)。