[sheepdog] [PATCH] zookeeper: explecitly ask users to wait to restart sheep

Robin Dong robin.k.dong at gmail.com
Sat Jan 11 09:00:46 CET 2014


Reviewed-by: Robin Dong <sanbai at taobao.com>


2014/1/10 Liu Yuan <namei.unix at gmail.com>

> Not every users is zookeeper guru, so we should make log as friendly as
> possible
>
> Signed-off-by: Liu Yuan <namei.unix at gmail.com>
> ---
>  sheep/cluster/zookeeper.c | 13 ++++++++-----
>  1 file changed, 8 insertions(+), 5 deletions(-)
>
> diff --git a/sheep/cluster/zookeeper.c b/sheep/cluster/zookeeper.c
> index b80d3c7..3f6c146 100644
> --- a/sheep/cluster/zookeeper.c
> +++ b/sheep/cluster/zookeeper.c
> @@ -32,6 +32,8 @@
>  #define MASTER_ZNONE BASE_ZNODE "/master"
>  #define LOCK_ZNODE BASE_ZNODE "/lock"
>
> +static int zk_timeout = SESSION_TIMEOUT;
> +
>  /* structure for distributed lock */
>  struct cluster_lock {
>         struct hlist_node hnode;
> @@ -930,7 +932,8 @@ static int zk_join(const struct sd_node *myself,
>         snprintf(path, sizeof(path), MEMBER_ZNODE "/%s",
> node_to_str(myself));
>         rc = zk_node_exists(path);
>         if (rc == ZOK) {
> -               sd_err("Previous zookeeper session exist, shoot myself.");
> +               sd_err("Previous zookeeper session exist, shoot myself.
> Please "
> +                      "wait for %d seconds to join me again.",
> zk_timeout);
>                 exit(1);
>         }
>
> @@ -1289,7 +1292,7 @@ static void zk_unlock(uint64_t lock_id)
>  static int zk_init(const char *option)
>  {
>         char *hosts, *to, *p;
> -       int ret, timeout = SESSION_TIMEOUT;
> +       int ret;
>
>         if (!option) {
>                 sd_err("You must specify zookeeper servers.");
> @@ -1298,7 +1301,7 @@ static int zk_init(const char *option)
>
>         hosts = strtok((char *)option, "=");
>         if ((to = strtok(NULL, "="))) {
> -               if (sscanf(to, "%u", &timeout) != 1) {
> +               if (sscanf(to, "%u", &zk_timeout) != 1) {
>                         sd_err("Invalid paramter for timeout");
>                         return -1;
>                 }
> @@ -1306,8 +1309,8 @@ static int zk_init(const char *option)
>                 *--p = '\0';
>         }
>         sd_debug("version %d.%d.%d, address %s, timeout %d",
> ZOO_MAJOR_VERSION,
> -                ZOO_MINOR_VERSION, ZOO_PATCH_VERSION, hosts, timeout);
> -       zhandle = zookeeper_init(hosts, zk_watcher, timeout, NULL, NULL,
> 0);
> +                ZOO_MINOR_VERSION, ZOO_PATCH_VERSION, hosts, zk_timeout);
> +       zhandle = zookeeper_init(hosts, zk_watcher, zk_timeout, NULL,
> NULL, 0);
>         if (!zhandle) {
>                 sd_err("failed to connect to zk server %s", option);
>                 return -1;
> --
> 1.8.1.2
>
> --
> sheepdog mailing list
> sheepdog at lists.wpkg.org
> http://lists.wpkg.org/mailman/listinfo/sheepdog
>



-- 
--
Best Regard
Robin Dong
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.wpkg.org/pipermail/sheepdog/attachments/20140111/3a797909/attachment-0003.html>


More information about the sheepdog mailing list