geo-rep: IPv6 support
`address_family=inet6` needs to be added while mounting master and slave volumes in gverify script. New option introduced to gluster cli(`--inet6`) which will be used internally by geo-rep while calling `gluster volume info --remote-host=<ipv6>`. Backport of https://review.gluster.org/22363 Fixes: bz#1695436 Change-Id: I1e0d42cae07158df043e64a2f991882d8c897837 Signed-off-by: Aravinda VK <avishwan@redhat.com> (cherry picked from commit 240e1d6821fbb779c3dd73f6f0225d755a5b7cc6)
This commit is contained in:
parent
f39fc92d65
commit
cbb52082da
@ -442,6 +442,12 @@ cli_opt_parse(char *opt, struct cli_state *state)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
oarg = strtail(opt, "inet6");
|
||||||
|
if (oarg) {
|
||||||
|
state->address_family = "inet6";
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
oarg = strtail(opt, "log-file=");
|
oarg = strtail(opt, "log-file=");
|
||||||
if (oarg) {
|
if (oarg) {
|
||||||
state->log_file = oarg;
|
state->log_file = oarg;
|
||||||
@ -688,6 +694,11 @@ cli_rpc_init(struct cli_state *state)
|
|||||||
this = THIS;
|
this = THIS;
|
||||||
cli_rpc_prog = &cli_prog;
|
cli_rpc_prog = &cli_prog;
|
||||||
|
|
||||||
|
/* If address family specified in CLI */
|
||||||
|
if (state->address_family) {
|
||||||
|
addr_family = state->address_family;
|
||||||
|
}
|
||||||
|
|
||||||
/* Connect to glusterd using the specified method, giving preference
|
/* Connect to glusterd using the specified method, giving preference
|
||||||
* to a unix socket connection. If nothing is specified, connect to
|
* to a unix socket connection. If nothing is specified, connect to
|
||||||
* the default glusterd socket.
|
* the default glusterd socket.
|
||||||
|
@ -136,6 +136,7 @@ struct cli_state {
|
|||||||
gf_loglevel_t log_level;
|
gf_loglevel_t log_level;
|
||||||
|
|
||||||
char *glusterd_sock;
|
char *glusterd_sock;
|
||||||
|
char *address_family;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct cli_local {
|
struct cli_local {
|
||||||
|
@ -94,6 +94,7 @@ echo $cmd_line;
|
|||||||
function master_stats()
|
function master_stats()
|
||||||
{
|
{
|
||||||
MASTERVOL=$1;
|
MASTERVOL=$1;
|
||||||
|
local inet6=$2;
|
||||||
local d;
|
local d;
|
||||||
local i;
|
local i;
|
||||||
local disk_size;
|
local disk_size;
|
||||||
@ -102,7 +103,12 @@ function master_stats()
|
|||||||
local m_status;
|
local m_status;
|
||||||
|
|
||||||
d=$(mktemp -d -t ${0##*/}.XXXXXX 2>/dev/null);
|
d=$(mktemp -d -t ${0##*/}.XXXXXX 2>/dev/null);
|
||||||
|
if [ "$inet6" = "inet6" ]; then
|
||||||
|
glusterfs -s localhost --xlator-option="*dht.lookup-unhashed=off" --xlator-option="transport.address-family=inet6" --volfile-id $MASTERVOL -l $master_log_file $d;
|
||||||
|
else
|
||||||
glusterfs -s localhost --xlator-option="*dht.lookup-unhashed=off" --volfile-id $MASTERVOL -l $master_log_file $d;
|
glusterfs -s localhost --xlator-option="*dht.lookup-unhashed=off" --volfile-id $MASTERVOL -l $master_log_file $d;
|
||||||
|
fi
|
||||||
|
|
||||||
i=$(get_inode_num $d);
|
i=$(get_inode_num $d);
|
||||||
if [[ "$i" -ne "1" ]]; then
|
if [[ "$i" -ne "1" ]]; then
|
||||||
echo 0:0;
|
echo 0:0;
|
||||||
@ -124,12 +130,18 @@ function slave_stats()
|
|||||||
SLAVEUSER=$1;
|
SLAVEUSER=$1;
|
||||||
SLAVEHOST=$2;
|
SLAVEHOST=$2;
|
||||||
SLAVEVOL=$3;
|
SLAVEVOL=$3;
|
||||||
|
local inet6=$4;
|
||||||
local cmd_line;
|
local cmd_line;
|
||||||
local ver;
|
local ver;
|
||||||
local status;
|
local status;
|
||||||
|
|
||||||
d=$(mktemp -d -t ${0##*/}.XXXXXX 2>/dev/null);
|
d=$(mktemp -d -t ${0##*/}.XXXXXX 2>/dev/null);
|
||||||
|
if [ "$inet6" = "inet6" ]; then
|
||||||
|
glusterfs --xlator-option="*dht.lookup-unhashed=off" --xlator-option="transport.address-family=inet6" --volfile-server $SLAVEHOST --volfile-id $SLAVEVOL -l $slave_log_file $d;
|
||||||
|
else
|
||||||
glusterfs --xlator-option="*dht.lookup-unhashed=off" --volfile-server $SLAVEHOST --volfile-id $SLAVEVOL -l $slave_log_file $d;
|
glusterfs --xlator-option="*dht.lookup-unhashed=off" --volfile-server $SLAVEHOST --volfile-id $SLAVEVOL -l $slave_log_file $d;
|
||||||
|
fi
|
||||||
|
|
||||||
i=$(get_inode_num $d);
|
i=$(get_inode_num $d);
|
||||||
if [[ "$i" -ne "1" ]]; then
|
if [[ "$i" -ne "1" ]]; then
|
||||||
echo 0:0;
|
echo 0:0;
|
||||||
@ -167,6 +179,8 @@ function main()
|
|||||||
log_file=$6
|
log_file=$6
|
||||||
> $log_file
|
> $log_file
|
||||||
|
|
||||||
|
inet6=$7
|
||||||
|
|
||||||
# Use FORCE_BLOCKER flag in the error message to differentiate
|
# Use FORCE_BLOCKER flag in the error message to differentiate
|
||||||
# between the errors which the force command should bypass
|
# between the errors which the force command should bypass
|
||||||
|
|
||||||
@ -204,8 +218,8 @@ function main()
|
|||||||
fi;
|
fi;
|
||||||
|
|
||||||
ERRORS=0;
|
ERRORS=0;
|
||||||
master_data=$(master_stats $1);
|
master_data=$(master_stats $1 ${inet6});
|
||||||
slave_data=$(slave_stats $2 $3 $4);
|
slave_data=$(slave_stats $2 $3 $4 ${inet6});
|
||||||
master_disk_size=$(echo $master_data | cut -f1 -d':');
|
master_disk_size=$(echo $master_data | cut -f1 -d':');
|
||||||
slave_disk_size=$(echo $slave_data | cut -f1 -d':');
|
slave_disk_size=$(echo $slave_data | cut -f1 -d':');
|
||||||
master_used_size=$(echo $master_data | cut -f2 -d':');
|
master_used_size=$(echo $master_data | cut -f2 -d':');
|
||||||
|
@ -84,6 +84,10 @@ def upgrade():
|
|||||||
# fail when it does stat to check the existence.
|
# fail when it does stat to check the existence.
|
||||||
init_gsyncd_template_conf()
|
init_gsyncd_template_conf()
|
||||||
|
|
||||||
|
inet6 = False
|
||||||
|
if "--inet6" in sys.argv:
|
||||||
|
inet6 = True
|
||||||
|
|
||||||
if "--monitor" in sys.argv:
|
if "--monitor" in sys.argv:
|
||||||
# python gsyncd.py --path=/bricks/b1
|
# python gsyncd.py --path=/bricks/b1
|
||||||
# --monitor -c gsyncd.conf
|
# --monitor -c gsyncd.conf
|
||||||
@ -147,8 +151,11 @@ def upgrade():
|
|||||||
|
|
||||||
user, hname = remote_addr.split("@")
|
user, hname = remote_addr.split("@")
|
||||||
|
|
||||||
|
if not inet6:
|
||||||
|
hname = gethostbyname(hname)
|
||||||
|
|
||||||
print(("ssh://%s@%s:gluster://127.0.0.1:%s" % (
|
print(("ssh://%s@%s:gluster://127.0.0.1:%s" % (
|
||||||
user, gethostbyname(hname), vol)))
|
user, hname, vol)))
|
||||||
|
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
elif "--normalize-url" in sys.argv:
|
elif "--normalize-url" in sys.argv:
|
||||||
@ -346,3 +353,7 @@ def upgrade():
|
|||||||
|
|
||||||
if pargs.reset_sync_time:
|
if pargs.reset_sync_time:
|
||||||
sys.argv.append("--reset-sync-time")
|
sys.argv.append("--reset-sync-time")
|
||||||
|
|
||||||
|
if inet6:
|
||||||
|
# Add `--inet6` as first argument
|
||||||
|
sys.argv = [sys.argv[0], "--inet6"] + sys.argv[1:]
|
||||||
|
@ -47,6 +47,7 @@ def main():
|
|||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
|
||||||
parser = ArgumentParser()
|
parser = ArgumentParser()
|
||||||
|
parser.add_argument("--inet6", action="store_true")
|
||||||
sp = parser.add_subparsers(dest="subcmd")
|
sp = parser.add_subparsers(dest="subcmd")
|
||||||
|
|
||||||
# Monitor Status File update
|
# Monitor Status File update
|
||||||
|
@ -110,8 +110,13 @@ def subcmd_voluuidget(args):
|
|||||||
|
|
||||||
ParseError = XET.ParseError if hasattr(XET, 'ParseError') else SyntaxError
|
ParseError = XET.ParseError if hasattr(XET, 'ParseError') else SyntaxError
|
||||||
|
|
||||||
po = Popen(['gluster', '--xml', '--remote-host=' + args.host,
|
cmd = ['gluster', '--xml', '--remote-host=' + args.host,
|
||||||
'volume', 'info', args.volname], bufsize=0,
|
'volume', 'info', args.volname]
|
||||||
|
|
||||||
|
if args.inet6:
|
||||||
|
cmd.append("--inet6")
|
||||||
|
|
||||||
|
po = Popen(cmd, bufsize=0,
|
||||||
stdin=None, stdout=PIPE, stderr=PIPE,
|
stdin=None, stdout=PIPE, stderr=PIPE,
|
||||||
universal_newlines=True)
|
universal_newlines=True)
|
||||||
|
|
||||||
|
@ -76,6 +76,19 @@ static char *gsync_reserved_opts[] = {"gluster-command",
|
|||||||
static char *gsync_no_restart_opts[] = {"checkpoint", "log_rsync_performance",
|
static char *gsync_no_restart_opts[] = {"checkpoint", "log_rsync_performance",
|
||||||
"log-rsync-performance", NULL};
|
"log-rsync-performance", NULL};
|
||||||
|
|
||||||
|
void
|
||||||
|
set_gsyncd_inet6_arg(runner_t *runner)
|
||||||
|
{
|
||||||
|
xlator_t *this = NULL;
|
||||||
|
char *af;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
this = THIS;
|
||||||
|
ret = dict_get_str(this->options, "transport.address-family", &af);
|
||||||
|
if (ret == 0)
|
||||||
|
runner_argprintf(runner, "--%s", af);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
__glusterd_handle_sys_exec(rpcsvc_request_t *req)
|
__glusterd_handle_sys_exec(rpcsvc_request_t *req)
|
||||||
{
|
{
|
||||||
@ -384,6 +397,7 @@ glusterd_urltransform_init(runner_t *runner, const char *transname)
|
|||||||
{
|
{
|
||||||
runinit(runner);
|
runinit(runner);
|
||||||
runner_add_arg(runner, GSYNCD_PREFIX "/gsyncd");
|
runner_add_arg(runner, GSYNCD_PREFIX "/gsyncd");
|
||||||
|
set_gsyncd_inet6_arg(runner);
|
||||||
runner_argprintf(runner, "--%s-url", transname);
|
runner_argprintf(runner, "--%s-url", transname);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -725,6 +739,7 @@ glusterd_get_slave_voluuid(char *slave_host, char *slave_vol, char *vol_uuid)
|
|||||||
|
|
||||||
runinit(&runner);
|
runinit(&runner);
|
||||||
runner_add_arg(&runner, GSYNCD_PREFIX "/gsyncd");
|
runner_add_arg(&runner, GSYNCD_PREFIX "/gsyncd");
|
||||||
|
set_gsyncd_inet6_arg(&runner);
|
||||||
runner_add_arg(&runner, "--slavevoluuid-get");
|
runner_add_arg(&runner, "--slavevoluuid-get");
|
||||||
runner_argprintf(&runner, "%s::%s", slave_host, slave_vol);
|
runner_argprintf(&runner, "%s::%s", slave_host, slave_vol);
|
||||||
|
|
||||||
@ -788,6 +803,7 @@ glusterd_gsync_get_config(char *master, char *slave, char *conf_path,
|
|||||||
runinit(&runner);
|
runinit(&runner);
|
||||||
runner_add_args(&runner, GSYNCD_PREFIX "/gsyncd", "-c", NULL);
|
runner_add_args(&runner, GSYNCD_PREFIX "/gsyncd", "-c", NULL);
|
||||||
runner_argprintf(&runner, "%s", conf_path);
|
runner_argprintf(&runner, "%s", conf_path);
|
||||||
|
set_gsyncd_inet6_arg(&runner);
|
||||||
runner_argprintf(&runner, "--iprefix=%s", DATADIR);
|
runner_argprintf(&runner, "--iprefix=%s", DATADIR);
|
||||||
runner_argprintf(&runner, ":%s", master);
|
runner_argprintf(&runner, ":%s", master);
|
||||||
runner_add_args(&runner, slave, "--config-get-all", NULL);
|
runner_add_args(&runner, slave, "--config-get-all", NULL);
|
||||||
@ -917,6 +933,7 @@ glusterd_gsync_get_status(char *master, char *slave, char *conf_path,
|
|||||||
runinit(&runner);
|
runinit(&runner);
|
||||||
runner_add_args(&runner, GSYNCD_PREFIX "/gsyncd", "-c", NULL);
|
runner_add_args(&runner, GSYNCD_PREFIX "/gsyncd", "-c", NULL);
|
||||||
runner_argprintf(&runner, "%s", conf_path);
|
runner_argprintf(&runner, "%s", conf_path);
|
||||||
|
set_gsyncd_inet6_arg(&runner);
|
||||||
runner_argprintf(&runner, "--iprefix=%s", DATADIR);
|
runner_argprintf(&runner, "--iprefix=%s", DATADIR);
|
||||||
runner_argprintf(&runner, ":%s", master);
|
runner_argprintf(&runner, ":%s", master);
|
||||||
runner_add_args(&runner, slave, "--status-get", NULL);
|
runner_add_args(&runner, slave, "--status-get", NULL);
|
||||||
@ -937,6 +954,7 @@ glusterd_gsync_get_param_file(char *prmfile, const char *param, char *master,
|
|||||||
runinit(&runner);
|
runinit(&runner);
|
||||||
runner_add_args(&runner, GSYNCD_PREFIX "/gsyncd", "-c", NULL);
|
runner_add_args(&runner, GSYNCD_PREFIX "/gsyncd", "-c", NULL);
|
||||||
runner_argprintf(&runner, "%s", conf_path);
|
runner_argprintf(&runner, "%s", conf_path);
|
||||||
|
set_gsyncd_inet6_arg(&runner);
|
||||||
runner_argprintf(&runner, "--iprefix=%s", DATADIR);
|
runner_argprintf(&runner, "--iprefix=%s", DATADIR);
|
||||||
runner_argprintf(&runner, ":%s", master);
|
runner_argprintf(&runner, ":%s", master);
|
||||||
runner_add_args(&runner, slave, "--config-get", NULL);
|
runner_add_args(&runner, slave, "--config-get", NULL);
|
||||||
@ -2811,6 +2829,7 @@ glusterd_verify_slave(char *volname, char *slave_url, char *slave_vol,
|
|||||||
char *slave_ip = NULL;
|
char *slave_ip = NULL;
|
||||||
glusterd_conf_t *priv = NULL;
|
glusterd_conf_t *priv = NULL;
|
||||||
xlator_t *this = NULL;
|
xlator_t *this = NULL;
|
||||||
|
char *af = NULL;
|
||||||
|
|
||||||
this = THIS;
|
this = THIS;
|
||||||
GF_ASSERT(this);
|
GF_ASSERT(this);
|
||||||
@ -2852,9 +2871,16 @@ glusterd_verify_slave(char *volname, char *slave_url, char *slave_vol,
|
|||||||
runner_argprintf(&runner, "%s", slave_vol);
|
runner_argprintf(&runner, "%s", slave_vol);
|
||||||
runner_argprintf(&runner, "%d", ssh_port);
|
runner_argprintf(&runner, "%d", ssh_port);
|
||||||
runner_argprintf(&runner, "%s", log_file_path);
|
runner_argprintf(&runner, "%s", log_file_path);
|
||||||
gf_msg_debug(this->name, 0, "gverify Args = %s %s %s %s %s %s %s",
|
ret = dict_get_str(this->options, "transport.address-family", &af);
|
||||||
|
if (ret)
|
||||||
|
af = "-";
|
||||||
|
|
||||||
|
runner_argprintf(&runner, "%s", af);
|
||||||
|
|
||||||
|
gf_msg_debug(this->name, 0, "gverify Args = %s %s %s %s %s %s %s %s",
|
||||||
runner.argv[0], runner.argv[1], runner.argv[2], runner.argv[3],
|
runner.argv[0], runner.argv[1], runner.argv[2], runner.argv[3],
|
||||||
runner.argv[4], runner.argv[5], runner.argv[6]);
|
runner.argv[4], runner.argv[5], runner.argv[6],
|
||||||
|
runner.argv[7]);
|
||||||
runner_redir(&runner, STDOUT_FILENO, RUN_PIPE);
|
runner_redir(&runner, STDOUT_FILENO, RUN_PIPE);
|
||||||
synclock_unlock(&priv->big_lock);
|
synclock_unlock(&priv->big_lock);
|
||||||
ret = runner_run(&runner);
|
ret = runner_run(&runner);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user