From 81edfb1a0e9a2064b1ae0d05cd0393268132685c Mon Sep 17 00:00:00 2001 From: lpstudy Date: Fri, 2 Jun 2017 20:18:24 +0800 Subject: [PATCH 1/3] Minor bug fix for shell scripts. 1. add readline download link to avoid compile error 2. run the shell with CURRENT_DIRECTORY, to avoid the error like `bin/kill_tera.sh` 3. add GetProcessDir function to get the exe directory, so that we can run `teracli` in any directory, rather than only work by `./teracli`. --- build.conf.template | 4 ++++ build.sh | 17 ++++++++++++++++- example/onebox/bin/kill_tera.sh | 3 ++- example/onebox/bin/launch_tera.sh | 2 +- src/common/file/file_path.cc | 18 ++++++++++++++++++ src/common/file/file_path.h | 3 +++ src/sdk/client_impl.cc | 6 +++--- 7 files changed, 47 insertions(+), 6 deletions(-) diff --git a/build.conf.template b/build.conf.template index b34741068..51d996aeb 100755 --- a/build.conf.template +++ b/build.conf.template @@ -18,6 +18,7 @@ LIBUNWIND_VERSION=0.99 GPERFTOOLS_VERSION=2.5 INS_VERSION=0.15 NOSE_VERSION=1.3.7 +READLINE_VERSION=7.0 if [ $MIRROR == "china" ]; then BOOST_URL=http://mirrors.tuna.tsinghua.edu.cn/macports/distfiles/boost/boost_${BOOST_VERSION}.tar.bz2 @@ -32,6 +33,7 @@ if [ $MIRROR == "china" ]; then GPERFTOOLS_URL=https://github.com/00k/gperftools/raw/master/gperftools-${GPERFTOOLS_VERSION}.tar.gz INS_URL=https://github.com/baidu/ins/archive/${INS_VERSION}.tar.gz NOSE_URL=http://mirrors.163.com/gentoo/distfiles/nose-${NOSE_VERSION}.tar.gz + READLINE_URL=http://git.savannah.gnu.org/cgit/readline.git/snapshot/readline-${READLINE_VERSION}.tar.gz elif [ $MIRROR == "origin" ]; then BOOST_URL=http://downloads.sourceforge.net/project/boost/boost/1.58.0/boost_${BOOST_VERSION}.tar.bz2 PROTOBUF_URL=https://github.com/google/protobuf/releases/download/v${PROTOBUF_VERSION}/protobuf-${PROTOBUF_VERSION}.tar.bz2 @@ -45,6 +47,7 @@ elif [ $MIRROR == "origin" ]; then GPERFTOOLS_URL=https://github.com/gperftools/gperftools/releases/download/gperftools-${GPERFTOOLS_VERSION}/gperftools-${GPERFTOOLS_VERSION}.tar.gz INS_URL=https://github.com/baidu/ins/archive/${INS_VERSION}.tar.gz NOSE_URL=https://pypi.python.org/packages/58/a5/0dc93c3ec33f4e281849523a5a913fa1eea9a3068acfa754d44d88107a44/nose-${NOSE_VERSION}.tar.gz + READLINE_URL=http://git.savannah.gnu.org/cgit/readline.git/snapshot/readline-${READLINE_VERSION}.tar.gz elif [ $MIRROR == "baidu" ]; then BOOST_URL=http://gitlab.baidu.com/baidups/third/raw/master/boost_${BOOST_VERSION}.tar.bz2 PROTOBUF_URL=http://gitlab.baidu.com/baidups/third/raw/master/protobuf-${PROTOBUF_VERSION}.tar.bz2 @@ -58,6 +61,7 @@ elif [ $MIRROR == "baidu" ]; then GPERFTOOLS_URL=http://gitlab.baidu.com/baidups/third/raw/master/gperftools-${GPERFTOOLS_VERSION}.tar.gz INS_URL=http://gitlab.baidu.com/baidups/third/raw/master/ins-${INS_VERSION}.tar.gz NOSE_URL=http://gitlab.baidu.com/baidups/third/raw/master/nose-${NOSE_VERSION}.tar.gz + READLINE_URL=http://git.savannah.gnu.org/cgit/readline.git/snapshot/readline-${READLINE_VERSION}.tar.gz else return 1 fi diff --git a/build.sh b/build.sh index 5283ba2fc..e35ab3ad3 100755 --- a/build.sh +++ b/build.sh @@ -223,7 +223,7 @@ if [ ${NOSE_VERSION} == "DISABLE" ]; then echo "Disable nose." elif [ ! -f "${FLAG_DIR}/nose_${NOSE_VERSION}" ] \ || [ ! -f "${DEPS_PREFIX}/bin/nosetests" ] \ - || [ ! -d "${DEPS_PREFIX}/lib/nose" ]; then + || [ ! -d "${DEPS_PREFIX}/lib/"nose* ]; then wget --no-check-certificate -O nose-${NOSE_VERSION}.tar.gz ${NOSE_URL} tar zxf nose-${NOSE_VERSION}.tar.gz --recursive-unlink cd nose-${NOSE_VERSION} @@ -233,6 +233,21 @@ elif [ ! -f "${FLAG_DIR}/nose_${NOSE_VERSION}" ] \ touch "${FLAG_DIR}/nose_${NOSE_VERSION}" fi +# readline (teracli_main.cc use this and lead to compile failed) +if [ ${READLINE_VERSION} == "DISABLE" ]; then + echo "Disable readline." +elif [ ! -f "${FLAG_DIR}/readline_${READLINE_VERSION}" ] \ + || [ ! -f "${DEPS_PREFIX}/lib/libreadline.a" ] \ + || [ ! -d "${DEPS_PREFIX}/include/readline" ]; then + wget --no-check-certificate -O readline-${READLINE_VERSION}.tar.gz ${READLINE_URL} + tar zxf readline-${READLINE_VERSION}.tar.gz --recursive-unlink + cd readline-${READLINE_VERSION} + ./configure ${DEPS_CONFIG} CPPFLAGS=-I${DEPS_PREFIX}/include LDFLAGS=-L${DEPS_PREFIX}/lib + make install + cd - + touch "${FLAG_DIR}/readline_${READLINE_VERSION}" +fi + cd ${WORK_DIR} ######################################## diff --git a/example/onebox/bin/kill_tera.sh b/example/onebox/bin/kill_tera.sh index 047de86bb..9f1a9ea0f 100755 --- a/example/onebox/bin/kill_tera.sh +++ b/example/onebox/bin/kill_tera.sh @@ -1,5 +1,6 @@ #!/bin/bash -source ./config +CURRENT_DIR=`dirname $0` +source ${CURRENT_DIR}/config PID=`ps x | grep tera_master | grep $PORT | awk '{print $1}'`; if [ ${PID}"x" != "x" ]; then diff --git a/example/onebox/bin/launch_tera.sh b/example/onebox/bin/launch_tera.sh index c6d5f2fba..bc3d22956 100755 --- a/example/onebox/bin/launch_tera.sh +++ b/example/onebox/bin/launch_tera.sh @@ -3,7 +3,7 @@ CURRENT_DIR=`dirname $0` source ${CURRENT_DIR}/config # make sure tera is killed -./kill_tera.sh +./$CURRENT_DIR/kill_tera.sh FAKE_ZK_PATH_PREFIX="${CURRENT_DIR}/../fakezk" TIME=`date +%Y-%m-%d-%H:%M:%S` diff --git a/src/common/file/file_path.cc b/src/common/file/file_path.cc index 44738117f..ddab81343 100644 --- a/src/common/file/file_path.cc +++ b/src/common/file/file_path.cc @@ -12,6 +12,7 @@ #include #include #include +#include #include @@ -105,6 +106,23 @@ bool CreateDirWithRetry(const std::string& dir_path) { } return is_success; } +std::string GetCWD(){ + char buf[1024]; + if(getcwd(buf, 1024) == NULL){ + return ""; + } + return buf; +} + +std::string GetProcessDir(){ + char buf[1024]; + ssize_t count = readlink("/proc/self/exe", buf, 1024); + if(count == 0) { + return ""; + } else{ + return dirname(buf); + } +} std::string UidToName(uid_t uid) { struct passwd *temp = NULL; diff --git a/src/common/file/file_path.h b/src/common/file/file_path.h index e0ab5d002..819581441 100644 --- a/src/common/file/file_path.h +++ b/src/common/file/file_path.h @@ -21,6 +21,9 @@ std::string GetPathPrefix(const std::string& full_path, bool CreateDirWithRetry(const std::string& dir_path); +std::string GetCWD(); +std::string GetProcessDir(); + std::string GidToName(gid_t gid); std::string UidToName(uid_t uid); diff --git a/src/sdk/client_impl.cc b/src/sdk/client_impl.cc index bc9eb1998..26999afdc 100644 --- a/src/sdk/client_impl.cc +++ b/src/sdk/client_impl.cc @@ -1207,16 +1207,16 @@ static int InitFlags(const std::string& confpath, const std::string& log_prefix) } else if (!FLAGS_tera_sdk_conf_file.empty() && !IsExist(confpath)) { LOG(ERROR) << "specified config file(FLAGS_tera_sdk_conf_file) not found"; return -1; - } else if (IsExist("./tera.flag")) { + } else if (IsExist(GetProcessDir()+"./tera.flag")) { flagfile = "./tera.flag"; - } else if (IsExist("../conf/tera.flag")) { + } else if (IsExist(GetProcessDir()+"/../conf/tera.flag")) { flagfile = "../conf/tera.flag"; } else if (IsExist(utils::GetValueFromEnv("TERA_CONF"))) { flagfile = utils::GetValueFromEnv("TERA_CONF"); } else { LOG(ERROR) << "hasn't specify the flagfile, but default config file not found"; return -1; - } + } utils::LoadFlagFile(flagfile); From 2f6a8c05a5a643ed9690b977654932e8ba435f70 Mon Sep 17 00:00:00 2001 From: lpstudy Date: Sat, 3 Jun 2017 14:51:48 +0800 Subject: [PATCH 2/3] Minor bug fix for not passing the Travis CI build. (#1279) --- src/sdk/client_impl.cc | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/sdk/client_impl.cc b/src/sdk/client_impl.cc index 26999afdc..4a92e1f44 100644 --- a/src/sdk/client_impl.cc +++ b/src/sdk/client_impl.cc @@ -1195,7 +1195,7 @@ static int InitFlags(const std::string& confpath, const std::string& log_prefix) LOG(ERROR) << "should specify no more than one config file"; return -1; } - + std::string exedir = GetProcessDir(); if (!confpath.empty() && IsExist(confpath)){ flagfile = confpath; } else if(!confpath.empty() && !IsExist(confpath)){ @@ -1207,10 +1207,14 @@ static int InitFlags(const std::string& confpath, const std::string& log_prefix) } else if (!FLAGS_tera_sdk_conf_file.empty() && !IsExist(confpath)) { LOG(ERROR) << "specified config file(FLAGS_tera_sdk_conf_file) not found"; return -1; - } else if (IsExist(GetProcessDir()+"./tera.flag")) { + } else if (IsExist("./tera.flag")) { flagfile = "./tera.flag"; - } else if (IsExist(GetProcessDir()+"/../conf/tera.flag")) { + } else if (IsExist("../conf/tera.flag")) { flagfile = "../conf/tera.flag"; + } else if (IsExist(exedir + "/./tera.flag")) { + flagfile = exedir + "/./tera.flag"; + } else if (IsExist(exedir + "/../conf/tera.flag")) { + flagfile = exedir + "/../conf/tera.flag"; } else if (IsExist(utils::GetValueFromEnv("TERA_CONF"))) { flagfile = utils::GetValueFromEnv("TERA_CONF"); } else { From c2bd8a482c6d7a0d389f284fa02510d67c9f1bb7 Mon Sep 17 00:00:00 2001 From: lpstudy Date: Sun, 11 Jun 2017 18:57:21 +0800 Subject: [PATCH 3/3] (#1279) see the comments for the details. --- build.conf.template | 1 - src/common/file/file_path.cc | 26 +++++++++++++++----------- src/sdk/client_impl.cc | 9 +++++++-- 3 files changed, 22 insertions(+), 14 deletions(-) diff --git a/build.conf.template b/build.conf.template index 51d996aeb..09edc8462 100755 --- a/build.conf.template +++ b/build.conf.template @@ -61,7 +61,6 @@ elif [ $MIRROR == "baidu" ]; then GPERFTOOLS_URL=http://gitlab.baidu.com/baidups/third/raw/master/gperftools-${GPERFTOOLS_VERSION}.tar.gz INS_URL=http://gitlab.baidu.com/baidups/third/raw/master/ins-${INS_VERSION}.tar.gz NOSE_URL=http://gitlab.baidu.com/baidups/third/raw/master/nose-${NOSE_VERSION}.tar.gz - READLINE_URL=http://git.savannah.gnu.org/cgit/readline.git/snapshot/readline-${READLINE_VERSION}.tar.gz else return 1 fi diff --git a/src/common/file/file_path.cc b/src/common/file/file_path.cc index ddab81343..cc1a83d2d 100644 --- a/src/common/file/file_path.cc +++ b/src/common/file/file_path.cc @@ -2,22 +2,26 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. +#include "common/file/file_path.h" + #include #include +#include +#include #include +#include +#include +#include + #include #include #include #include -#include -#include -#include -#include #include #include "common/base/string_ext.h" -#include "common/file/file_path.h" + DECLARE_int32(file_op_retry_times); @@ -106,17 +110,17 @@ bool CreateDirWithRetry(const std::string& dir_path) { } return is_success; } -std::string GetCWD(){ - char buf[1024]; - if(getcwd(buf, 1024) == NULL){ +std::string GetCWD() { + char buf[PATH_MAX]; + if(getcwd(buf, PATH_MAX) == NULL){ return ""; } return buf; } -std::string GetProcessDir(){ - char buf[1024]; - ssize_t count = readlink("/proc/self/exe", buf, 1024); +std::string GetProcessDir() { + char buf[PATH_MAX]; + ssize_t count = readlink("/proc/self/exe", buf, PATH_MAX); if(count == 0) { return ""; } else{ diff --git a/src/sdk/client_impl.cc b/src/sdk/client_impl.cc index 4a92e1f44..f510f0bce 100644 --- a/src/sdk/client_impl.cc +++ b/src/sdk/client_impl.cc @@ -1189,7 +1189,7 @@ static int SpecifiedFlagfileCount(const std::string& confpath) { static int InitFlags(const std::string& confpath, const std::string& log_prefix) { // search conf file, priority: - // user-specified > ./tera.flag > ../conf/tera.flag + // user-specified > ./tera.flag > ../conf/tera.flag > exeDir/tera.flag > exeDir/../tera.flag std::string flagfile; if (SpecifiedFlagfileCount(confpath) > 1) { LOG(ERROR) << "should specify no more than one config file"; @@ -1220,10 +1220,15 @@ static int InitFlags(const std::string& confpath, const std::string& log_prefix) } else { LOG(ERROR) << "hasn't specify the flagfile, but default config file not found"; return -1; - } + } utils::LoadFlagFile(flagfile); + if(!IsDir(FLAGS_log_dir)) { + LOG(ERROR) << "wrong log directory: "<