CMakeLists.txt 11.1 KB
Newer Older
J
jinhai 已提交
1
#-------------------------------------------------------------------------------
2
# Copyright (C) 2019-2020 Zilliz. All rights reserved.
J
jinhai 已提交
3
#
4 5
# Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
J
jinhai 已提交
6
#
7 8 9 10 11
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software distributed under the License
# is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
# or implied. See the License for the specific language governing permissions and limitations under the License.
J
jinhai 已提交
12 13
#-------------------------------------------------------------------------------

Z
zhiru 已提交
14 15
include_directories(${MILVUS_SOURCE_DIR})
include_directories(${MILVUS_ENGINE_SRC})
W
wxyu 已提交
16
include_directories(${MILVUS_THIRDPARTY_SRC})
J
jinhai 已提交
17

S
starlord 已提交
18 19
include_directories(${MILVUS_ENGINE_SRC}/grpc/gen-status)
include_directories(${MILVUS_ENGINE_SRC}/grpc/gen-milvus)
Z
zhiru 已提交
20

W
Wang XiangYu 已提交
21
add_subdirectory(config)
22
add_subdirectory(tracing)
W
Wang XiangYu 已提交
23

24
set(FOUND_OPENBLAS "unknown")
25

S
starlord 已提交
26
add_subdirectory(index)
Q
quicksilver 已提交
27

S
starlord 已提交
28 29
set(INDEX_INCLUDE_DIRS ${INDEX_INCLUDE_DIRS} PARENT_SCOPE)
foreach (dir ${INDEX_INCLUDE_DIRS})
Z
zhiru 已提交
30
    include_directories(${dir})
Z
zhiru 已提交
31
endforeach ()
Z
zhiru 已提交
32

Z
update  
zhiru 已提交
33
aux_source_directory(${MILVUS_ENGINE_SRC}/cache cache_files)
S
starlord 已提交
34
aux_source_directory(${MILVUS_ENGINE_SRC}/metrics metrics_files)
35
aux_source_directory(${MILVUS_ENGINE_SRC}/metrics/prometheus metrics_prometheus_files)
Z
update  
zhiru 已提交
36
aux_source_directory(${MILVUS_ENGINE_SRC}/db db_main_files)
37
aux_source_directory(${MILVUS_ENGINE_SRC}/db/attr db_attr_files)
Z
update  
zhiru 已提交
38 39
aux_source_directory(${MILVUS_ENGINE_SRC}/db/engine db_engine_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/db/insert db_insert_files)
G
groot 已提交
40
aux_source_directory(${MILVUS_ENGINE_SRC}/db/merge db_merge_files)
41
aux_source_directory(${MILVUS_ENGINE_SRC}/db/wal db_wal_files)
42
aux_source_directory(${MILVUS_ENGINE_SRC}/db/snapshot db_snapshot_files)
Z
zhiru 已提交
43

44 45 46 47 48 49 50
aux_source_directory(${MILVUS_ENGINE_SRC}/db/meta db_meta_main_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/db/meta/backend db_meta_backend_files)
set(db_meta_files
        ${db_meta_main_files}
        ${db_meta_backend_files}
        )

Z
zhiru 已提交
51
set(grpc_service_files
Z
update  
zhiru 已提交
52 53 54 55
        ${MILVUS_ENGINE_SRC}/grpc/gen-milvus/milvus.grpc.pb.cc
        ${MILVUS_ENGINE_SRC}/grpc/gen-milvus/milvus.pb.cc
        ${MILVUS_ENGINE_SRC}/grpc/gen-status/status.grpc.pb.cc
        ${MILVUS_ENGINE_SRC}/grpc/gen-status/status.pb.cc
Z
zhiru 已提交
56 57
        )

58 59 60 61
add_subdirectory(query)
add_subdirectory(search)

# Now no use of context
62 63
aux_source_directory(${MILVUS_ENGINE_SRC}/context context_files)

Z
update  
zhiru 已提交
64 65 66 67
aux_source_directory(${MILVUS_ENGINE_SRC}/scheduler scheduler_main_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/scheduler/action scheduler_action_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/scheduler/event scheduler_event_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/scheduler/job scheduler_job_files)
68
aux_source_directory(${MILVUS_ENGINE_SRC}/scheduler/selector scheduler_selector_files)
Z
update  
zhiru 已提交
69 70
aux_source_directory(${MILVUS_ENGINE_SRC}/scheduler/resource scheduler_resource_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/scheduler/task scheduler_task_files)
Z
zhiru 已提交
71
set(scheduler_files
Z
update  
zhiru 已提交
72
        ${scheduler_main_files}
W
wxyu 已提交
73 74
        ${scheduler_action_files}
        ${scheduler_event_files}
W
wxyu 已提交
75
        ${scheduler_job_files}
76
        ${scheduler_selector_files}
W
wxyu 已提交
77 78 79 80
        ${scheduler_resource_files}
        ${scheduler_task_files}
        )

