| #!/bin/bash |
| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you under the Apache License, Version 2.0 (the |
| # "License"); you may not use this file except in compliance |
| # with the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, |
| # software distributed under the License is distributed on an |
| # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| # KIND, either express or implied. See the License for the |
| # specific language governing permissions and limitations |
| # under the License. |
| |
| source $(dirname $0)/pack_common.sh |
| |
| function usage() { |
| echo "Options for subcommand 'pack_server':" |
| echo " -h" |
| echo " -p|--update-package-template <minos-package-template-file-path>" |
| echo " -g|--custom-gcc" |
| echo " -k|--keytab-file" |
| exit 0 |
| } |
| |
| pwd="$(cd "$(dirname "$0")" && pwd)" |
| shell_dir="$(cd $pwd/.. && pwd)" |
| cd "$shell_dir" || exit 1 |
| |
| if [ ! -f src/include/pegasus/git_commit.h ]; then |
| echo "ERROR: src/include/pegasus/git_commit.h not found" |
| exit 1 |
| fi |
| |
| if [ ! -f DSN_ROOT/bin/pegasus_server/pegasus_server ]; then |
| echo "ERROR: DSN_ROOT/bin/pegasus_server/pegasus_server not found" |
| exit 1 |
| fi |
| |
| if [ ! -f src/builder/CMAKE_OPTIONS ]; then |
| echo "ERROR: src/builder/CMAKE_OPTIONS not found" |
| exit 1 |
| fi |
| |
| if grep -q Debug src/builder/CMAKE_OPTIONS; then |
| build_type=debug |
| else |
| build_type=release |
| fi |
| version=$(grep "VERSION" src/include/pegasus/version.h | cut -d "\"" -f 2) |
| commit_id=$(grep "GIT_COMMIT" src/include/pegasus/git_commit.h | cut -d "\"" -f 2) |
| glibc_ver=$(ldd --version | grep ldd | grep -Eo "[0-9]+.[0-9]+$") |
| echo "Packaging pegasus server $version ($commit_id) glibc-$glibc_ver $build_type ..." |
| |
| pack_version=server-$version-${commit_id:0:7}-glibc${glibc_ver}-${build_type} |
| pack=pegasus-$pack_version |
| |
| if [ -f ${pack}.tar.gz ]; then |
| rm -f ${pack}.tar.gz |
| fi |
| |
| if [ -d ${pack} ]; then |
| rm -rf ${pack} |
| fi |
| |
| pack_template="" |
| if [ -n "$MINOS_CONFIG_FILE" ]; then |
| pack_template=$(dirname $MINOS_CONFIG_FILE)/xiaomi-config/package/pegasus.yaml |
| fi |
| |
| custom_gcc="false" |
| keytab_file="" |
| |
| while [[ $# > 0 ]]; do |
| option_key="$1" |
| case $option_key in |
| -p | --update-package-template) |
| pack_template="$2" |
| shift |
| ;; |
| -g | --custom-gcc) |
| custom_gcc="true" |
| ;; |
| -h | --help) |
| usage |
| ;; |
| -k | --keytab-file) |
| keytab_file="$2" |
| shift |
| ;; |
| esac |
| shift |
| done |
| |
| mkdir -p ${pack}/bin |
| copy_file ./DSN_ROOT/bin/pegasus_server/pegasus_server ${pack}/bin |
| copy_file ./DSN_ROOT/lib/libdsn_meta_server.so ${pack}/bin |
| copy_file ./DSN_ROOT/lib/libdsn_replica_server.so ${pack}/bin |
| copy_file ./DSN_ROOT/lib/libdsn_utils.so ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libPoco*.so.48 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libtcmalloc_and_profiler.so.4 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libboost*.so.1.69.0 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libhdfs* ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libsasl2.so.3 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libcom_err.so.3 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libgssapi_krb5.so.2 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libkrb5support.so.0 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libkrb5.so.3 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/libk5crypto.so.3 ${pack}/bin |
| copy_file ./rdsn/thirdparty/output/lib/sasl2 ${pack}/bin |
| copy_file ./scripts/sendmail.sh ${pack}/bin |
| copy_file ./src/server/config.ini ${pack}/bin |
| copy_file ./src/server/config.min.ini ${pack}/bin |
| copy_file ./config_hdfs.sh ${pack}/bin |
| |
| copy_file "$(get_stdcpp_lib $custom_gcc)" "${pack}/bin" |
| |
| pack_server_lib() { |
| pack_system_lib "${pack}/bin" server "$1" |
| } |
| |
| pack_server_lib snappy |
| pack_server_lib crypto |
| pack_server_lib ssl |
| pack_server_lib zstd |
| pack_server_lib lz4 |
| |
| # Pack hadoop-related files. |
| # If you want to use hdfs service to backup/restore/bulkload pegasus tables, |
| # you need to set env ${HADOOP_HOME}, edit ${HADOOP_HOME}/etc/hadoop/core-site.xml, |
| # and specify the keytab file. |
| if [ -n "$HADOOP_HOME" ] && [ -n "$keytab_file" ]; then |
| mkdir -p ${pack}/hadoop |
| copy_file $keytab_file ${pack}/hadoop |
| copy_file ${HADOOP_HOME}/etc/hadoop/core-site.xml ${pack}/hadoop |
| if [ -d $HADOOP_HOME/share/hadoop ]; then |
| for f in ${HADOOP_HOME}/share/hadoop/common/lib/*.jar; do |
| copy_file $f ${pack}/hadoop |
| done |
| for f in ${HADOOP_HOME}/share/hadoop/common/*.jar; do |
| copy_file $f ${pack}/hadoop |
| done |
| for f in ${HADOOP_HOME}/share/hadoop/hdfs/lib/*.jar; do |
| copy_file $f ${pack}/hadoop |
| done |
| for f in ${HADOOP_HOME}/share/hadoop/hdfs/*.jar; do |
| copy_file $f ${pack}/hadoop |
| done |
| fi |
| else |
| echo "Couldn't find env ${HADOOP_HOME} or no valid keytab file was specified, |
| hadoop-related files were not packed." |
| fi |
| |
| DISTRIB_ID=$(cat /etc/*-release | grep DISTRIB_ID | awk -F'=' '{print $2}') |
| DISTRIB_RELEASE=$(cat /etc/*-release | grep DISTRIB_RELEASE | awk -F'=' '{print $2}') |
| if [ -n "$DISTRIB_ID" ] && [ -n "$DISTRIB_RELEASE" ]; then |
| if [ "$DISTRIB_ID" == "Ubuntu" ] && [ "$DISTRIB_RELEASE" == "18.04" ]; then |
| pack_system_lib icui18n |
| pack_system_lib icuuc |
| pack_system_lib icudata |
| fi |
| # more cases can be added here. |
| fi |
| |
| chmod +x ${pack}/bin/pegasus_* ${pack}/bin/*.sh |
| chmod -x ${pack}/bin/lib* |
| |
| echo "Pegasus Server $version ($commit_id) $platform $build_type" >${pack}/VERSION |
| |
| tar cfz ${pack}.tar.gz ${pack} |
| |
| if [ -f $pack_template ]; then |
| echo "Modifying $pack_template ..." |
| sed -i "/^version:/c version: \"$pack_version\"" $pack_template |
| sed -i "/^build:/c build: \"\.\/run.sh pack\"" $pack_template |
| sed -i "/^source:/c source: \"$PEGASUS_ROOT\"" $pack_template |
| fi |
| |
| echo ${pack} >PACKAGE |
| |
| echo "Done" |