[CRIU] [PATCH 03/10] p.haul: adapt p.haul-ssh script to new p.haul usage semantics
Nikita Spiridonov
nspiridonov at odin.com
Fri Oct 9 10:11:35 PDT 2015
Adapt p.haul-ssh script to new semantics since standalone mode was
removed from p.haul (only work over existing connections supported
for now).
Signed-off-by: Nikita Spiridonov <nspiridonov at odin.com>
---
p.haul-ssh | 44 ++++++++++++++++++++++++++++++++------------
1 files changed, 32 insertions(+), 12 deletions(-)
diff --git a/p.haul-ssh b/p.haul-ssh
index 20b7912..d15a5b7 100755
--- a/p.haul-ssh
+++ b/p.haul-ssh
@@ -4,7 +4,9 @@ set -e
# This script is a p.haul wrapper that allows to migrate process
# using ssh tunnel for transferring data and without having to
-# start p.haul-service in advance.
+# start p.haul-service in advance. Script use p.haul-wrap helper script
+# to establish required connections and specify these connections via
+# command line arguments.
#
# This script performs folowing actions:
# 1) Launch p.haul-service on the remote and bind it to localhost:REM_PORT
@@ -25,14 +27,16 @@ REMOTE=""
LOG="/tmp/phs.log"
PH_EXEC="p.haul"
-PH_OPTS=()
+PH_WRAP_EXEC="p.haul-wrap"
+PH_WRAP_OPTS=()
PHS_EXEC="p.haul-service"
-PHS_OPTS=()
+PHS_WRAP_EXEC="p.haul-wrap"
+PHS_WRAP_OPTS=()
usage=\
"SSH wrapper for p.haul\n\
-Usage: p.haul-ssh [SSH_OPTIONS] [PHAUL_OPTIONS]
+Usage: p.haul-ssh [SSH_OPTIONS] [PHAUL_WRAP_OPTIONS]
\n\
SSH options:\n\
--ssh-compression Use compression in ssh tunnel\n\
@@ -41,10 +45,12 @@ SSH options:\n\
--ssh-port SSH port (${PORT} by default)\n\
--ssh-log Logfile for service log\n\
--ssh-ph-exec Path to p.haul executable\n\
+ --ssh-ph-wrap-exec Path to p.haul-wrap executable\n\
--ssh-phs-exec Path to p.haul-service executable on the remote machine\n\
+ --ssh-phs-wrap-exec Path to p.haul-wrap executable on the remote machine\n\
--help Print this messange\n\
\n\
-See p.haul --help for PHAUL_OPTIONS\n"
+See p.haul-wrap --help and p.haul --help for PHAUL_WRAP_OPTIONS\n"
while [ "$1" != "" ]; do
case $1 in
@@ -70,10 +76,18 @@ while [ "$1" != "" ]; do
shift
PH_EXEC=$1
;;
+ "--ssh-ph-wrap-exec")
+ shift
+ PH_WRAP_EXEC=$1
+ ;;
"--ssh-phs-exec")
shift
PHS_EXEC=$1
;;
+ "--ssh-phs-wrap-exec")
+ shift
+ PHS_WRAP_EXEC=$1
+ ;;
"--ssh-port")
shift
PORT=$1
@@ -87,24 +101,30 @@ while [ "$1" != "" ]; do
exit 0
;;
*)
- PH_OPTS+=($1)
+ PH_WRAP_OPTS+=($1)
;;
esac
shift
done
-# Replace p.haul positional "to" option with 127.0.0.1.
-REMOTE=${PH_OPTS[2]}
-PH_OPTS[2]="127.0.0.1"
+# Replace p.haul positional "to" option with 127.0.0.1
+REMOTE=${PH_WRAP_OPTS[0]}
+PH_WRAP_OPTS[0]="127.0.0.1"
# Tell p.haul to connect to the local port
-PH_OPTS+=("--port ${LOC_PORT}")
+PH_WRAP_OPTS+=("--port ${LOC_PORT}")
+
+# Specify path to p.haul executable
+PH_WRAP_OPTS+=("--path ${PH_EXEC}")
# Tell p.haul-service to bind on localhost, so it is not directly accesible
# from the outer web.
PHS_OPTS+=("--bind-port ${REM_PORT}")
PHS_OPTS+=("--bind-addr \"127.0.0.1\"")
+# Specify path to p.haul-service executable
+PHS_WRAP_OPTS+=("--path ${PHS_EXEC}")
+
# Use ssh multiplexing to speedup establishing additional ssh sessions and
# to get control over all of them.
CTL_SK="~/ph_ssh_${USER}_${REMOTE}_${PORT}"
@@ -115,7 +135,7 @@ SSH_BASE="ssh -p ${PORT} ${USER}@${REMOTE} -S ${CTL_SK}"
trap '${SSH_BASE} -S ${CTL_SK} -O exit &> /dev/null' EXIT
echo "Start p.haul-service"
-${SSH_BASE} ${SERVER_FLAGS} ${PHS_EXEC} ${PHS_OPTS[@]} &> ${LOG} < /dev/null
+${SSH_BASE} ${SERVER_FLAGS} ${PHS_WRAP_EXEC} service ${PHS_WRAP_OPTS[@]} &> ${LOG} < /dev/null
echo "Done"
echo "Checking that p.haul-service is started"
@@ -126,5 +146,5 @@ ${SSH_BASE} ${TUNNEL_FLAGS} -L 127.0.0.1:${LOC_PORT}:127.0.0.1:${REM_PORT}
echo "Done"
echo "Launch p.haul"
-${PH_EXEC} ${PH_OPTS[@]}
+${PH_WRAP_EXEC} client ${PH_WRAP_OPTS[@]}
echo "Done"
--
1.7.1
More information about the CRIU
mailing list