scp-hosts.sh 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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. source ${workDir}/env/install_env.sh
  21. txt=""
  22. if [[ "$OSTYPE" == "darwin"* ]]; then
  23. # Mac OSX
  24. txt="''"
  25. fi
  26. workersGroup=(${workers//,/ })
  27. for workerGroup in ${workersGroup[@]}
  28. do
  29. echo $workerGroup;
  30. worker=`echo $workerGroup|awk -F':' '{print $1}'`
  31. groupsName=`echo $workerGroup|awk -F':' '{print $2}'`
  32. workersGroupMap+=([$worker]=$groupsName)
  33. done
  34. hostsArr=(${ips//,/ })
  35. for host in ${hostsArr[@]}
  36. do
  37. if ! ssh -p $sshPort $host test -e $installPath; then
  38. ssh -p $sshPort $host "sudo mkdir -p $installPath; sudo chown -R $deployUser:$deployUser $installPath"
  39. fi
  40. echo "scp dirs to $host/$installPath starting"
  41. ssh -p $sshPort $host "cd $installPath/; rm -rf bin/ conf/ lib/ script/ sql/ ui/"
  42. for dsDir in bin master-server worker-server alert-server api-server ui
  43. do
  44. # if worker in workersGroupMap
  45. if [[ "${workersGroupMap[${host}]}" ]]; then
  46. echo "export WORKER_GROUPS_0=${workersGroupMap[${host}]}" >> worker-server/bin/dolphinscheduler_env.sh
  47. fi
  48. echo "start to scp $dsDir to $host/$installPath"
  49. # Use quiet mode to reduce command line output
  50. scp -q -P $sshPort -r $workDir/../$dsDir $host:$installPath
  51. done
  52. echo "scp dirs to $host/$installPath complete"
  53. done