-
-
Notifications
You must be signed in to change notification settings - Fork 81
/
Copy pathbuild.sh
executable file
·339 lines (289 loc) · 13.7 KB
/
build.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
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
#!/bin/bash
set -e
# default to build Release
build_type=${1:-Release}
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
. ${DIR}/vars.sh
BUILD_DIR=${PROJ_DIR}/buildlib
HDFS="-DENABLE_HDFS=1 -DENABLE_GSASL_LIBRARY=1 -DENABLE_KRB5=1"
MYSQL="-DENABLE_MYSQL=1"
# check current os type
if [ "$(uname)" == "Darwin" ]; then
export CXX=/usr/local/opt/llvm/bin/clang++
export CC=/usr/local/opt/llvm/bin/clang
export PATH=/usr/local/opt/llvm/bin:$PATH
GLIBC_COMPATIBILITY="-DGLIBC_COMPATIBILITY=0"
UNWIND="-DUSE_UNWIND=0"
JEMALLOC="-DENABLE_JEMALLOC=0"
PYINIT_ENTRY="-Wl,-exported_symbol,_PyInit_${CHDB_PY_MOD}"
HDFS="-DENABLE_HDFS=0 -DENABLE_GSASL_LIBRARY=0 -DENABLE_KRB5=0"
MYSQL="-DENABLE_MYSQL=0"
ICU="-DENABLE_ICU=0"
SED_INPLACE="sed -i ''"
# if Darwin ARM64 (M1, M2), disable AVX
if [ "$(uname -m)" == "arm64" ]; then
CMAKE_TOOLCHAIN_FILE="-DCMAKE_TOOLCHAIN_FILE=cmake/darwin/toolchain-aarch64.cmake"
CPU_FEATURES="-DENABLE_AVX=0 -DENABLE_AVX2=0"
LLVM="-DENABLE_EMBEDDED_COMPILER=0 -DENABLE_DWARF_PARSER=0"
else
LLVM="-DENABLE_EMBEDDED_COMPILER=1 -DENABLE_DWARF_PARSER=1"
# disable AVX on Darwin for macos11
if [ "$(sw_vers -productVersion | cut -d. -f1)" -le 11 ]; then
CPU_FEATURES="-DENABLE_AVX=0 -DENABLE_AVX2=0"
else
# for M1, M2 using x86_64 emulation, we need to disable AVX and AVX2
CPU_FEATURES="-DENABLE_AVX=0 -DENABLE_AVX2=0"
# # If target macos version is 12, we need to test if support AVX2,
# # because some Mac Pro Late 2013 (MacPro6,1) support AVX but not AVX2
# # just test it on the github action, hope you don't using Mac Pro Late 2013.
# # https://everymac.com/mac-answers/macos-12-monterey-faq/macos-monterey-macos-12-compatbility-list-system-requirements.html
# if [ "$(sysctl -n machdep.cpu.leaf7_features | grep AVX2)" != "" ]; then
# CPU_FEATURES="-DENABLE_AVX=1 -DENABLE_AVX2=1"
# else
# CPU_FEATURES="-DENABLE_AVX=1 -DENABLE_AVX2=0"
# fi
fi
fi
elif [ "$(uname)" == "Linux" ]; then
GLIBC_COMPATIBILITY="-DGLIBC_COMPATIBILITY=1"
UNWIND="-DUSE_UNWIND=1"
JEMALLOC="-DENABLE_JEMALLOC=1"
PYINIT_ENTRY="-Wl,-ePyInit_${CHDB_PY_MOD}"
ICU="-DENABLE_ICU=1"
SED_INPLACE="sed -i"
# only x86_64, enable AVX, enable embedded compiler
if [ "$(uname -m)" == "x86_64" ]; then
CPU_FEATURES="-DENABLE_AVX=1 -DENABLE_AVX2=0"
LLVM="-DENABLE_EMBEDDED_COMPILER=1 -DENABLE_DWARF_PARSER=1"
else
CPU_FEATURES="-DENABLE_AVX=0 -DENABLE_AVX2=0 -DNO_ARMV81_OR_HIGHER=1"
LLVM="-DENABLE_EMBEDDED_COMPILER=0 -DENABLE_DWARF_PARSER=0"
fi
else
echo "OS not supported"
exit 1
fi
if [ ! -d $BUILD_DIR ]; then
mkdir $BUILD_DIR
fi
cd ${BUILD_DIR}
CMAKE_ARGS="-DCMAKE_BUILD_TYPE=${build_type} -DENABLE_THINLTO=0 -DENABLE_TESTS=0 -DENABLE_CLICKHOUSE_SERVER=0 -DENABLE_CLICKHOUSE_CLIENT=0 \
-DENABLE_CLICKHOUSE_KEEPER=0 -DENABLE_CLICKHOUSE_KEEPER_CONVERTER=0 -DENABLE_CLICKHOUSE_LOCAL=1 -DENABLE_CLICKHOUSE_SU=0 -DENABLE_CLICKHOUSE_BENCHMARK=0 \
-DENABLE_AZURE_BLOB_STORAGE=1 -DENABLE_CLICKHOUSE_COPIER=0 -DENABLE_CLICKHOUSE_DISKS=0 -DENABLE_CLICKHOUSE_FORMAT=0 -DENABLE_CLICKHOUSE_GIT_IMPORT=0 \
-DENABLE_AWS_S3=1 -DENABLE_HIVE=0 -DENABLE_AVRO=1 \
-DENABLE_CLICKHOUSE_OBFUSCATOR=0 -DENABLE_CLICKHOUSE_ODBC_BRIDGE=0 -DENABLE_CLICKHOUSE_STATIC_FILES_DISK_UPLOADER=0 \
-DENABLE_KAFKA=1 -DENABLE_LIBPQXX=1 -DENABLE_NATS=0 -DENABLE_AMQPCPP=0 -DENABLE_NURAFT=0 \
-DENABLE_CASSANDRA=0 -DENABLE_ODBC=0 -DENABLE_NLP=0 \
-DENABLE_LDAP=0 \
${MYSQL} \
${HDFS} \
-DENABLE_LIBRARIES=0 -DENABLE_RUST=0 \
${GLIBC_COMPATIBILITY} \
-DENABLE_UTILS=0 ${LLVM} ${UNWIND} \
${ICU} -DENABLE_UTF8PROC=1 ${JEMALLOC} \
-DENABLE_PARQUET=1 -DENABLE_ROCKSDB=1 -DENABLE_SQLITE=1 -DENABLE_VECTORSCAN=1 \
-DENABLE_PROTOBUF=1 -DENABLE_THRIFT=1 -DENABLE_MSGPACK=1 \
-DENABLE_BROTLI=1 -DENABLE_H3=1 -DENABLE_CURL=1 \
-DENABLE_CLICKHOUSE_ALL=0 -DUSE_STATIC_LIBRARIES=1 -DSPLIT_SHARED_LIBRARIES=0 \
-DENABLE_SIMDJSON=1 -DENABLE_RAPIDJSON=1 \
${CPU_FEATURES} \
${CMAKE_TOOLCHAIN_FILE} \
-DENABLE_AVX512=0 -DENABLE_AVX512_VBMI=0 \
-DENABLE_LIBFIU=1 \
-DCHDB_VERSION=${CHDB_VERSION} \
"
# # Generate libchdb.so linkage command:
# # 1. Use ar to delete the LocalChdb.cpp.o from libclickhouse-local-lib.a
# # `ar d programs/local/libclickhouse-local-lib.a LocalChdb.cpp.o`
# # 2. Change the entry point from `PyInit_chdb` to `query_stable`
# # `-Wl,-ePyInit_chdb` to `-Wl,-equery_stable` on Linux
# # `-Wl,-exported_symbol,_PyInit_${CHDB_PY_MOD}` to
# # `-Wl,-exported_symbol,_query_stable -Wl,-exported_symbol,_free_result` on Darwin
# # 3. Change the output file name from `_chdb.cpython-xx-x86_64-linux-gnu.s` to `libchdb.so`
# # `-o _chdb.cpython-39-x86_64-linux-gnu.so` to `-o libchdb.so`
# # 4. Write the command to a file for debug
# # 5. Run the command to generate libchdb.so
# # Remove object from archive and save it to a new archive like:
# # path/to/oldname.a -> path/to/oldname-nopy.a
# remove_obj_from_archive() {
# local archive=$1
# local obj=$2
# local new_archive=$(echo ${archive} | sed 's/\.a$/-nopy.a/')
# cp -a ${archive} ${new_archive}
# ${AR} d ${new_archive} ${obj}
# echo "Old archive: ${archive}"
# ls -l ${archive}
# echo "New archive: ${new_archive}"
# ls -l ${new_archive}
# local oldfile=$(basename ${archive})
# local newfile=$(basename ${new_archive})
# LIBCHDB_CMD=$(echo ${LIBCHDB_CMD} | sed "s/${oldfile}/${newfile}/g")
# ${SED_INPLACE} "s/${oldfile}/${newfile}/g" CMakeFiles/libchdb.rsp
# }
# # Step 1, 2, 3:
# # Backup the libclickhouse-local-lib.a and restore it after ar d
# # LIBCHDB_SO="libchdb.so"
# # CLEAN_CHDB_A="libclickhouse-local-chdb.a"
# # cp -a ${BUILD_DIR}/programs/local/libclickhouse-local-lib.a ${BUILD_DIR}/programs/local/libclickhouse-local-lib.a.bak
# # ${AR} d ${BUILD_DIR}/programs/local/libclickhouse-local-lib.a LocalChdb.cpp.o
# # mv ${BUILD_DIR}/programs/local/libclickhouse-local-lib.a ${BUILD_DIR}/programs/local/${CLEAN_CHDB_A}
# # mv ${BUILD_DIR}/programs/local/libclickhouse-local-lib.a.bak ${BUILD_DIR}/programs/local/libclickhouse-local-lib.a
# # ls -l ${BUILD_DIR}/programs/local/
# LIBCHDB_SO="libchdb.so"
# LIBCHDB_CMD=${PYCHDB_CMD}
# if [ "${build_type}" == "Debug" ]; then
# remove_obj_from_archive ${BUILD_DIR}/programs/local/libclickhouse-local-libd.a LocalChdb.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/libdbmsd.a StoragePython.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/libdbmsd.a PythonSource.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/libclickhouse_common_iod.a PythonUtils.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/TableFunctions/libclickhouse_table_functionsd.a TableFunctionPython.cpp.o
# else
# remove_obj_from_archive ${BUILD_DIR}/programs/local/libclickhouse-local-lib.a LocalChdb.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/libdbms.a StoragePython.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/libdbms.a PythonSource.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/libclickhouse_common_io.a PythonUtils.cpp.o
# remove_obj_from_archive ${BUILD_DIR}/src/TableFunctions/libclickhouse_table_functions.a TableFunctionPython.cpp.o
# fi
LIBCHDB_SO="libchdb.so"
# Build libchdb.so
cmake ${CMAKE_ARGS} -DENABLE_PYTHON=0 ..
ninja -d keeprsp
BINARY=${BUILD_DIR}/programs/clickhouse
echo -e "\nBINARY: ${BINARY}"
ls -lh ${BINARY}
echo -e "\nldd ${BINARY}"
${LDD} ${BINARY}
rm -f ${BINARY}
cd ${BUILD_DIR}
ninja -d keeprsp -v > build.log || true
USING_RESPONSE_FILE=$(grep -m 1 'clang++.*-o programs/clickhouse .*' build.log | grep '@CMakeFiles/clickhouse.rsp' || true)
if [ ! "${USING_RESPONSE_FILE}" == "" ]; then
if [ -f CMakeFiles/clickhouse.rsp ]; then
cp -a CMakeFiles/clickhouse.rsp CMakeFiles/libchdb.rsp
else
echo "CMakeFiles/clickhouse.rsp not found"
exit 1
fi
fi
LIBCHDB_CMD=$(grep -m 1 'clang++.*-o programs/clickhouse .*' build.log \
| sed "s/-o programs\/clickhouse/-fPIC -shared -o ${LIBCHDB_SO}/" \
| sed 's/^[^&]*&& //' | sed 's/&&.*//' \
| sed 's/ -Wl,-undefined,error/ -Wl,-undefined,dynamic_lookup/g' \
| sed 's/ -Xlinker --no-undefined//g' \
| sed 's/@CMakeFiles\/clickhouse.rsp/@CMakeFiles\/libchdb.rsp/g' \
)
# generate the command to generate libchdb.so
LIBCHDB_CMD=$(echo ${LIBCHDB_CMD} | sed 's/ '${CHDB_PY_MODULE}'/ '${LIBCHDB_SO}'/g')
if [ ! "${USING_RESPONSE_FILE}" == "" ]; then
${SED_INPLACE} 's/ '${CHDB_PY_MODULE}'/ '${LIBCHDB_SO}'/g' CMakeFiles/libchdb.rsp
fi
if [ "$(uname)" == "Linux" ]; then
LIBCHDB_CMD=$(echo ${LIBCHDB_CMD} | sed 's/ '${PYINIT_ENTRY}'/ /g')
if [ ! "${USING_RESPONSE_FILE}" == "" ]; then
${SED_INPLACE} 's/ '${PYINIT_ENTRY}'/ /g' CMakeFiles/libchdb.rsp
fi
fi
if [ "$(uname)" == "Darwin" ]; then
LIBCHDB_CMD=$(echo ${LIBCHDB_CMD} | sed 's/ '${PYINIT_ENTRY}'/ -Wl,-exported_symbol,_query_stable -Wl,-exported_symbol,_free_result -Wl,-exported_symbol,_query_stable_v2 -Wl,-exported_symbol,_free_result_v2/g')
# ${SED_INPLACE} 's/ '${PYINIT_ENTRY}'/ -Wl,-exported_symbol,_query_stable -Wl,-exported_symbol,_free_result -Wl,-exported_symbol,_query_stable_v2 -Wl,-exported_symbol,_free_result_v2/g' CMakeFiles/libchdb.rsp
fi
LIBCHDB_CMD=$(echo ${LIBCHDB_CMD} | sed 's/@CMakeFiles\/clickhouse.rsp/@CMakeFiles\/libchdb.rsp/g')
# Step 4:
# save the command to a file for debug
echo ${LIBCHDB_CMD} > libchdb_cmd.sh
# Step 5:
${LIBCHDB_CMD}
LIBCHDB_DIR=${BUILD_DIR}/
LIBCHDB=${LIBCHDB_DIR}/${LIBCHDB_SO}
ls -lh ${LIBCHDB}
# build chdb python module
cmake ${CMAKE_ARGS} -DENABLE_PYTHON=1 ..
ninja -d keeprsp || true
# del the binary and run ninja -v again to capture the command, then modify it to generate CHDB_PY_MODULE
/bin/rm -f ${BINARY}
cd ${BUILD_DIR}
ninja -d keeprsp -v > build.log || true
USING_RESPONSE_FILE=$(grep -m 1 'clang++.*-o programs/clickhouse .*' build.log | grep '@CMakeFiles/clickhouse.rsp' || true)
if [ ! "${USING_RESPONSE_FILE}" == "" ]; then
if [ -f CMakeFiles/clickhouse.rsp ]; then
cp -a CMakeFiles/clickhouse.rsp CMakeFiles/pychdb.rsp
else
echo "CMakeFiles/clickhouse.rsp not found"
exit 1
fi
fi
# extract the command to generate CHDB_PY_MODULE
PYCHDB_CMD=$(grep -m 1 'clang++.*-o programs/clickhouse .*' build.log \
| sed "s/-o programs\/clickhouse/-fPIC -Wl,-undefined,dynamic_lookup -shared ${PYINIT_ENTRY} -o ${CHDB_PY_MODULE}/" \
| sed 's/^[^&]*&& //' | sed 's/&&.*//' \
| sed 's/ -Wl,-undefined,error/ -Wl,-undefined,dynamic_lookup/g' \
| sed 's/ -Xlinker --no-undefined//g' \
| sed 's/@CMakeFiles\/clickhouse.rsp/@CMakeFiles\/pychdb.rsp/g' \
)
# # inplace modify the CMakeFiles/pychdb.rsp
# ${SED_INPLACE} 's/-o programs\/clickhouse/-fPIC -Wl,-undefined,dynamic_lookup -shared ${PYINIT_ENTRY} -o ${CHDB_PY_MODULE}/' CMakeFiles/pychdb.rsp
# ${SED_INPLACE} 's/ -Wl,-undefined,error/ -Wl,-undefined,dynamic_lookup/g' CMakeFiles/pychdb.rsp
# ${SED_INPLACE} 's/ -Xlinker --no-undefined//g' CMakeFiles/pychdb.rsp
if [ "$(uname)" == "Linux" ]; then
# remove src/CMakeFiles/clickhouse_malloc.dir/Common/stubFree.c.o
PYCHDB_CMD=$(echo ${PYCHDB_CMD} | sed 's/ src\/CMakeFiles\/clickhouse_malloc.dir\/Common\/stubFree.c.o//g')
# put -Wl,-wrap,malloc ... after -DUSE_JEMALLOC=1
PYCHDB_CMD=$(echo ${PYCHDB_CMD} | sed 's/ -DUSE_JEMALLOC=1/ -DUSE_JEMALLOC=1 -Wl,-wrap,malloc -Wl,-wrap,valloc -Wl,-wrap,pvalloc -Wl,-wrap,calloc -Wl,-wrap,realloc -Wl,-wrap,memalign -Wl,-wrap,aligned_alloc -Wl,-wrap,posix_memalign -Wl,-wrap,free/g')
if [ ! "${USING_RESPONSE_FILE}" == "" ]; then
${SED_INPLACE} 's/ src\/CMakeFiles\/clickhouse_malloc.dir\/Common\/stubFree.c.o//g' CMakeFiles/pychdb.rsp
${SED_INPLACE} 's/ -DUSE_JEMALLOC=1/ -DUSE_JEMALLOC=1 -Wl,-wrap,malloc -Wl,-wrap,valloc -Wl,-wrap,pvalloc -Wl,-wrap,calloc -Wl,-wrap,realloc -Wl,-wrap,memalign -Wl,-wrap,aligned_alloc -Wl,-wrap,posix_memalign -Wl,-wrap,free/g' CMakeFiles/pychdb.rsp
fi
fi
# save the command to a file for debug
echo ${PYCHDB_CMD} > pychdb_cmd.sh
${PYCHDB_CMD}
ls -lh ${CHDB_PY_MODULE}
## check all the so files
LIBCHDB_DIR=${BUILD_DIR}/
PYCHDB=${LIBCHDB_DIR}/${CHDB_PY_MODULE}
LIBCHDB=${LIBCHDB_DIR}/${LIBCHDB_SO}
if [ ${build_type} == "Debug" ]; then
echo -e "\nDebug build, skip strip"
else
echo -e "\nStrip the binary:"
${STRIP} --strip-debug --remove-section=.comment --remove-section=.note ${PYCHDB}
${STRIP} --strip-debug --remove-section=.comment --remove-section=.note ${LIBCHDB}
fi
echo -e "\nStripe the binary:"
echo -e "\nPYCHDB: ${PYCHDB}"
ls -lh ${PYCHDB}
echo -e "\nLIBCHDB: ${LIBCHDB}"
ls -lh ${LIBCHDB}
echo -e "\nldd ${PYCHDB}"
${LDD} ${PYCHDB}
echo -e "\nfile info of ${PYCHDB}"
file ${PYCHDB}
echo -e "\nldd ${LIBCHDB}"
${LDD} ${LIBCHDB}
echo -e "\nfile info of ${LIBCHDB}"
file ${LIBCHDB}
rm -f ${CHDB_DIR}/*.so
cp -a ${PYCHDB} ${CHDB_DIR}/${CHDB_PY_MODULE}
cp -a ${LIBCHDB} ${PROJ_DIR}/${LIBCHDB_SO}
echo -e "\nSymbols:"
echo -e "\nPyInit in PYCHDB: ${PYCHDB}"
${NM} ${PYCHDB} | grep PyInit || true
echo -e "\nPyInit in LIBCHDB: ${LIBCHDB}"
${NM} ${LIBCHDB} | grep PyInit || echo "PyInit not found in ${LIBCHDB}, it's OK"
echo -e "\nquery_stable in PYCHDB: ${PYCHDB}"
${NM} ${PYCHDB} | grep query_stable || true
echo -e "\nquery_stable in LIBCHDB: ${LIBCHDB}"
${NM} ${LIBCHDB} | grep query_stable || true
echo -e "\nAfter copy:"
cd ${PROJ_DIR} && pwd
# ls -lh ${PROJ_DIR}
# strip the binary (no debug info at all)
# strip ${CHDB_DIR}/${CHDB_PY_MODULE} || true
# echo -e "\nAfter strip:"
# echo -e "\nLIBCHDB: ${PYCHDB}"
# ls -lh ${CHDB_DIR}
# echo -e "\nfile info of ${PYCHDB}"
# file ${CHDB_DIR}/${CHDB_PY_MODULE}
ccache -s || true
# bash ${DIR}/build_bind.sh
# bash ${DIR}/test_smoke.sh