Subversion Repositories SmartDukaan

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2217 rajveer 1
#!/bin/bash
2
 
3
# resolve links - $0 may be a softlink
4
PRG="$0"
5
 
6
while [ -h "$PRG" ]; do
7
  ls=`ls -ld "$PRG"`
8
  link=`expr "$ls" : '.*-> \(.*\)$'`
9
  if expr "$link" : '/.*' > /dev/null; then
10
    PRG="$link"
11
  else
12
    PRG=`dirname "$PRG"`/"$link"
13
  fi
14
done
15
 
16
# Get standard environment variables
17
PRGDIR=`dirname $(readlink -f "$PRG")`
18
 
19
PROJECT_DIR="`dirname ${PRGDIR}`"
20
LOG_DIR="/var/log/content-generation"
21
DATE=`date +%Y-%b-%d-%Hh%Mm%Ss`
22
MYSQL_DUMP="${PRGDIR}/partial-catalog-${DATE}.sql"
23
CONTENT_LOG="${LOG_DIR}/content-generation-${DATE}.log"
24
COMPARISON_LOG="${LOG_DIR}/comparison-score-computation-${DATE}.log"
25
PRODUCT_LIST_LOG="${LOG_DIR}/product-list-${DATE}.log"
26
IR_LOG="${LOG_DIR}/irdata-generation-${DATE}.log"
27
SOLR_IRDATA=/var/lib/tomcat6/webapps/export/solr/irdata_solr
28
 
29
STAGING_SERVER="192.168.138.69"
30
STAGING_ENTITIES_EXPORT_PATH="entities-shop2020"
31
 
32
PROD_SERVER="192.168.141.43"
33
PROD_ENTITIES_EXPORT_PATH="entities-saholic"
34
 
35
STATIC_SERVER="173.230.151.179"
36
 
37
ENTITIES_DEST_PATH="/var/lib/tomcat6/webapps/export/html/entities.tgz"
38
 
39
MAVEN_REPO="${HOME}/.m2/repository"
40
M2_CLASSPATH="${MAVEN_REPO}/in/shop2020/ContentStore/1.0-SNAPSHOT/ContentStore-1.0-SNAPSHOT.jar:${MAVEN_REPO}/in/shop2020/ThriftConfig/1.0-SNAPSHOT/ThriftConfig-1.0-SNAPSHOT.jar:${MAVEN_REPO}/in/shop2020/Common/1.0-SNAPSHOT/Common-1.0-SNAPSHOT.jar:${MAVEN_REPO}/readonly/apache/velocity/1.6.3/velocity-1.6.3.jar:${MAVEN_REPO}/readonly/apache/commons-lang/2.4/commons-lang-2.4.jar:${MAVEN_REPO}/readonly/apache/commons-collections/3.2.1/commons-collections-3.2.1.jar:${MAVEN_REPO}/readonly/apache/thrift/0.2.0/thrift-0.2.0.jar:${MAVEN_REPO}/readonly/slf4j/slf4j-api/1.5.8/slf4j-api-1.5.8.jar:${MAVEN_REPO}/readonly/slf4j/slf4j-simple/1.5.8/slf4j-simple-1.5.8.jar:${MAVEN_REPO}/readonly/apache/commons-logging-api/1.1/commons-logging-api-1.1.jar:${MAVEN_REPO}/readonly/bdb/je/4.1.7/je-4.1.7.jar:${MAVEN_REPO}/readonly/jython/2.5.1/jython-2.5.1.jar:${MAVEN_REPO}/commons-cli/commons-cli/1.2/commons-cli-1.2.jar:${MAVEN_REPO}/readonly/apache/commons-io/1.3.2/commons-io-1.3.2.jar"
41
 
42
echo "Stopping tomcat at `date +%c`"
43
echo "======================================================="
44
/etc/init.d/tomcat6 stop
45
 
46
echo "Generating the icons and thumbnails for all Entitites"
47
echo "======================================================="
48
cd /var/lib/tomcat6/webapps/db/media/
49
python2.6 ImageConverter.py default.jpg icon.jpg 120 120
50
python2.6 ImageConverter.py default.jpg thumbnail.jpg 60 60
51
echo "Icons and thumbnails generated"
52
echo "======================================================="
53
 
54
 
55
echo "Generating content for one entities ${PROJECT_DIR}"
56
echo "======================================================="
57
cd ${PROJECT_DIR}/ContentStore
58
java -cp ${M2_CLASSPATH}  in.shop2020.util.ContentGenerationUtility -t ALL > ${CONTENT_LOG} 
59
echo "======================================================="
60
echo "Content generation completed"
61
 
