Використовуйте pgrepзамість цього:
pgrep -cxu $USER -f my-tool
Використовувані варіанти:
-c, --count
Suppress normal output; instead print a count of matching pro‐
cesses. When count does not match anything, e.g. returns zero,
the command will return non-zero value.
-x, --exact
Only match processes whose names (or command line if -f is spec‐
ified) exactly match the pattern.
-u, --euid euid,...
Only match processes whose effective user ID is listed. Either
the numerical or symbolical value may be used.
Якщо ви хочете використовувати це в скрипті bash, який перевіряє, чи він вже запущений, ви можете використовувати $0. Це розширюється до шляху поточного сценарію (наприклад /home/username/bin/foo.sh), але нам це потрібно лише foo.sh. Для того, щоб отримати , що ми можемо видалити все до останнього , /використовуючи в Bash маніпуляції рядки інструментів : ${0##*/}. Це означає, що ми можемо зробити щось на кшталт:
## If there are more than 1 instances of the current script run
## by this user
if [[ $(pgrep -cxu "$USER" "${0##*/}") -gt 1 ]];
then
echo "Script already running, exiting."
exit
fi
Ви також можете розглянути можливість використання для цього замкових файлів:
## If the lock file exists
if [ -e /tmp/$USER.foo.lock ]; then
## Check if the PID in the lockfile is a running instance
## of foo.sh to guard against crashed scripts
if ps $(cat /tmp/$USER.foo.lock) | grep foo.sh >/dev/null; then
echo "Script foo.sh is already running, exiting"
exit
else
echo "Lockfile contains a stale PID, continuing"
rm /tmp/$USER.foo.lock
fi
fi
## Create the lockfile by printing the script's PID into it
echo $$ > /tmp/$USER.foo.lock
## Rest of the script here
## At the end, delete the lockfile
rm /tmp/$USER.foo.lock
pidof, є кращі інструменти брешутьpgrep