Skip to content

Commit

Permalink
Merge pull request #9418 from zhongwencool/global-gc-interval
Browse files Browse the repository at this point in the history
feat: support node.global_gc_interval=disabled
  • Loading branch information
zhongwencool committed Nov 28, 2022
2 parents 8235a09 + 65a1f90 commit 7c04808
Show file tree
Hide file tree
Showing 8 changed files with 17 additions and 9 deletions.
4 changes: 2 additions & 2 deletions apps/emqx_conf/i18n/emqx_conf_schema.conf
Expand Up @@ -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"
Expand Down
2 changes: 1 addition & 1 deletion apps/emqx_conf/src/emqx_conf.app.src
@@ -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]},
Expand Down
2 changes: 1 addition & 1 deletion apps/emqx_conf/src/emqx_conf_schema.erl
Expand Up @@ -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",
Expand Down
6 changes: 5 additions & 1 deletion apps/emqx_conf/test/emqx_global_gc_SUITE.erl
Expand Up @@ -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.
6 changes: 3 additions & 3 deletions apps/emqx_machine/src/emqx_global_gc.erl
Expand Up @@ -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.
Expand Down
2 changes: 1 addition & 1 deletion apps/emqx_machine/src/emqx_machine.app.src
Expand Up @@ -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]},
Expand Down
2 changes: 2 additions & 0 deletions changes/v5.0.12-en.md
Expand Up @@ -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).
Expand Down
2 changes: 2 additions & 0 deletions changes/v5.0.12-zh.md
Expand Up @@ -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)
Expand Down

0 comments on commit 7c04808

Please sign in to comment.