W
wxyu 已提交
81 82
aux_source_directory(${MILVUS_THIRDPARTY_SRC}/easyloggingpp thirdparty_easyloggingpp_files)
aux_source_directory(${MILVUS_THIRDPARTY_SRC}/nlohmann thirdparty_nlohmann_files)
83
aux_source_directory(${MILVUS_THIRDPARTY_SRC}/dablooms thirdparty_dablooms_files)
W
wxyu 已提交
84 85 86
set(thirdparty_files
        ${thirdparty_easyloggingpp_files}
        ${thirdparty_nlohmann_files}
87
        ${thirdparty_dablooms_files}
W
wxyu 已提交
88 89
        )

90
aux_source_directory(${MILVUS_ENGINE_SRC}/server server_service_files)
B
BossZou 已提交
91
aux_source_directory(${MILVUS_ENGINE_SRC}/server/init server_init_files)
92
aux_source_directory(${MILVUS_ENGINE_SRC}/server/delivery/request delivery_request_files)
93
aux_source_directory(${MILVUS_ENGINE_SRC}/server/delivery/hybrid_request delivery_hybrid_request_files)
94
aux_source_directory(${MILVUS_ENGINE_SRC}/server/delivery/strategy delivery_strategy_files)
95 96
aux_source_directory(${MILVUS_ENGINE_SRC}/server/delivery delivery_files)
set(server_files
B
BossZou 已提交
97
        ${server_init_files}
98
        ${server_service_files}
W
Wang XiangYu 已提交
99
        ${server_init_files}
100
        ${delivery_request_files}
101
        ${delivery_hybrid_request_files}
102
        ${delivery_strategy_files}
103 104 105
        ${delivery_files}
        )

G
groot 已提交
106
aux_source_directory(${MILVUS_ENGINE_SRC}/server/grpc_impl grpc_impl_files)
Z
Zhiru Zhu 已提交
107 108
aux_source_directory(${MILVUS_ENGINE_SRC}/server/grpc_impl/interceptor grpc_interceptor_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/server/context server_context_files)
G
groot 已提交
109 110 111
set(grpc_server_files
        ${grpc_request_files}
        ${grpc_impl_files}
Z
Zhiru Zhu 已提交
112
        ${grpc_interceptor_files}
G
groot 已提交
113 114
        )

B
BossZou 已提交
115 116 117 118
aux_source_directory(${MILVUS_ENGINE_SRC}/server/web_impl/handler web_handler_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/server/web_impl/component web_conponent_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/server/web_impl/controller web_controller_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/server/web_impl/dto web_dto_files)
119
aux_source_directory(${MILVUS_ENGINE_SRC}/server/web_impl/utils web_utils_files)
B
BossZou 已提交
120 121 122 123 124 125
aux_source_directory(${MILVUS_ENGINE_SRC}/server/web_impl web_impl_files)
set(web_server_files
        ${web_handler_files}
        ${web_conponent_files}
        ${web_controller_files}
        ${web_dto_files}
126
        ${web_utils_files}
B
BossZou 已提交
127 128 129
        ${web_impl_files}
        )

C
Cai Yudong 已提交
130
aux_source_directory(${MILVUS_ENGINE_SRC}/storage storage_main_files)
131
aux_source_directory(${MILVUS_ENGINE_SRC}/storage/disk storage_disk_files)
C
Cai Yudong 已提交
132
#aux_source_directory(${MILVUS_ENGINE_SRC}/storage/s3 storage_s3_files)
C
Cai Yudong 已提交
133 134
set(storage_files
        ${storage_main_files}
135
        ${storage_disk_files}
C
Cai Yudong 已提交
136
#        ${storage_s3_files}
C
Cai Yudong 已提交
137 138
        )

Z
update  
zhiru 已提交
139
aux_source_directory(${MILVUS_ENGINE_SRC}/utils utils_files)
140

C
Cai Yudong 已提交
141
aux_source_directory(${MILVUS_ENGINE_SRC}/index/archive wrapper_files)
G
groot 已提交
142

