diff options
| author | Krishnan Parthasarathi <kparthas@redhat.com> | 2013-04-16 10:36:31 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2013-04-16 04:48:58 -0700 | 
| commit | 29d7563416c0d94cf36d7e05493332aacebfa0e0 (patch) | |
| tree | 1d2359b137617cf2473d040a011066953a7ffce8 /xlators | |
| parent | 695d173b13f583de846720b66fc201bd84969330 (diff) | |
glusterd: allow multiple instances of glusterd on one machine
This is needed to support automated testing of cluster-communication
features such as probing and quorum.  In order to use this, you need to
do the following preparatory steps.
* Copy /var/lib/glusterd to another directory for each virtual host
* Ensure that each virtual host has a different UUID in its glusterd.info
Now you can start each copy of glusterd with the following xlator-options.
* management.transport.socket.bind-address=$ip_address
* management.working-directory=$unique_working_directory
You can use 127.x.y.z addresses for binding without needing to assign
them to interfaces explicitly.  Note that you must use addresses, not
names, because of some stuff in the socket code that's not worth fixing
just for this usage, but after that you can use names in /etc/hosts
instead.
At this point you can issue CLI commands to a specific glusterd using
the --remote-host option.  So far probe, volume create/start/stop,
mount, and basic I/O all seem to work as expected with multiple
instances.
Change-Id: I1beabb44cff8763d2774bc208b2ffcda27c1a550
BUG: 913555
Original-author: Jeff Darcy <jdarcy@redhat.com>
Signed-off-by: Krishnan Parthasarathi <kparthas@redhat.com>
Reviewed-on: http://review.gluster.org/4838
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Diffstat (limited to 'xlators')
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-handler.c | 26 | ||||
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-utils.c | 48 | ||||
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-utils.h | 3 | 
3 files changed, 76 insertions, 1 deletions
| diff --git a/xlators/mgmt/glusterd/src/glusterd-handler.c b/xlators/mgmt/glusterd/src/glusterd-handler.c index d69f8352010..d5bad0f2751 100644 --- a/xlators/mgmt/glusterd/src/glusterd-handler.c +++ b/xlators/mgmt/glusterd/src/glusterd-handler.c @@ -707,6 +707,7 @@ glusterd_handle_cli_probe (rpcsvc_request_t *req)          glusterd_peerinfo_t             *peerinfo = NULL;          gf_boolean_t                    run_fsm = _gf_true;          xlator_t                        *this = NULL; +        char                            *bind_name = NULL;          GF_ASSERT (req);          this = THIS; @@ -736,7 +737,16 @@ glusterd_handle_cli_probe (rpcsvc_request_t *req)          gf_log ("glusterd", GF_LOG_INFO, "Received CLI probe req %s %d",                  cli_req.hostname, cli_req.port); -        if (glusterd_is_local_addr(cli_req.hostname)) { +        if (dict_get_str(this->options,"transport.socket.bind-address", +                         &bind_name) == 0) { +                gf_log ("glusterd", GF_LOG_DEBUG, +                        "only checking probe address vs. bind address"); +                ret = glusterd_is_same_address(bind_name,cli_req.hostname); +        } +        else { +                ret = glusterd_is_local_addr(cli_req.hostname); +        } +        if (ret) {                  glusterd_xfer_cli_probe_resp (req, 0, GF_PROBE_LOCALHOST, NULL,                                                cli_req.hostname, cli_req.port);                  ret = 0; @@ -2429,6 +2439,7 @@ glusterd_friend_rpc_create (xlator_t *this, glusterd_peerinfo_t *peerinfo,          dict_t                 *options = NULL;          int                    ret = -1;          glusterd_peerctx_t     *peerctx = NULL; +        data_t                 *data = NULL;          peerctx = GF_CALLOC (1, sizeof (*peerctx), gf_gld_mt_peerctx_t);          if (!peerctx) @@ -2445,6 +2456,19 @@ glusterd_friend_rpc_create (xlator_t *this, glusterd_peerinfo_t *peerinfo,          if (ret)                  goto out; +        /* +         * For simulated multi-node testing, we need to make sure that we +         * create our RPC endpoint with the same address that the peer would +         * use to reach us. +         */ +        if (this->options) { +                data = dict_get(this->options,"transport.socket.bind-address"); +                if (data) { +                        ret = dict_set(options, +                                       "transport.socket.source-addr",data); +                } +        } +          ret = glusterd_rpc_create (&peerinfo->rpc, options,                                     glusterd_peer_rpc_notify, peerctx);          if (ret) { diff --git a/xlators/mgmt/glusterd/src/glusterd-utils.c b/xlators/mgmt/glusterd/src/glusterd-utils.c index 093c59ce87a..4db538b0223 100644 --- a/xlators/mgmt/glusterd/src/glusterd-utils.c +++ b/xlators/mgmt/glusterd/src/glusterd-utils.c @@ -7397,3 +7397,51 @@ glusterd_copy_uuid_to_dict (uuid_t uuid, dict_t *dict, char *key)          return 0;  } + +gf_boolean_t +glusterd_is_same_address (char *name1, char *name2) +{ +        struct addrinfo         *addr1 = NULL; +        struct addrinfo         *addr2 = NULL; +        struct addrinfo         *p = NULL;        +        struct addrinfo         *q = NULL;        +        gf_boolean_t            ret = _gf_false; +        int                     gai_err = 0; + +        gai_err = getaddrinfo(name1,NULL,NULL,&addr1); +        if (gai_err != 0) { +                gf_log (name1, GF_LOG_WARNING, +                        "error in getaddrinfo: %s\n", gai_strerror(gai_err)); +                goto out; +        } + +        gai_err = getaddrinfo(name2,NULL,NULL,&addr2); +        if (gai_err != 0) { +                gf_log (name2, GF_LOG_WARNING, +                        "error in getaddrinfo: %s\n", gai_strerror(gai_err)); +                goto out; +        } + +        for (p = addr1; p; p = p->ai_next) { +                for (q = addr2; q; q = q->ai_next) { +                        if (p->ai_addrlen != q->ai_addrlen) { +                                continue; +                        } +                        if (memcmp(p->ai_addr,q->ai_addr,p->ai_addrlen)) { +                                continue; +                        } +                        ret = _gf_true; +                        goto out; +                } +        } + +out: +        if (addr1) { +                freeaddrinfo(addr1); +        } +        if (addr2) { +                freeaddrinfo(addr2); +        } +        return ret; + +} diff --git a/xlators/mgmt/glusterd/src/glusterd-utils.h b/xlators/mgmt/glusterd/src/glusterd-utils.h index b5f005560c2..6084f5714b3 100644 --- a/xlators/mgmt/glusterd/src/glusterd-utils.h +++ b/xlators/mgmt/glusterd/src/glusterd-utils.h @@ -509,4 +509,7 @@ glusterd_generate_and_set_task_id (dict_t *dict, char *key);  int  glusterd_copy_uuid_to_dict (uuid_t uuid, dict_t *dict, char *key); + +gf_boolean_t +glusterd_is_same_address (char *name1, char *name2);  #endif | 
