当程序需要由git仓下载代码时,一般可以使用两种方式:其一是每次执行程序git仓下载的目录不一样,这种方法比较适合git仓内容比较小的场景;其二就是有一个公共目录用来下载git仓代码,当git仓存在时我们只需要git pull更新代码就行,当代码仓很大时使用这种方法能节省程序运行时间和存储空间。
但是当多个用户同时使用git pull更新同一个代码仓时只有一个用户成功其他用户会出现失败的情况,这时就需要制定一个方法,当有用户在执行git pull操作时其他用户先进入等待状态,待git pull完成后下一个用户在进行git pull操作。
可以把这种方式称为git_locked,参考实现代码如下
#!/bin/bash
make_git_locked()
{
for (( wait_time=0;wait_time<180;wait_time++ ))
do
#判断之前的locked是否没有释放
if [ -f /tmp/git_locked ];then
git_pid=$(cat /tmp/git_locked)
ps aux |grep ${git_pid}|grep -v grep|grep test.sh
if [ $? -ne 0 ];then
rm -rf /tmp/git_locked
fi
fi
if [ ! -f /tmp/git_locked ];then
echo $$ > /tmp/git_locked
return 0
else
sleep 1
echo "others is git pull now,wait a minute"
fi
done
return 1
}
git_pull()
{
#更新前上锁
make_git_locked
if [ $? -ne 0 ];then
echo "ERROR:make_git_locked failed!!"
return 1
fi
pushd /home/Sudley/git_dir/
git pull origin
if [ $? -ne 0 ];then
echo "ERROR:git pull failed!!"
return 1
fi
#更新结束去锁
if [ -f /tmp/git_locked ];then
rm -rf /tmp/git_locked
fi
popd
}
git_pull