aboutsummaryrefslogtreecommitdiffstats
path: root/kerl
diff options
context:
space:
mode:
authorJoseph Wayne Norton <[email protected]>2012-05-11 18:12:31 +0900
committerJoseph Wayne Norton <[email protected]>2012-05-12 00:56:41 +0900
commitc46684b1550da8260c8d3d6329685cc9770d6cfe (patch)
tree0746504283f6fb3cc50814942133193afa0d20df /kerl
parenta284ba75b4328d766f7950002eca390cbab64fba (diff)
downloadkerl-c46684b1550da8260c8d3d6329685cc9770d6cfe.tar.gz
kerl-c46684b1550da8260c8d3d6329685cc9770d6cfe.tar.bz2
kerl-c46684b1550da8260c8d3d6329685cc9770d6cfe.zip
Add 'kerl deploy' command to deploy an installation to a given host and directory
Diffstat (limited to 'kerl')
-rwxr-xr-xkerl100
1 files changed, 91 insertions, 9 deletions
diff --git a/kerl b/kerl
index 2f964fd..f2549ee 100755
--- a/kerl
+++ b/kerl
@@ -36,6 +36,12 @@ fi
if [ -n "$KERL_AGNER_AUTOINSTALL" ]; then
_KAA="$KERL_AGNER_AUTOINSTALL"
fi
+if [ -n "$KERL_DEPLOY_SSH_OPTIONS" ]; then
+ _KDSSH="$KERL_DEPLOY_SSH_OPTIONS"
+fi
+if [ -n "$KERL_DEPLOY_RSYNC_OPTIONS" ]; then
+ _KDRSYNC="$KERL_DEPLOY_RSYNC_OPTIONS"
+fi
KERL_CONFIGURE_OPTIONS=
KERL_DISABLE_AGNER=
KERL_SASL_STARTUP=
@@ -56,6 +62,12 @@ fi
if [ -n "$_KAA" ]; then
KERL_AGNER_AUTOINSTALL="$_KAA"
fi
+if [ -n "$_KDSSH" ]; then
+ KERL_DEPLOY_SSH_OPTIONS="$_KDSSH"
+fi
+if [ -n "$_KDRSYNC" ]; then
+ KERL_DEPLOY_RSYNC_OPTIONS="$_KDRSYNC"
+fi
if [ -z "$KERL_SASL_STARTUP" ]; then
INSTALL_OPT=-minimal
@@ -85,6 +97,7 @@ usage()
echo "Valid commands are:"
echo " build Build specified release or git repository"
echo " install Install the specified release at the given location"
+ echo " deploy Deploy the specified installation to the given host and location"
echo " update Update agner or the list of available releases from erlang.org"
echo " list List releases, builds and installations"
echo " delete Delete builds and installations"
@@ -201,6 +214,15 @@ is_valid_installation()
return 1
}
+assert_valid_installation()
+{
+ if ! is_valid_installation $1; then
+ echo "$1 is not a kerl-managed Erlang/OTP installation"
+ exit 1
+ fi
+ return 0
+}
+
do_update_agner()
{
rel=`get_release_from_name $1`
@@ -462,6 +484,55 @@ ACTIVATE
echo "kerl_deactivate"
}
+do_deploy()
+{
+ if [ -z "$1" ]; then
+ echo "No host given"
+ exit 1
+ fi
+ host=$1
+
+ assert_valid_installation "$2"
+ rel=`get_name_from_install_path "$2"`
+ path=$2
+ remotepath=$path
+
+ if [ ! -z "$3" ]; then
+ remotepath=$3
+ fi
+
+ ssh $KERL_DEPLOY_SSH_OPTIONS $host true > /dev/null 2>&1
+ if [ $? -ne 0 ]; then
+ echo "Couldn't ssh to $host"
+ exit 1
+ fi
+
+ echo "Cloning Erlang/OTP $rel ($path) to $host ($remotepath) ..."
+
+ rsync -aqz -e "ssh $KERL_DEPLOY_SSH_OPTIONS" $KERL_DEPLOY_RSYNC_OPTIONS "$path/" "$host:$remotepath/"
+ if [ $? -ne 0 ]; then
+ echo "Couldn't rsync Erlang/OTP $rel ($path) to $host ($remotepath)"
+ exit 1
+ fi
+
+ ssh $KERL_DEPLOY_SSH_OPTIONS $host "cd \"$remotepath\" && env ERL_TOP=\`pwd\` ./Install $INSTALL_OPT \`pwd\` > /dev/null 2>&1"
+ if [ $? -ne 0 ]; then
+ echo "Couldn't install Erlang/OTP $rel to $host ($remotepath)"
+ exit 1
+ fi
+
+ ssh $KERL_DEPLOY_SSH_OPTIONS $host "cd \"$remotepath\" && sed -i -e \"s#$path#\`pwd\`#g\" activate"
+ if [ $? -ne 0 ]; then
+ echo "Couldn't completely install Erlang/OTP $rel to $host ($remotepath)"
+ exit 1
+ fi
+
+ echo "On $host, you can activate this installation running the following command:"
+ echo ". $remotepath/activate"
+ echo "Later on, you can leave the installation typing:"
+ echo "kerl_deactivate"
+}
+
list_print()
{
if [ -f $KERL_BASE_DIR/otp_$1 ]; then
@@ -600,6 +671,21 @@ case "$1" in
fi
fi
;;
+ deploy)
+ if [ $# -lt 2 ]; then
+ echo "usage: $0 $1 <[user@]host> [directory] [remote_directory]"
+ exit 1
+ fi
+ if [ $# -eq 4 ]; then
+ do_deploy $2 "$3" "$4"
+ else
+ if [ $# -eq 3 ]; then
+ do_deploy $2 "$3"
+ else
+ do_deploy $2 .
+ fi
+ fi
+ ;;
update)
if [ $# -lt 2 ]; then
update_usage
@@ -675,15 +761,11 @@ case "$1" in
fi
;;
installation)
- if is_valid_installation "$3"; then
- rm -Rf "$3"
- escaped=`echo "$3" | sed $SED_OPT -e 's#/$##' -e 's#\/#\\\/#g'`
- list_remove $2s "$escaped"
- echo "The installation in $3 has been deleted"
- else
- echo "$3 is not a kerl-managed Erlang/OTP installation"
- exit 1
- fi
+ assert_valid_installation "$3"
+ rm -Rf "$3"
+ escaped=`echo "$3" | sed $SED_OPT -e 's#/$##' -e 's#\/#\\\/#g'`
+ list_remove $2s "$escaped"
+ echo "The installation in $3 has been deleted"
;;
*)
echo "Cannot delete $2"