143 144
aux_source_directory(${MILVUS_ENGINE_SRC}/codecs codecs_files)
aux_source_directory(${MILVUS_ENGINE_SRC}/codecs/default codecs_default_files)
C
Cai Yudong 已提交
145
aux_source_directory(${MILVUS_ENGINE_SRC}/codecs/snapshot codecs_snapshot_files)
146 147 148

aux_source_directory(${MILVUS_ENGINE_SRC}/segment segment_files)

Z
update  
zhiru 已提交
149
set(engine_files
J
jinhai 已提交
150
        ${CMAKE_CURRENT_SOURCE_DIR}/main.cpp
G
groot 已提交
151
        ${cache_files}
S
starlord 已提交
152
        ${db_main_files}
153
        ${db_attr_files}
S
starlord 已提交
154 155 156
        ${db_engine_files}
        ${db_insert_files}
        ${db_meta_files}
G
groot 已提交
157
        ${db_merge_files}
158
        ${db_wal_files}
159
        ${db_snapshot_files}
C
Cai Yudong 已提交
160
        ${storage_files}
W
wxyu 已提交
161
        ${thirdparty_files}
162
        ${utils_files}
Z
update  
zhiru 已提交
163
        ${wrapper_files}
164 165
        ${codecs_files}
        ${codecs_default_files}
C
Cai Yudong 已提交
166
        ${codecs_snapshot_files}
167
        ${segment_files}
G
groot 已提交
168
        )
X
xj.lin 已提交
169

Z
Zhiru Zhu 已提交
170
set(grpc_lib
S
starlord 已提交
171 172 173 174
        grpcpp_channelz
        grpc++
        grpc
        grpc_protobuf
Z
update  
zhiru 已提交
175 176
        grpc_protoc
        )
J
jinhai 已提交
177

Z
zhiru 已提交
178
set(prometheus_lib
Z
zhiru 已提交
179 180
        prometheus-cpp-push
        prometheus-cpp-pull
Z
update  
zhiru 已提交
181
        prometheus-cpp-core
182
        curl
Z
update  
zhiru 已提交
183
        )
Z
zhiru 已提交
184 185

set(boost_lib
186 187 188
        libboost_system.a
        libboost_filesystem.a
        libboost_serialization.a
Z
update  
zhiru 已提交
189
        )
Z
zhiru 已提交
190

C
Cai Yudong 已提交
191 192 193 194 195
set(s3_client_lib
        aws-cpp-sdk-s3
        aws-cpp-sdk-core
        )

Z
zhiru 已提交
196 197
set(third_party_libs
        sqlite
Z
Zhiru Zhu 已提交
198
        ${grpc_lib}
Z
zhiru 已提交
199
        yaml-cpp
Z
zhiru 已提交
200
        mysqlpp
Z
Zhiru Zhu 已提交
201
        zlib
202
        fiu
Z
Zhiru Zhu 已提交
203
        ${boost_lib}
Z
zhiru 已提交
204
        )
S
starlord 已提交
205

