workaround for cp not having the -l option on Solaris and OS X: SOLR-282

git-svn-id: https://svn.apache.org/repos/asf/lucene/solr/trunk@555612 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
William Au 2007-07-12 12:35:01 +00:00
parent 1fec553e28
commit 7a7d05c27b
9 changed files with 101 additions and 24 deletions

View File

@ -131,14 +131,19 @@ then
logExit failed 1 logExit failed 1
fi fi
# check status of commit request # check status of commit request - original format
echo $rs | grep '<result.*status="0"' > /dev/null 2>&1 echo $rs | grep '<result.*status="0"' > /dev/null 2>&1
if [[ $? != 0 ]] if [[ $? != 0 ]]
then
# check status of commit request - new format
echo $rs | grep '<lst name="responseHeader"><int name="status">0</int>' > /dev/null 2>&1
if [[ $? != 0 ]]
then then
logMessage commit request to Solr at ${curl_url} failed: logMessage commit request to Solr at ${curl_url} failed:
logMessage $rs logMessage $rs
logExit failed 2 logExit failed 2
fi fi
fi
# successful commit creates a snapshot file synchronously # successful commit creates a snapshot file synchronously
lastsnap=`ls -drt1 ${data_dir}/snapshot.* 2> /dev/null | tail -1 ` lastsnap=`ls -drt1 ${data_dir}/snapshot.* 2> /dev/null | tail -1 `
@ -170,7 +175,16 @@ trap 'echo cleaning up, please wait ...;/bin/rm -rf ${data_dir}/${name} ${data_d
# make a backup using hard links into temporary location # make a backup using hard links into temporary location
# then move it into place atomically # then move it into place atomically
if [[ "${OS}" == "SunOS" || "${OS}" == "Darwin" ]]
then
orig_dir=$(pwd)
mkdir ${data_dir}/${temp}
cd ${lastsnap}
find . -print|cpio -pdlmu ${data_dir}/${temp} 1>/dev/null 2>&1
cd ${orig_dir}
else
cp -lr ${lastsnap} ${data_dir}/${temp} cp -lr ${lastsnap} ${data_dir}/${temp}
fi
mv ${data_dir}/${temp} ${data_dir}/${name} mv ${data_dir}/${temp} ${data_dir}/${name}
logExit ended 0 logExit ended 0

View File

@ -131,14 +131,19 @@ then
logExit failed 1 logExit failed 1
fi fi
# check status of optimize request # check status of optimize request - original format
echo $rs | grep '<result.*status="0"' > /dev/null 2>&1 echo $rs | grep '<result.*status="0"' > /dev/null 2>&1
if [[ $? != 0 ]] if [[ $? != 0 ]]
then
# check status of optimize request - new format
echo $rs | grep '<lst name="responseHeader"><int name="status">0</int>' > /dev/null 2>&1
if [[ $? != 0 ]]
then then
logMessage optimize request to Solr at ${curl_url} failed: logMessage optimize request to Solr at ${curl_url} failed:
logMessage $rs logMessage $rs
logExit failed 2 logExit failed 2
fi fi
fi
# successful optimize creates a snapshot file synchronously # successful optimize creates a snapshot file synchronously
lastsnap=`ls -drt1 ${data_dir}/snapshot.* | tail -1 ` lastsnap=`ls -drt1 ${data_dir}/snapshot.* | tail -1 `
@ -170,7 +175,16 @@ trap 'echo cleaning up, please wait ...;/bin/rm -rf ${data_dir}/${name} ${data_d
# make a backup using hard links into temporary location # make a backup using hard links into temporary location
# then move it into place atomically # then move it into place atomically
if [[ "${OS}" == "SunOS" || "${OS}" == "Darwin" ]]
then
orig_dir=$(pwd)
mkdir ${data_dir}/${temp}
cd ${lastsnap}
find . -print|cpio -pdlmu ${data_dir}/${temp} 1>/dev/null 2>&1
cd ${orig_dir}
else
cp -lr ${lastsnap} ${data_dir}/${temp} cp -lr ${lastsnap} ${data_dir}/${temp}
fi
mv ${data_dir}/${temp} ${data_dir}/${name} mv ${data_dir}/${temp} ${data_dir}/${name}
logExit ended 0 logExit ended 0

View File

@ -101,7 +101,16 @@ logMessage making backup ${data_dir}/${name}
# make a backup using hard links into temporary location # make a backup using hard links into temporary location
# then move it into place atomically # then move it into place atomically
if [[ "${OS}" == "SunOS" || "${OS}" == "Darwin" ]]
then
orig_dir=$(pwd)
mkdir ${data_dir}/${temp}
cd ${data_dir}/index
find . -print|cpio -pdlmu ${data_dir}/${temp} 1>/dev/null 2>&1
cd ${orig_dir}
else
cp -lr ${data_dir}/index ${data_dir}/${temp} cp -lr ${data_dir}/index ${data_dir}/${temp}
fi
mv ${data_dir}/${temp} ${data_dir}/${name} mv ${data_dir}/${temp} ${data_dir}/${name}
logExit ended 0 logExit ended 0