62
echo "Generating content for partners"
63
echo "======================================================="
64
cd ${PROJECT_DIR}/ContentStore
65
java -cp ${M2_CLASSPATH}  in.shop2020.util.ProductListGenerator > ${PRODUCT_LIST_LOG}
66
echo "Content generation for partners completed"
67
echo "======================================================="
68
 
69
/etc/init.d/tomcat6 start
70
/etc/init.d/apache2 restart
71
echo "Tomcat restarted at `date +%c`"
72
 
73
echo "Dumping item, vendoritemmapping and vendoritempricing tables to be imported on staging and production servers"
74
echo "======================================================="
75
cd ${PRGDIR}
76
mysqldump -uroot -pshop2020 catalog --tables item vendoritemmapping vendoritempricing > ${MYSQL_DUMP}
77
 
78
echo "Copying generated content to staging and production servers"
79
echo "======================================================="
80
#Update media content on both staging and production
81
cd /var/lib/tomcat6/webapps/export
82
rm -f media.tgz
83
mv media media-${DATE}; tar -zcf media.tgz media-${DATE}; mv media-${DATE} media
84
scp media.tgz ${STAGING_SERVER}:/var/lib/tomcat6/webapps/export/
85
scp media.tgz ${PROD_SERVER}:/var/lib/tomcat6/webapps/export/
86
scp media.tgz ${STATIC_SERVER}:/var/www/
87
 
2230 rajveer 88
rm -f javascripts.tgz
89
mv javascripts javascripts-${DATE}; tar -zcf javascripts.tgz partners-${DATE}; mv javascripts-${DATE} javascripts
90
scp javascripts.tgz ${STAGING_SERVER}:/var/lib/tomcat6/webapps/export/
91
scp javascripts.tgz ${PROD_SERVER}:/var/lib/tomcat6/webapps/export/
92
scp javascripts.tgz ${STATIC_SERVER}:/var/www
93
 
2217 rajveer 94
#Update entities on staging using the entities-shop2020 direcotry
95
#Update entities on production using the entities-saholic directory
96
cd /var/lib/tomcat6/webapps/export/html
97
rm -f ${STAGING_ENTITIES_EXPORT_PATH}.tgz ${PROD_ENTITIES_EXPORT_PATH}.tgz
98
mv ${STAGING_ENTITIES_EXPORT_PATH} entities-${DATE}
99
tar -zcf ${STAGING_ENTITIES_EXPORT_PATH}.tgz entities-${DATE}
100
mv entities-${DATE} ${STAGING_ENTITIES_EXPORT_PATH}
101
 
102
mv ${PROD_ENTITIES_EXPORT_PATH} entities-${DATE}
103
tar -zcf ${PROD_ENTITIES_EXPORT_PATH}.tgz entities-${DATE}
104
mv entities-${DATE} ${PROD_ENTITIES_EXPORT_PATH}
105
 
106
scp ${STAGING_ENTITIES_EXPORT_PATH}.tgz ${STAGING_SERVER}:${ENTITIES_DEST_PATH}
107
scp ${PROD_ENTITIES_EXPORT_PATH}.tgz ${PROD_SERVER}:${ENTITIES_DEST_PATH}
108
 
109
#Update product list data on staging and production servers
110
cd /var/lib/tomcat6/webapps/export
111
rm -f partners.tgz
112
mv partners partners-${DATE}; tar -zcf partners.tgz partners-${DATE}; mv partners-${DATE} partners
113
scp partners.tgz ${STAGING_SERVER}:/var/lib/tomcat6/webapps/export/
114
scp partners.tgz ${PROD_SERVER}:/var/lib/tomcat6/webapps/export/
115
scp partners.tgz ${STATIC_SERVER}:/var/www
116
 
117
#Update solr data on staging and production servers
118
scp ${SOLR_IRDATA}.xml ${STAGING_SERVER}:${SOLR_IRDATA}-${DATE}.xml
119
scp ${SOLR_IRDATA}.xml ${PROD_SERVER}:${SOLR_IRDATA}-${DATE}.xml
120
 
121
#Put mysql dump on staging and production servers
122
scp ${MYSQL_DUMP} ${STAGING_SERVER}:/catalog-dumps
123
scp ${MYSQL_DUMP} ${PROD_SERVER}:/catalog-dumps
124
 
125
ssh ${STAGING_SERVER} "echo ${DATE}>/catalog-dumps/latest.timestamp"
126
ssh ${PROD_SERVER} "echo ${DATE}>/catalog-dumps/latest.timestamp"
127
ssh ${STATIC_SERVER} "echo ${DATE}>/catalog-dumps/latest.timestamp"
128
 
129
echo "Done copying content to staging and production servers"
130
echo "======================================================="