don't need these scripts
This commit is contained in:
parent
fae66957f9
commit
122806997a
2 changed files with 0 additions and 169 deletions
|
@ -1,107 +0,0 @@
|
|||
#!/bin/sh
|
||||
|
||||
##
|
||||
# This software was developed and / or modified by Raytheon Company,
|
||||
# pursuant to Contract DG133W-05-CQ-1067 with the US Government.
|
||||
#
|
||||
# U.S. EXPORT CONTROLLED TECHNICAL DATA
|
||||
# This software product contains export-restricted data whose
|
||||
# export/transfer/disclosure is restricted by U.S. law. Dissemination
|
||||
# to non-U.S. persons whether in the United States or abroad requires
|
||||
# an export license or other authorization.
|
||||
#
|
||||
# Contractor Name: Raytheon Company
|
||||
# Contractor Address: 6825 Pine Street, Suite 340
|
||||
# Mail Stop B8
|
||||
# Omaha, NE 68106
|
||||
# 402.291.0100
|
||||
#
|
||||
# See the AWIPS II Master Rights File ("Master Rights File.pdf") for
|
||||
# further licensing information.
|
||||
##
|
||||
|
||||
# SOFTWARE HISTORY
|
||||
# Date Ticket# Engineer Description
|
||||
# ------------ ---------- ----------- --------------------------
|
||||
# Feb 12, 2008 jelkins - Initial creation
|
||||
|
||||
# remotely execute remote_program on local files
|
||||
remote_program=$(basename $0)
|
||||
|
||||
# USAGE
|
||||
# Create a link to this script. The link name should be the name of the remote
|
||||
# program to execute on the remote_machine. Modify the workspace_dir and
|
||||
# remote_machine variables below as needed.
|
||||
|
||||
# The first time a program is remotely executed, this script will automatically
|
||||
# generate the keys needed to perform password-less connections between the
|
||||
# local machine and the remote machine and vice versa. The remote machine
|
||||
# password will only need to be entered once.
|
||||
|
||||
# remote_machine is the network address of the machine on which the
|
||||
# remote_program is setup. remote_user is the username to log into the
|
||||
# remote_machine as.
|
||||
remote_machine="awips-nis"
|
||||
remote_user="$USER"
|
||||
|
||||
# workspace_dir is the location on the local machine which should be mounted
|
||||
# remotely. The default value of "$HOME" assumes the files required by the
|
||||
# remote_program are someplace in the $HOME directory. If the files reside
|
||||
# outside of the $HOME directory change $HOME to reflect the correct location.
|
||||
workspace_dir=$(readlink -f $HOME)
|
||||
|
||||
# local_mahchine is the local machine's ip address. local_machine should not
|
||||
# need changing unless the network interface is not eth0 or the line below fails
|
||||
# to determine the correct ip address.
|
||||
local_machine=$(/sbin/ifconfig eth0 | grep "inet" | sed 's/.*addr:\([^ ]*\).*/\1/')
|
||||
|
||||
# local_id is the pattern that will uniquely identify the local_machine and
|
||||
# user. The mount pattern and root should not need to be changed.
|
||||
local_id="$USER@$local_machine"
|
||||
mount_root=".remote_execute"
|
||||
|
||||
# remote_mount_point is the location on the remote machine where the workspace_dir
|
||||
# will be mounted. There should be no need to change this variable.
|
||||
remote_mount_point="$mount_root/$local_id"
|
||||
|
||||
if [ "$remote_machine" = "$local_mahchine" ]
|
||||
then
|
||||
$remote_program $@
|
||||
else
|
||||
|
||||
remote_id="$remote_user@$remote_machine"
|
||||
local_key_file="$HOME/$mount_root/keys/$remote_id"
|
||||
remote_key_file="$mount_root/keys/$local_id"
|
||||
|
||||
if [ ! -e "$local_key_file" ]
|
||||
then
|
||||
echo "Setting up execution of $remote_program on $remote_machine as $remote_user"
|
||||
|
||||
# --- local key setup ---
|
||||
mkdir -p $(dirname $local_key_file)
|
||||
ssh-keygen -t rsa -f $local_key_file -N ""
|
||||
chmod 600 $local_key_file.pub
|
||||
ssh-copy-id -i $local_key_file.pub $remote_id
|
||||
|
||||
# --- remote key setup ---
|
||||
ssh -i $local_key_file $remote_id << TO_HERE
|
||||
mkdir -p \$(dirname $remote_key_file)
|
||||
ssh-keygen -t rsa -f \$HOME/$remote_key_file -N ""
|
||||
chmod 600 \$HOME/$remote_key_file.pub
|
||||
TO_HERE
|
||||
ssh -t -i $local_key_file $remote_id ssh-copy-id -i \$HOME/$remote_key_file.pub $local_id
|
||||
|
||||
fi
|
||||
|
||||
# --- mount workspace_dir and execute remote_program ---
|
||||
ssh -i $local_key_file $remote_id sh << TO_HERE
|
||||
|
||||
mkdir -p ~/$remote_mount_point
|
||||
sshfs -o IdentityFile="~/$remote_key_file" $USER@$local_machine:$workspace_dir ~/$remote_mount_point 2> /dev/null
|
||||
cd ~/$remote_mount_point$(readlink -f $(pwd) | sed "s|$workspace_dir||")
|
||||
$remote_program $@
|
||||
|
||||
TO_HERE
|
||||
fi
|
||||
|
||||
|
|
@ -1,62 +0,0 @@
|
|||
#!/bin/sh
|
||||
|
||||
##
|
||||
# This software was developed and / or modified by Raytheon Company,
|
||||
# pursuant to Contract DG133W-05-CQ-1067 with the US Government.
|
||||
#
|
||||
# U.S. EXPORT CONTROLLED TECHNICAL DATA
|
||||
# This software product contains export-restricted data whose
|
||||
# export/transfer/disclosure is restricted by U.S. law. Dissemination
|
||||
# to non-U.S. persons whether in the United States or abroad requires
|
||||
# an export license or other authorization.
|
||||
#
|
||||
# Contractor Name: Raytheon Company
|
||||
# Contractor Address: 6825 Pine Street, Suite 340
|
||||
# Mail Stop B8
|
||||
# Omaha, NE 68106
|
||||
# 402.291.0100
|
||||
#
|
||||
# See the AWIPS II Master Rights File ("Master Rights File.pdf") for
|
||||
# further licensing information.
|
||||
##
|
||||
|
||||
# SOFTWARE HISTORY
|
||||
# Date Ticket# Engineer Description
|
||||
# ------------ ---------- ----------- --------------------------
|
||||
# Feb 16, 2008 jelkins - Initial creation
|
||||
|
||||
# waits until the program is not in use before executing it
|
||||
|
||||
# USAGE
|
||||
# Create a link to this script. The link name should be the name of the program
|
||||
# to execute as a single instance and should be placed into a directory located
|
||||
# one directory above the location of the actual program.
|
||||
|
||||
lockfile="/tmp/$(basename $0).tmp.lock"
|
||||
program_location=($(which -a $(basename $0)))
|
||||
|
||||
# critical section checking
|
||||
# http://www.davidpashley.com/articles/writing-robust-shell-scripts.html
|
||||
while [ 1 ]
|
||||
do
|
||||
if ( set -o noclobber; echo "$USER on PID $$" > "$lockfile") 2> /dev/null;
|
||||
then
|
||||
trap 'rm -f "$lockfile"' INT TERM EXIT
|
||||
|
||||
${program_location[1]} $@
|
||||
error_code=$?
|
||||
|
||||
rm -f "$lockfile"
|
||||
trap - INT TERM EXIT
|
||||
exit $error_code
|
||||
else
|
||||
lock_id="$(cat $lockfile)"
|
||||
if [ ! "$lock_id" = "$prev_lock_id" ]
|
||||
then
|
||||
echo "Failed to acquire lockfile: $lockfile."
|
||||
echo "Held by $lock_id"
|
||||
echo "Waiting to acquire lockfile ..."
|
||||
prev_lock_id="$lock_id"
|
||||
fi
|
||||
fi
|
||||
done
|
Loading…
Add table
Reference in a new issue