CMakeLists.txt 4.8 KB
Newer Older
J
jinhai 已提交
1 2 3 4 5 6
#-------------------------------------------------------------------------------
# Copyright 上海赜睿信息科技有限公司(Zilliz) - All Rights Reserved
# Unauthorized copying of this file, via any medium is strictly prohibited.
# Proprietary and confidential.
#-------------------------------------------------------------------------------

Y
yu yunfeng 已提交
7

J
jinhai 已提交
8 9 10 11
aux_source_directory(cache cache_files)
aux_source_directory(config config_files)
aux_source_directory(server server_files)
aux_source_directory(utils utils_files)
G
groot 已提交
12
aux_source_directory(db db_files)
G
groot 已提交
13
aux_source_directory(db/scheduler db_scheduler_files)
X
xj.lin 已提交
14
aux_source_directory(wrapper wrapper_files)
15
aux_source_directory(metrics metrics_files)
Y
yu yunfeng 已提交
16

J
jinhai 已提交
17
set(license_check_files
Y
yangwei.yao 已提交
18 19 20 21
        license/LicenseLibrary.cpp
        license/LicenseCheck.cpp
        )

Y
yu yunfeng 已提交
22
set(license_generator_files
Y
yangwei.yao 已提交
23 24
        license/LicenseGenerator.cpp
        license/LicenseLibrary.cpp
Y
yu yunfeng 已提交
25
        )
J
jinhai 已提交
26

G
groot 已提交
27
set(service_files
G
groot 已提交
28 29 30
        thrift/gen-cpp/MilvusService.cpp
        thrift/gen-cpp/milvus_constants.cpp
        thrift/gen-cpp/milvus_types.cpp
Y
yu yunfeng 已提交
31 32
        metrics/SystemInfo.cpp
        metrics/SystemInfo.h
G
groot 已提交
33 34
        server/ThreadPoolServer.cpp
        server/ThreadPoolServer.h
G
groot 已提交
35
        )
G
groot 已提交
36

G
groot 已提交
37
set(engine_files
J
jinhai 已提交
38
        ${CMAKE_CURRENT_SOURCE_DIR}/main.cpp
G
groot 已提交
39
        ${cache_files}
G
groot 已提交
40
        ${db_files}
G
groot 已提交
41
        ${db_scheduler_files}
G
groot 已提交
42
        ${wrapper_files}
Y
yu yunfeng 已提交
43 44
#        metrics/Metrics.cpp
        ${metrics_files}
G
groot 已提交
45
        )
X
xj.lin 已提交
46

Y
yu yunfeng 已提交
47
set(get_sys_info_files
Y
yangwei.yao 已提交
48
        license/GetSysInfo.cpp)
J
jinhai 已提交
49

50 51 52 53
set(s3_client_files
        storage/s3/S3ClientWrapper.cpp
        storage/s3/S3ClientWrapper.h)

G
groot 已提交
54
include_directories(/usr/include)
Z
zhiru 已提交
55
include_directories("${CUDA_TOOLKIT_ROOT_DIR}/include")
G
groot 已提交
56
include_directories(thrift/gen-cpp)
J
jinhai 已提交
57