Y
youny626 已提交
206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222
if (MILVUS_GPU_VERSION)
    include_directories(${CUDA_INCLUDE_DIRS})
    link_directories("${CUDA_TOOLKIT_ROOT_DIR}/lib64")
    set(cuda_lib
            ${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs/libnvidia-ml.so
            cudart
            cublas
            )
    set(third_party_libs ${third_party_libs}
            ${cuda_lib}
            )
    aux_source_directory(${MILVUS_ENGINE_SRC}/wrapper/gpu wrapper_gpu_files)
    set(engine_files ${engine_files}
            ${wrapper_gpu_files}
            )
endif ()

223 224
# cannot be enabled together with ENABLE_CPU_PROFILING
if (ENABLE_MEM_PROFILING)
Y
yudong.cai 已提交
225
    set(third_party_libs ${third_party_libs}
F
feisiyicl 已提交
226
            tcmalloc
227 228 229 230 231 232
            )
endif ()

if (ENABLE_CPU_PROFILING)
    set(third_party_libs ${third_party_libs}
            gperftools
Y
youny626 已提交
233 234
            libunwind
            )
Z
zhiru 已提交
235
endif ()
Y
yangwei.yao 已提交
236

237 238 239 240 241 242
if (MILVUS_WITH_PROMETHEUS)
    set(third_party_libs ${third_party_libs}
            ${prometheus_lib}
            )
endif ()

C
Cai Yudong 已提交
243 244 245 246 247 248 249 250
if (MILVUS_WITH_AWS)
    set(third_party_libs ${third_party_libs}
            ${s3_client_lib}
            curl
            crypto
            )
endif ()

S
starlord 已提交
251 252 253 254
set(engine_libs
        pthread
        libgomp.a
        libgfortran.a
Y
youny626 已提交
255
        dl
S
starlord 已提交
256
        )
257 258

if (NOT ${CMAKE_SYSTEM_PROCESSOR} MATCHES "aarch64")
W
wxyu 已提交
259
    set(engine_libs
Z
zhiru 已提交
260 261 262
            ${engine_libs}
            libquadmath.a
            )
W
wxyu 已提交
263 264
endif ()

265 266 267 268 269
if (MILVUS_WITH_PROMETHEUS)
    add_library(metrics STATIC ${metrics_files} ${metrics_prometheus_files})
else ()
    add_library(metrics STATIC ${metrics_files})
endif ()
W
Wang XiangYu 已提交
270
add_dependencies(metrics fiu)
Y
yu yunfeng 已提交
271

Z
zhiru 已提交
272
set(metrics_lib
Z
zhiru 已提交
273
        yaml-cpp
Z
zhiru 已提交
274
        )
Y
yu yunfeng 已提交
275

276 277 278 279 280 281
if (MILVUS_WITH_PROMETHEUS)
    set(metrics_lib ${metrics_lib}
            ${prometheus_lib}
            )
endif ()

Z
zhiru 已提交
282
target_link_libraries(metrics ${metrics_lib})
Y
yu yunfeng 已提交
283

284 285 286 287 288 289 290 291 292

add_library(milvus_engine STATIC ${engine_files})
target_link_libraries(milvus_engine
        knowhere
        ${third_party_libs}
        ${engine_libs}
        metrics
        )

G
groot 已提交
293
set(server_libs
G
groot 已提交
294
        milvus_engine
W
Wang XiangYu 已提交
295
        config
Y
yu yunfeng 已提交
296
        metrics
Z
Zhiru Zhu 已提交
297
        tracing
B
BossZou 已提交
298
        oatpp
299 300
        query
        search
G
groot 已提交
301
        )
G
groot 已提交
302

S
starlord 已提交
303
add_executable(milvus_server
304
        ${context_files}
Z
zhiru 已提交
305
        ${scheduler_files}
S
starlord 已提交
306
        ${server_files}
Z
zhiru 已提交
307
        ${grpc_server_files}
S
starlord 已提交
308
        ${grpc_service_files}
B
BossZou 已提交
309
        ${web_server_files}
Z
Zhiru Zhu 已提交
310
        ${server_context_files}
Z
zhiru 已提交
311
        ${utils_files}
S
starlord 已提交
312
        )
Y
yu yunfeng 已提交
313

S
starlord 已提交
314 315 316
target_link_libraries(milvus_server
        ${server_libs}
        )
S
starlord 已提交
317 318 319

install(TARGETS milvus_server DESTINATION bin)

320 321 322 323
install(FILES
        ${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}
        ${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}.3
        ${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}.3.2.4
324 325 326
        ${CMAKE_BINARY_DIR}/fiu_ep-prefix/src/fiu_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}fiu${CMAKE_SHARED_LIBRARY_SUFFIX}
        ${CMAKE_BINARY_DIR}/fiu_ep-prefix/src/fiu_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}fiu${CMAKE_SHARED_LIBRARY_SUFFIX}.0
        ${CMAKE_BINARY_DIR}/fiu_ep-prefix/src/fiu_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}fiu${CMAKE_SHARED_LIBRARY_SUFFIX}.1.00
Z
zhiru 已提交
327
        DESTINATION lib)
O
op-hunter 已提交
328

329
if (FOUND_OPENBLAS STREQUAL "false")
O
op-hunter 已提交
330
    install(FILES
331 332 333 334
        ${CMAKE_BINARY_DIR}/src/index/openblas_ep-prefix/src/openblas_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}openblas${CMAKE_SHARED_LIBRARY_SUFFIX}
        ${CMAKE_BINARY_DIR}/src/index/openblas_ep-prefix/src/openblas_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}openblas${CMAKE_SHARED_LIBRARY_SUFFIX}.0
        ${CMAKE_BINARY_DIR}/src/index/openblas_ep-prefix/src/openblas_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}openblas${CMAKE_SHARED_LIBRARY_SUFFIX}.0.3
        DESTINATION lib)
W
Wang XiangYu 已提交
335
endif()