Merge pull request #7463 from thalesmg/mria-shard-transport
feat: allow customizing per-shard transaction log transport
This commit is contained in:
commit
59d5478d4e
|
@ -319,8 +319,8 @@ db {
|
||||||
##
|
##
|
||||||
## @doc db.backend
|
## @doc db.backend
|
||||||
## ValueType: mnesia | rlog
|
## ValueType: mnesia | rlog
|
||||||
## Default: mnesia
|
## Default: rlog
|
||||||
backend = mnesia
|
backend = rlog
|
||||||
|
|
||||||
## RLOG role
|
## RLOG role
|
||||||
##
|
##
|
||||||
|
|
|
@ -475,6 +475,28 @@ In sync mode the core node waits for an ack from the replicant nodes before send
|
||||||
transaction log entry.
|
transaction log entry.
|
||||||
"""
|
"""
|
||||||
})}
|
})}
|
||||||
|
, {"default_shard_transport",
|
||||||
|
sc(hoconsc:enum([gen_rpc, distr]),
|
||||||
|
#{ mapping => "mria.shard_transport"
|
||||||
|
, default => gen_rpc
|
||||||
|
, desc =>
|
||||||
|
"Defines the default transport for pushing transaction logs.<br/>"
|
||||||
|
"This may be overridden on a per-shard basis in <code>db.shard_transports</code>."
|
||||||
|
"<code>gen_rpc</code> uses the <code>gen_rpc</code> library, "
|
||||||
|
"<code>distr</code> uses the Erlang distribution.<br/>"
|
||||||
|
})}
|
||||||
|
, {"shard_transports",
|
||||||
|
sc(map(shard, hoconsc:enum([gen_rpc, distr])),
|
||||||
|
#{ desc =>
|
||||||
|
"Allows to tune the transport method used for transaction log replication, "
|
||||||
|
"on a per-shard basis.<br/>"
|
||||||
|
"<code>gen_rpc</code> uses the <code>gen_rpc</code> library, "
|
||||||
|
"<code>distr</code> uses the Erlang distribution.<br/>"
|
||||||
|
"If not specified, the default is to use the value "
|
||||||
|
"set in <code>db.default_shard_transport</code>."
|
||||||
|
, mapping => "emqx_machine.custom_shard_transports"
|
||||||
|
, default => #{}
|
||||||
|
})}
|
||||||
];
|
];
|
||||||
|
|
||||||
fields("cluster_call") ->
|
fields("cluster_call") ->
|
||||||
|
|
|
@ -30,12 +30,13 @@
|
||||||
start() ->
|
start() ->
|
||||||
case os:type() of
|
case os:type() of
|
||||||
{win32, nt} -> ok;
|
{win32, nt} -> ok;
|
||||||
_nix ->
|
_Nix ->
|
||||||
os:set_signal(sighup, ignore),
|
os:set_signal(sighup, ignore),
|
||||||
os:set_signal(sigterm, handle) %% default is handle
|
os:set_signal(sigterm, handle) %% default is handle
|
||||||
end,
|
end,
|
||||||
ok = set_backtrace_depth(),
|
ok = set_backtrace_depth(),
|
||||||
start_sysmon(),
|
start_sysmon(),
|
||||||
|
configure_shard_transports(),
|
||||||
ekka:start(),
|
ekka:start(),
|
||||||
ok = print_otp_version_warning().
|
ok = print_otp_version_warning().
|
||||||
|
|
||||||
|
@ -81,3 +82,12 @@ node_status() ->
|
||||||
|
|
||||||
update_vips() ->
|
update_vips() ->
|
||||||
system_monitor:add_vip(mria_status:shards_up()).
|
system_monitor:add_vip(mria_status:shards_up()).
|
||||||
|
|
||||||
|
configure_shard_transports() ->
|
||||||
|
ShardTransports = application:get_env(emqx_machine, custom_shard_transports, #{}),
|
||||||
|
maps:foreach(
|
||||||
|
fun(ShardBin, Transport) ->
|
||||||
|
ShardName = binary_to_existing_atom(ShardBin),
|
||||||
|
mria_config:set_shard_transport(ShardName, Transport)
|
||||||
|
end,
|
||||||
|
ShardTransports).
|
||||||
|
|
|
@ -34,7 +34,7 @@ init_per_suite(Config) ->
|
||||||
%% emqx_machine_SUITE.erl
|
%% emqx_machine_SUITE.erl
|
||||||
%%
|
%%
|
||||||
%% Reason:
|
%% Reason:
|
||||||
%% the `emqx_machine_boot:ensure_apps_started()` will crashed
|
%% the `emqx_machine_boot:ensure_apps_started()` will crash
|
||||||
%% on starting `emqx_authz` with dirty confs, which caused the file
|
%% on starting `emqx_authz` with dirty confs, which caused the file
|
||||||
%% `.._build/test/lib/emqx_conf/etc/acl.conf` could not be found
|
%% `.._build/test/lib/emqx_conf/etc/acl.conf` could not be found
|
||||||
%%
|
%%
|
||||||
|
@ -65,6 +65,25 @@ init_per_suite(Config) ->
|
||||||
end_per_suite(_Config) ->
|
end_per_suite(_Config) ->
|
||||||
emqx_common_test_helpers:stop_apps([]).
|
emqx_common_test_helpers:stop_apps([]).
|
||||||
|
|
||||||
|
init_per_testcase(t_custom_shard_transports, Config) ->
|
||||||
|
OldConfig = application:get_env(emqx_machine, custom_shard_transports),
|
||||||
|
[{old_config, OldConfig} | Config];
|
||||||
|
init_per_testcase(_TestCase, Config) ->
|
||||||
|
Config.
|
||||||
|
|
||||||
|
end_per_testcase(t_custom_shard_transports, Config) ->
|
||||||
|
OldConfig0 = ?config(old_config, Config),
|
||||||
|
application:stop(ekka),
|
||||||
|
case OldConfig0 of
|
||||||
|
{ok, OldConfig} ->
|
||||||
|
application:set_env(emqx_machine, custom_shard_transports, OldConfig);
|
||||||
|
undefined ->
|
||||||
|
application:unset_env(emqx_machine, custom_shard_transports)
|
||||||
|
end,
|
||||||
|
ok;
|
||||||
|
end_per_testcase(_TestCase, _Config) ->
|
||||||
|
ok.
|
||||||
|
|
||||||
t_shutdown_reboot(_Config) ->
|
t_shutdown_reboot(_Config) ->
|
||||||
emqx_machine_boot:stop_apps(),
|
emqx_machine_boot:stop_apps(),
|
||||||
false = emqx:is_running(node()),
|
false = emqx:is_running(node()),
|
||||||
|
@ -72,3 +91,15 @@ t_shutdown_reboot(_Config) ->
|
||||||
true = emqx:is_running(node()),
|
true = emqx:is_running(node()),
|
||||||
ok = emqx_machine_boot:stop_apps(),
|
ok = emqx_machine_boot:stop_apps(),
|
||||||
false = emqx:is_running(node()).
|
false = emqx:is_running(node()).
|
||||||
|
|
||||||
|
t_custom_shard_transports(_Config) ->
|
||||||
|
%% used to ensure the atom exists
|
||||||
|
Shard = test_shard,
|
||||||
|
%% the config keys are binaries
|
||||||
|
ShardBin = atom_to_binary(Shard),
|
||||||
|
DefaultTransport = gen_rpc,
|
||||||
|
?assertEqual(DefaultTransport, mria_config:shard_transport(Shard)),
|
||||||
|
application:set_env(emqx_machine, custom_shard_transports, #{ShardBin => distr}),
|
||||||
|
emqx_machine:start(),
|
||||||
|
?assertEqual(distr, mria_config:shard_transport(Shard)),
|
||||||
|
ok.
|
||||||
|
|
Loading…
Reference in New Issue