summaryrefslogtreecommitdiff
path: root/additional/persist.sh
blob: ef4fb516ba5665d5fdc9a029b5aa7c086f77f97a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#!/bin/bash

# Script to automatically fetch and clean data on the Grid'5000 shares
# Params: 
# 1: Name for the experiment
# 2: Additional plot tar to include (see ./plots)

set -e

function work_in_progress() {
  echo -ne '\r\033[K'
  sleep 1
  echo -ne '.\r'
  sleep 1
  echo -ne '..\r'
  sleep 1
  echo -ne '...\r'
  sleep 1
}

function backup() {
  if [ -z ${1} ]; then
    echo "Missing experiment name"
    exit 1
  fi
  if [ -z ${2} ]; then
    echo "No plots will be included"
  else
    echo "The file '${2}' will be deleted when this script finishes, do you want to contiue? [y/n]" 
    while true; do
      read -n 1 -s yn
      case $yn in
        [Yy]*) break 2;;
        [Nn]*) exit ;;
        *) echo "Please enter 'y' or 'n'" ;;
      esac
    done
  fi

  # Slugify the name
  NAME=$(\
    echo "$1" | \
    sed -r s/[~\^]+//g | \
    sed -r s/[^a-zA-Z0-9]+/-/g | \
    sed -r s/^-+\|-+$//g | \
    tr A-Z a-z \
  )
  BACKUP_NAME="${NAME}-$(date +%d-%m-%y).tar"
  BACKUP_DIR="archives"
  
  G5K_BACKUP="g5k-$(date +%s).tar.gz"
  
  echo "Creating archive, this can take some time"
  ssh g5k 'rm -rf grenoble/g5k.tar* && find . -maxdepth 1 -type l -exec tar --ignore-failed-read -rf grenoble/g5k.tar -C {} exp-logs exp-data espec-times 2>&1 \; | grep -vi "no such file"' &
  
  PID=$!
  while kill -0 $PID > /dev/null 2>&1; do
    work_in_progress
  done
  
  echo "Compressing archive, this may take some time"
  ssh g5k 'gzip grenoble/g5k.tar' &
  
  PID=$!
  while kill -0 $PID > /dev/null 2>&1; do
    work_in_progress
  done
  
  echo "Copying archive to local machine"
  scp g5k:~/grenoble/g5k.tar.gz ${G5K_BACKUP}
  
  test -d ${BACKUP_DIR} || mkdir ${BACKUP_DIR}
  
  echo "Creating Backup Tar ${BACKUP_DIR}/${BACKUP_NAME}"
  tar -cvf ${BACKUP_DIR}/${BACKUP_NAME} ${G5K_BACKUP} ${2} &
  
  PID=$!
  while kill -0 $PID > /dev/null 2>&1; do
    work_in_progress
  done
  
  rm ${G5K_BACKUP} ${2}
}

function delete() {
  echo "Cleaning up g5k storage"
  ssh g5k 'rm grenoble/g5k.tar.gz || true && $(find . -type l -exec rm -rf {}/exp-logs/ {}/exp-data {}/espec-times \;)' &
  
  PID=$!
  while kill -0 $PID > /dev/null 2>&1; do
    work_in_progress
  done
}

echo "
Make sure that:

- Your ssh key to access the grid is added to the ssh-agent with 'ssh-add <KEY>'
- The config to access the grid is setup as described in:
  https://www.grid5000.fr/w/SSH#Using_SSH_ProxyCommand_feature_to_ease_the_access_to_hosts_inside_Grid.275000
"

if [[ $(ssh-add -L) =~ "The agent has no" ]]; then
  echo "No ssh key added, aborting"
  exit 1
fi
  
  
case $1 in
  -b|--backup)
    backup $2 $3
    ;;
  -d|--delete)
    delete
    ;;
  *)
    echo "Usage: ./persist.sh <OPTIONS>"
    echo ""
    echo "OPTIONS:"
    echo " -b | --backup <experiment-name> <addtitional-plot-archive>"
    echo "    backup exp-data, exp-logs and espec-times from g5k NFS"
    echo " -d | --delete"
    echo "    delete exp-data, exp-logs and espec-times from g5k NFS"
    ;;
esac