install.sh 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. #!/bin/bash
  2. #
  3. # Licensed to the Apache Software Foundation (ASF) under one or more
  4. # contributor license agreements. See the NOTICE file distributed with
  5. # this work for additional information regarding copyright ownership.
  6. # The ASF licenses this file to You under the Apache License, Version 2.0
  7. # (the "License"); you may not use this file except in compliance with
  8. # the License. You may obtain a copy of the License at
  9. #
  10. # http://www.apache.org/licenses/LICENSE-2.0
  11. #
  12. # Unless required by applicable law or agreed to in writing, software
  13. # distributed under the License is distributed on an "AS IS" BASIS,
  14. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. # See the License for the specific language governing permissions and
  16. # limitations under the License.
  17. #
  18. workDir=`dirname $0`
  19. workDir=`cd ${workDir};pwd`
  20. baseDir=`cd ${workDir}/..;pwd`
  21. source ${workDir}/env/install_env.sh
  22. source ${workDir}/env/dolphinscheduler_env.sh
  23. echo "1.create directory"
  24. # If install Path equal to "/" or related path is "/" or is empty, will cause directory "/bin" be overwrite or file adding,
  25. # so we should check its value. Here use command `realpath` to get the related path, and it will skip if your shell env
  26. # without command `realpath`.
  27. if [ ${baseDir} = $installPath ]; then
  28. echo "Fatal: The installPath can not be same as the current path: ${installPath}"
  29. exit 1
  30. elif [ ! -d $installPath ];then
  31. sudo mkdir -p $installPath
  32. sudo chown -R $deployUser:$deployUser $installPath
  33. elif [[ -z "${installPath// }" || "${installPath// }" == "/" || ( $(command -v realpath) && $(realpath -s "${installPath}") == "/" ) ]]; then
  34. echo "Parameter installPath can not be empty, use in root path or related path of root path, currently use ${installPath}"
  35. exit 1
  36. fi
  37. echo "2.scp resources"
  38. bash ${workDir}/scp-hosts.sh
  39. if [ $? -eq 0 ];then
  40. echo 'scp copy completed'
  41. else
  42. echo 'scp copy failed to exit'
  43. exit 1
  44. fi
  45. echo "3.stop server"
  46. bash ${workDir}/stop-all.sh
  47. echo "4.delete zk node"
  48. bash ${workDir}/remove-zk-node.sh $zkRoot
  49. echo "5.startup"
  50. bash ${workDir}/start-all.sh