forked from hortonworks/hive-testbench
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathtpcds-setup.sh
executable file
·166 lines (140 loc) · 3.8 KB
/
tpcds-setup.sh
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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
#!/bin/bash
function usage {
echo "Usage: tpcds-setup.sh --scale <scale_factor> [--dir <temp_directory>] [--no-part] [--external] [--format <serde_format>]"
exit 1
}
function runcommand {
if [ "X$DEBUG_SCRIPT" != "X" ]; then
$1
else
$1 2>/dev/null
fi
}
which hive > /dev/null 2>&1
if [ $? -ne 0 ]; then
echo "Script must be run where Hive is installed"
exit 1
fi
# Tables in the TPC-DS schema.
DIMS="date_dim time_dim item customer customer_demographics household_demographics customer_address store promotion warehouse ship_mode reason income_band call_center web_page catalog_page web_site"
FACTS="store_sales store_returns web_sales web_returns catalog_sales catalog_returns inventory"
# Defaults
STRATEGY="partitioned"
TYPE="managed"
FORMAT="orc"
while [[ $# -gt 0 ]]; do
case "$1" in
-D*)
APP_JAVA_OPTS="${APP_JAVA_OPTS} ${1}"
shift
;;
--scale)
shift
SCALE=$1
shift
;;
--dir)
shift
DIR=$1
shift
;;
--no-part)
shift
STRATEGY="not_partitioned"
;;
--external)
shift
TYPE="external"
;;
--format)
shift
FORMAT=$1
shift
;;
*)
PRG_ARGS="${PRG_ARGS} \"$1\""
shift
esac
done
# Get the parameters.
#SCALE=$1
#DIR=$2
if [ "X$BUCKET_DATA" != "X" ]; then
BUCKETS=13
RETURN_BUCKETS=13
else
BUCKETS=1
RETURN_BUCKETS=1
fi
if [ "X$DEBUG_SCRIPT" != "X" ]; then
set -x
fi
# Sanity checking.
if [ "X$SCALE" = "X" ]; then
usage
fi
if [ "X$DIR" = "X" ]; then
DIR=/tmp/tpcds-generate
fi
if [ $SCALE -eq 1 ]; then
echo "Scale factor must be greater than 1"
exit 1
fi
if [ "$TYPE" = "external" ]; then
LEGACY="true"
else
LEGACY="false"
fi
# Do the actual data load.
hdfs dfs -mkdir -p ${DIR}
hdfs dfs -ls ${DIR}/${SCALE} > /dev/null
if [ $? -ne 0 ]; then
echo "Run tpcds-gen.sh script first to build base generated data."
exit 1
fi
# Assuming we are running the default hive/beeline connection (beeline-site.xml) and as the user
HIVE="hive"
LOAD_FILE="load_${STRATEGY}_${TYPE}_${FORMAT}_${SCALE}.mk"
SILENCE="2> /dev/null 1> /dev/null"
if [ "X$DEBUG_SCRIPT" != "X" ]; then
SILENCE=""
fi
echo -e "all: ${DIMS} ${FACTS}" > $LOAD_FILE
i=1
total=24
DATABASE=tpcds_bin_${STRATEGY}_${TYPE}_${FORMAT}_${SCALE}
DDL_DIR=bin_${STRATEGY}
echo -e "Running with... "
echo -e " Database: ${DATABASE}"
echo -e " Strategy: ${STRATEGY}"
echo -e " Type: ${TYPE}"
echo -e " FORMAT: ${FORMAT}"
echo -e " SCALE: ${SCALE}"
#DATABASE=tpcds_bin_partitioned_${FORMAT}_${SCALE}
MAX_REDUCERS=2500 # maximum number of useful reducers for any scale
REDUCERS=$((test ${SCALE} -gt ${MAX_REDUCERS} && echo ${MAX_REDUCERS}) || echo ${SCALE})
# Populate the smaller tables.
for t in ${DIMS}
do
COMMAND="$HIVE -i settings/load-partitioned.sql -f ddl-tpcds/bin_${STRATEGY}/${t}.sql \
--hivevar DB=${DATABASE} --hivevar SOURCE=tpcds_text_${SCALE} \
--hivevar SCALE=${SCALE} --hivevar LEGACY=${LEGACY} \
--hivevar REDUCERS=${REDUCERS} \
--hivevar FILE=${FORMAT}"
echo -e "${t}:\n\t@$COMMAND $SILENCE && echo 'Optimizing table $t ($i/$total).'" >> $LOAD_FILE
i=`expr $i + 1`
done
for t in ${FACTS}
do
COMMAND="$HIVE -i settings/load-partitioned.sql -f ddl-tpcds/bin_${STRATEGY}/${t}.sql \
--hivevar DB=${DATABASE} \
--hivevar SCALE=${SCALE} --hivevar LEGACY=${LEGACY} \
--hivevar SOURCE=tpcds_text_${SCALE} --hivevar BUCKETS=${BUCKETS} \
--hivevar RETURN_BUCKETS=${RETURN_BUCKETS} --hivevar REDUCERS=${REDUCERS} --hivevar FILE=${FORMAT}"
echo -e "${t}:\n\t@$COMMAND $SILENCE && echo 'Optimizing table $t ($i/$total).'" >> $LOAD_FILE
i=`expr $i + 1`
done
make -j 1 -f $LOAD_FILE
echo "Loading constraints"
runcommand "$HIVE -f ddl-tpcds/bin_${STRATEGY}/add_constraints.sql --hivevar DB=${DATABASE}"
echo "Data loaded into database ${DATABASE}."