View File

@ -116,13 +116,18 @@ then
logExit failed 1 logExit failed 1
fi fi
# check status of commit request # check status of commit request - original format
echo $rs | grep '<result.*status="0"' > /dev/null 2>&1 echo $rs | grep '<result.*status="0"' > /dev/null 2>&1
if [[ $? != 0 ]] if [[ $? != 0 ]]
then
# check status of commit request - new format
echo $rs | grep '<lst name="responseHeader"><int name="status">0</int>' > /dev/null 2>&1
if [[ $? != 0 ]]
then then
logMessage commit request to Solr at ${curl_url} failed: logMessage commit request to Solr at ${curl_url} failed:
logMessage $rs logMessage $rs
logExit failed 2 logExit failed 2
fi fi
fi
logExit ended 0 logExit ended 0

View File

@ -117,13 +117,18 @@ then
logExit failed 1 logExit failed 1
fi fi
# check status of optimize request # check status of optimize request - original format
rc=`echo $rs|cut -f2 -d'"'` rc=`echo $rs|cut -f2 -d'"'`
if [[ $? != 0 ]] if [[ $? != 0 ]]
then
# check status of optimize request - new format
echo $rs | grep '<lst name="responseHeader"><int name="status">0</int>' > /dev/null 2>&1
if [[ $? != 0 ]]
then then
logMessage optimize request to Solr at ${curl_url} failed: logMessage optimize request to Solr at ${curl_url} failed:
logMessage $rs logMessage $rs
logExit failed 2 logExit failed 2
fi fi
fi
logExit ended 0 logExit ended 0

View File

@ -21,6 +21,7 @@ export PATH=/sbin:/usr/sbin:/bin:/usr/bin:$PATH
# set up variables # set up variables
prog=${0##*/} prog=${0##*/}
OS=`uname`
# source the config file if present # source the config file if present
confFile=${solr_root}/conf/scripts.conf confFile=${solr_root}/conf/scripts.conf

View File

@ -141,9 +141,20 @@ fi
# install using hard links into temporary directory # install using hard links into temporary directory
# remove original index and then atomically copy new one into place # remove original index and then atomically copy new one into place
logMessage installing snapshot ${name} logMessage installing snapshot ${name}
if [[ "${OS}" == "SunOS" || "${OS}" == "Darwin" ]]
then
orig_dir=$(pwd)
mkdir ${data_dir}/index.tmp$$ && \
cd ${name} && \
find . -print|cpio -pdlmu ${data_dir}/index.tmp$$ 1>/dev/null 2>&1 && \
/bin/rm -rf ${data_dir}/index && \
mv -f ${data_dir}/index.tmp$$ ${data_dir}/index
cd ${orig_dir}
else
cp -lr ${name}/ ${data_dir}/index.tmp$$ && \ cp -lr ${name}/ ${data_dir}/index.tmp$$ && \
/bin/rm -rf ${data_dir}/index && \ /bin/rm -rf ${data_dir}/index && \
mv -f ${data_dir}/index.tmp$$ ${data_dir}/index mv -f ${data_dir}/index.tmp$$ ${data_dir}/index
fi
# update distribution stats # update distribution stats
echo ${name} > ${solr_root}/logs/snapshot.current echo ${name} > ${solr_root}/logs/snapshot.current

View File

@ -200,7 +200,16 @@ fi
# take a snapshot of current index so that only modified files will be rsync-ed # take a snapshot of current index so that only modified files will be rsync-ed
# put the snapshot in the 'work-in-progress" directory to prevent it from # put the snapshot in the 'work-in-progress" directory to prevent it from
# being installed while the copying is still in progress # being installed while the copying is still in progress
if [[ "${OS}" == "SunOS" || "${OS}" == "Darwin" ]]
then
orig_dir=$(pwd)
mkdir ${data_dir}/${name}-wip
cd ${data_dir}/index
find . -print|cpio -pdlmu ${data_dir}/${name}-wip 1>/dev/null 2>&1
cd ${orig_dir}
else
cp -lr ${data_dir}/index ${data_dir}/${name}-wip cp -lr ${data_dir}/index ${data_dir}/${name}-wip
fi
# force rsync of segments and .del files since we are doing size-only # force rsync of segments and .del files since we are doing size-only
if [[ -n ${sizeonly} ]] if [[ -n ${sizeonly} ]]
then then

View File

@ -102,7 +102,16 @@ logMessage taking snapshot ${name}
# take a snapshot using hard links into temporary location # take a snapshot using hard links into temporary location
# then move it into place atomically # then move it into place atomically
if [[ "${OS}" == "SunOS" || "${OS}" == "Darwin" ]]
then
orig_dir=$(pwd)
mkdir ${temp}
cd ${data_dir}/index
find . -print|cpio -pdlmu ${temp} 1>/dev/null 2>&1
cd ${orig_dir}
else
cp -lr ${data_dir}/index ${temp} cp -lr ${data_dir}/index ${temp}
fi
mv ${temp} ${name} mv ${temp} ${name}
logExit ended 0 logExit ended 0