#!/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. # Only one lock is allowed: biglock # getLockFile() parameters # $1 lock filename # $2 timeout seconds getLockFile() { __locked=0 __LOCKFILE="/tmp/$1-$$.lock" if [ $2 ] then __TIMEOUT=$2 else __TIMEOUT=30 fi if [ -e $__LOCKFILE ] then logger -t cloud "Process $0 pid $$ want to get ECLUSIVE LOCK $1 RECURSIVELY!" psline=`ps u $$` logger -t cloud "Failed job detail: $psline" echo 0 return fi psline=`ps u $$` echo $psline > $__LOCKFILE for i in `seq 1 $(($__TIMEOUT * 10))` do currlock=`ls -tr /tmp/$1-*.lock | head -n1` if [ $currlock -ef $__LOCKFILE ] then __locked=1 break fi sleep 0.1 if [ $((i % 10)) -eq 0 ] then logger -t cloud "Process $0 pid $$ waiting for the lock $1 for another 1 second" fi done if [ $__locked -ne 1 ] then logger -t cloud "fail to acquire the lock $1 for process $0 pid $$ after $__TIMEOUT seconds time out!" cmd=`cat $currlock` logger -t cloud "waiting for command: $cmd" psline=`ps u $$` logger -t cloud "Failed job detail: $psline" rm $__LOCKFILE fi echo $__locked } # releaseLockFile() parameters # $1 lock filename # $2 locked(1) or not(0) releaseLockFile() { __LOCKFILE="/tmp/$1-$$.lock" __locked=$2 if [ "$__locked" == "1" ] then rm $__LOCKFILE fi } # releaseLockFile() parameters # $1 exit value # $2 lock filename # $3 locked(1) or not(0) unlock_exit() { releaseLockFile $2 $3 exit $1 }