source: TOOLS/PACK_IPSL/archive_restart.sh @ 1723

Last change on this file since 1723 was 1709, checked in by acosce, 12 years ago

Add tool pack used for ccrt/tgcc migration

File size: 5.5 KB
Line 
1#!/bin/bash
2
3
4#on veut archiver les fichiers restart
5#Dans le cadre du demenagement ils seront renommes
6#ATM/Restart/****.nc
7#OCE/Restart/****.nc
8#...
9#sous la forme
10#RESTART/ATM_****.nc
11#RESTART/OCE_****.nc
12#Attention de bien conserver les dates d'origines
13#
14#Dans le cadre de la production nouvelle chaine
15#ils auront directement le bon nom
16#
17#On veut egalement que l'archive soit par periode de temps
18# cette periode est definie par la taille du pack donc connue
19# en entree du script (1M, 1Y, 5Y, 10Y etc...)
20#
21
22
23# $1= PATH/config_card d'une simulation avec
24# TagName/JobName/ExperimentName/SpaceName/DateBegin/DateEnd/PATH_SIMUL
25# $2=period_pack en M/m ou Y/y
26
27config_card=${1}
28LISTE_DMNFS=${2}
29
30
31export JOB_DIR=${JOB_DIR:-${PWD}}
32export IGCM_DEM=${IGCM_DEM:-${SCRATCHDIR}/IGCM_DEM}
33export IGCM_TMP=${IGCM_TMP:-${IGCM_DEM}/tmp}
34mkdir -p ${IGCM_DEM}
35mkdir -p ${IGCM_TMP}
36clean_tmp=${clean_tmp:-yes}
37EXE_DIR=$(dirname ${0})
38SCRIPT_NAME=$(basename ${0} )
39
40source ${EXE_DIR}/DEM_utilities.sh
41
42DEM_log -0 "Demarrage de ${SCRIPT_NAME}"
43
44
45#### 0- lecture de config.card
46#### on veut les renseignements suivants :
47#### JobName, PATH_SIMUL, DateBegin et DateEnd
48eval $(grep JobName ${config_card}) 
49eval $(grep PATH_SIMUL_FULL ${config_card}) 
50eval $(grep DateBegin ${config_card}) 
51eval $(grep DateEnd ${config_card}) 
52eval $(grep IGCM_DEM_SIMU ${config_card})
53
54
55#### Preparation de l'environnement
56# repertoire dans lequel seront crees les archives
57STORE_RESTART=$IGCM_DEM_SIMU/Restart
58mkdir -p ${STORE_RESTART}
59
60# lecture de periodpack dans ${IGCM_DEM_SIMU}/period_pack.txt
61period_pack=`awk '{print $0} ' ${IGCM_DEM_SIMU}/period_pack.txt`
62
63#### 1- renommer les fichiers ######
64DEM_log -1 "Renommer les fichiers de Restart"
65
66cd ${STORE_RESTART}
67rm -rf *
68
69# On les copie sur le scratchdir en changeant le nom et conservant la date
70grep ${PATH_SIMUL_FULL} ${LISTE_DMNFS} | grep Restart | awk '{print $3}' | sed '/^.*Restart$/d' >> ${IGCM_DEM_SIMU}/liste_restart_files.txt
71
72
73#awk -F/ '{dest_name=$(NF-2)("_") $(NF);
74#   system("cp --preserve " $0 " "dest_name)}' ${IGCM_DEM_SIMU}/liste_restart_files.txt
75 
76gawk -F/ '{dest_name=$(NF-2)("_") $(NF); system("ln -s " $0 " "dest_name)}' ${IGCM_DEM_SIMU}/liste_restart_files.txt
77
78ls -l ${STORE_RESTART} > ${IGCM_DEM_SIMU}/new_liste_restart_files.txt
79
80### 2- creer les listes de fichiers par periode ####
81DEM_log -1 "Creation des listes de fichiers par periode"
82### 2.1- extraire l'annee et le mois de DateBegin ###
83date_begin=${DateBegin}
84date_end=${DateEnd}
85
86year_begin=$(echo ${date_begin} | cut -c 1-4 )
87month_begin=$(echo ${date_begin} | cut -c 5-6 )
88year_end=$(echo ${date_end} | cut -c 1-4 )
89month_end=$(echo ${date_end} | cut -c 5-6 )
90
91
92### 2.2- creation des listes ###
93date_begin_pack=${date_begin}
94date_end_simulation=${date_end}
95
96month_begin_pack=${month_begin}
97year_begin_pack=${year_begin}
98
99number_pack=1
100
101while [ ${date_begin_pack} -le ${date_end_simulation} ]
102do
103
104DEM_log -1 "On calcule la date de fin du pack "
105
106   month_end_pack=${month_begin_pack}
107   year_end_pack=`expr ${year_begin_pack} + ${period_pack}`
108
109   if [ ${month_end_pack} -le 9 ] 
110   then
111      date_end_pack=${year_end_pack}0${month_end_pack}01
112   fi
113   if [ ${month_end_pack} -gt 9 ] 
114   then
115      date_end_pack=${year_end_pack}${month_end_pack}01   
116   fi
117
118 
119   for file in `awk '{print $9}' ${IGCM_DEM_SIMU}/new_liste_restart_files.txt`; do
120   
121     extract_date_file=`echo ${file}  | sed -e "s/.*\${JobName}_//"`
122     date_file=`echo ${extract_date_file}| sed 's/\([0-9]\{8\}\)_.*$/\1/g'`
123
124
125     echo pack n°${number_pack}  ${date_file} ${date_begin_pack} ${date_end_pack} 
126     if [  ${date_file} -lt ${date_end_pack} ]
127     then
128        if [ ${date_file} -ge ${date_begin_pack} ]
129        then
130           echo ${file} >> ${IGCM_TMP}/${$}.liste_pack_restart_${number_pack}.txt
131        fi
132     fi
133   
134   done
135
136#on archive les restart - le nom de l'archive contiendra ${yearbegin}${monthbegin}_${yearend}${monthend}
137# end etant la date du dernier fichier contenu et non pas la premiere date suivant
138DEM_log -1 "Recherche de la date de fin reel pour nommer l'archive "
139#On classe par ordre alphabetique les fichiers contenus dans liste_pack_restart
140#la date du dernier fichier donnera la date de fin du pack
141   sort ${IGCM_TMP}/${$}.liste_pack_restart_${number_pack}.txt > ${IGCM_TMP}/${$}.liste_pack_restart_${number_pack}.txt.tmp
142   last_file=$(tail -n 1 ${IGCM_TMP}/${$}.liste_pack_restart_${number_pack}.txt.tmp )
143   extract_date_file=$( echo ${last_file}  | sed -e "s/.*${JobName}_//" )
144   echo ${extract_date_file}
145   DateEnd_Restart=$(   echo ${extract_date_file}| sed 's/\([0-9]\{8\}\)_.*$/\1/g' )
146   echo ${DateEnd_Restart}
147   mv ${IGCM_TMP}/${$}.liste_pack_restart_${number_pack}.txt.tmp ${IGCM_DEM_SIMU}/liste_pack_restart_${date_begin_pack}_${DateEnd_Restart}.txt
148
149
150DEM_log -1 "Passage de la commande Tar pour archiver la liste creee"
151   tar -cf ${JobName}_${date_begin_pack}_${DateEnd_Restart}_restart.tar --dereference  --files-from ${IGCM_DEM_SIMU}/liste_pack_restart_${date_begin_pack}_${DateEnd_Restart}.txt
152#   cat  ${IGCM_DEM_SIMU}/liste_pack_restart_${number_pack}.txt | xargs rm
153
154
155DEM_log -1 "On defini le datebegin de la  prochaine periode pack"
156#on defini la periode pack suivante
157   month_begin_pack=${month_end_pack}
158   year_begin_pack=${year_end_pack}
159
160   if [ ${month_begin_pack} -le 9 ]
161   then
162      date_begin_pack=${year_begin_pack}0${month_begin_pack}01
163   fi
164   if [ ${month_begin_pack} -gt 9 ]
165   then
166      date_begin_pack=${year_begin_pack}${month_begin_pack}01
167   fi
168
169
170   number_pack=`expr ${number_pack} + 1`
171
172done
173
174
175
Note: See TracBrowser for help on using the repository browser.