Z
zhiru 已提交
58 59
set(third_party_libs
        easyloggingpp
G
groot 已提交
60 61 62
        sqlite
        thrift
        yaml-cpp
63
        libgpufaiss.a
Z
zhiru 已提交
64 65 66
        faiss
        lapack
        openblas
Z
zhiru 已提交
67 68 69
        prometheus-cpp-push
        prometheus-cpp-pull
        prometheus-cpp-core
G
groot 已提交
70 71 72 73 74
        boost_system_static
        boost_filesystem_static
        boost_serialization_static
        bzip2
        lz4
Z
zhiru 已提交
75 76 77
        snappy
        zlib
        zstd
Y
yu yunfeng 已提交
78
        ${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs/libnvidia-ml.so
Z
zhiru 已提交
79
        )
80 81 82
if (MEGASEARCH_WITH_ARROW STREQUAL "ON")
    set(third_party_libs ${third_party_libs} arrow)
endif() 
Z
zhiru 已提交
83

X
xj.lin 已提交
84
if (GPU_VERSION STREQUAL "ON")
Z
zhiru 已提交
85
    link_directories("${CUDA_TOOLKIT_ROOT_DIR}/lib64")
X
xj.lin 已提交
86 87 88 89 90 91
    set(engine_libs
            pthread
            libgomp.a
            libgfortran.a
            cudart
            cublas
Y
yu yunfeng 已提交
92
            ${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs/libnvidia-ml.so
X
xj.lin 已提交
93 94 95 96 97 98
            )
else()
    set(engine_libs
            pthread
            libgomp.a
            libgfortran.a
Y
yu yunfeng 已提交
99
            ${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs/libnvidia-ml.so
Y
yangwei.yao 已提交
100 101 102
            )
endif ()

103 104

if (NOT ${CMAKE_SYSTEM_PROCESSOR} MATCHES "aarch64")
W
wxyu 已提交
105 106 107 108 109 110
    set(engine_libs
	    ${engine_libs}
	    libquadmath.a
	    )
endif ()

Y
yangwei.yao 已提交
111
if (ENABLE_LICENSE STREQUAL "ON")
Z
zhiru 已提交
112 113
    link_directories("${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs")
    link_directories("${CUDA_TOOLKIT_ROOT_DIR}/lib64")
Y
yangwei.yao 已提交
114 115 116 117 118 119
    set(license_libs
            nvidia-ml
            crypto
            cudart
            cublas
            )
X
xj.lin 已提交
120 121
endif ()

G
groot 已提交
122

Y
yu yunfeng 已提交
123

G
groot 已提交
124 125
cuda_add_library(milvus_engine STATIC ${engine_files})
target_link_libraries(milvus_engine ${engine_libs} ${third_party_libs})
G
groot 已提交
126

Y
yu yunfeng 已提交
127 128
add_library(metrics STATIC ${metrics_files})

Y
yangwei.yao 已提交
129
if (ENABLE_LICENSE STREQUAL "ON")
G
groot 已提交
130 131
        add_library(license_check STATIC ${license_check_files})
        target_link_libraries(license_check ${license_libs} ${third_party_libs})
Y
yangwei.yao 已提交
132 133
endif ()

Z
zhiru 已提交
134 135 136 137 138
set(metrics_lib
        prometheus-cpp-push
        prometheus-cpp-pull
        prometheus-cpp-core
        )
Y
yu yunfeng 已提交
139

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

G
groot 已提交
142
set(server_libs
G
groot 已提交
143
        milvus_engine
G
groot 已提交
144
        pthread
X
xj.lin 已提交
145
        dl
Y
yu yunfeng 已提交
146
        metrics
G
groot 已提交
147
        )
G
groot 已提交
148

G
groot 已提交
149
add_executable(milvus_server
Z
zhiru 已提交
150 151 152 153 154
        ${config_files}
        ${server_files}
        ${utils_files}
        ${service_files}
        ${metrics_files}
Z
zhiru 已提交
155
        #${EASYLOGGINGPP_INCLUDE_DIR}/easylogging++.cc
Z
zhiru 已提交
156 157
        )

Y
yangwei.yao 已提交
158
if (ENABLE_LICENSE STREQUAL "ON")
G
groot 已提交
159
        target_link_libraries(milvus_server ${server_libs} license_check ${third_party_libs})
Y
yangwei.yao 已提交
160
else ()
G
groot 已提交
161
        target_link_libraries(milvus_server ${server_libs} ${third_party_libs})
Y
yangwei.yao 已提交
162
endif()
J
jinhai 已提交
163

Y
yangwei.yao 已提交
164
if (ENABLE_LICENSE STREQUAL "ON")
Z
zhiru 已提交
165
        add_executable(get_sys_info ${get_sys_info_files})
Y
yu yunfeng 已提交
166
        add_executable(license_generator ${license_generator_files})
Z
zhiru 已提交
167

G
groot 已提交
168
        target_link_libraries(get_sys_info ${license_libs} license_check ${third_party_libs})
Z
zhiru 已提交
169 170 171 172
        target_link_libraries(license_generator ${license_libs} ${third_party_libs})

        install(TARGETS get_sys_info DESTINATION bin)
        install(TARGETS license_generator DESTINATION bin)
Y
yangwei.yao 已提交
173
endif ()
174

G
groot 已提交
175
install(TARGETS milvus_server DESTINATION bin)
Y
yu yunfeng 已提交
176

Y
yu yunfeng 已提交
177
add_subdirectory(sdk)
Y
yu yunfeng 已提交
178 179 180 181 182 183
#target_link_libraries(
#        libprometheus-cpp-push.a
#        libprometheus-cpp-pull.a
#        libprometheus-cpp-core.a
#        pthread
#        z
Y
yu yunfeng 已提交
184 185
#        ${CURL_LIBRARIES})