forked from fluent/fluent-bit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
CMakeLists.txt
490 lines (431 loc) · 15.2 KB
/
CMakeLists.txt
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
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
cmake_minimum_required(VERSION 2.8)
project(fluent-bit)
# Update CFLAGS
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -fPIC ")
if(NOT ${CMAKE_SYSTEM_NAME} MATCHES "Windows")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D__FILENAME__='\"$(subst ${CMAKE_SOURCE_DIR}/,,$(abspath $<))\"'")
else()
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D__FILENAME__=__FILE__")
endif()
include(GNUInstallDirs)
include(ExternalProject)
include(cmake/FindJournald.cmake)
include(cmake/FindMonkey.cmake)
# Output paths
set(FLB_ROOT "${CMAKE_CURRENT_SOURCE_DIR}")
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/bin")
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/lib")
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/library")
# Fluent Bit Version
set(FLB_VERSION_MAJOR 0)
set(FLB_VERSION_MINOR 13)
set(FLB_VERSION_PATCH 0)
set(FLB_VERSION_STR "${FLB_VERSION_MAJOR}.${FLB_VERSION_MINOR}.${FLB_VERSION_PATCH}")
# Build Options
option(FLB_ALL "Enable all features" No)
option(FLB_DEBUG "Build with debug symbols" No)
option(FLB_JEMALLOC "Build with Jemalloc support" No)
option(FLB_REGEX "Build wiht Regex support" Yes)
option(FLB_TLS "Build with SSL/TLS support" No)
option(FLB_WITHOUT_BIN "Do not build executable" No)
option(FLB_WITHOUT_EXAMPLES "Do not build examples" No)
option(FLB_WITHOUT_SHARED_LIB "Do not build shared library" No)
option(FLB_STATS "Enable stats support" No)
option(FLB_VALGRIND "Enable Valgrind support" No)
option(FLB_TRACE "Enable trace mode" No)
option(FLB_TESTS_RUNTIME "Enable runtime tests" No)
option(FLB_TESTS_INTERNAL "Enabel internal tests" No)
option(FLB_MTRACE "Enable mtrace support" No)
option(FLB_BUFFERING "Enable buffering support" No)
option(FLB_POSIX_TLS "Force POSIX thread storage" No)
option(FLB_WITHOUT_INOTIFY "Disable inotify support" No)
option(FLB_SQLDB "Enable SQL embedded DB" No)
option(FLB_HTTP_SERVER "Enable HTTP Server" No)
# Metrics: Experimental Feature, disabled by default on 0.12 series
# but enabled in the upcoming 0.13 release. Note that development
# mode enable this feature.
option(FLB_METRICS "Enable metrics support" No)
# Proxy Plugins
option(FLB_PROXY_GO "Enable Go plugins support" Yes)
# Advanced options for Flushing methods
# =====================================
# Flush methods defines under what kind of context/environment the plugins
# flush callback is invoked. Since this is done through co-routines
# there are two options available:
#
# FLB_FLUSH_LIBCO: set by default, use lib/flb_libco implementation which
# supports amd64, arm, x86 and ppc.
#
# FLB_FLUSH_UCONTEXT (DEPRECATED): It uses POSIX ucontext for co-routines
# implementation.
# Despites this is POSIX deprecated, it's supported on Linux and BSD
# systems, but specific old-toolchains do not implement it.
# Build-in Plugins
option(FLB_IN_CPU "Enable CPU input plugin" Yes)
option(FLB_IN_DISK "Enable Disk input plugin" Yes)
option(FLB_IN_EXEC "Enable Exec input plugin" Yes)
option(FLB_IN_FORWARD "Enable Forward input plugin" Yes)
option(FLB_IN_HEALTH "Enable Health input plugin" Yes)
option(FLB_IN_HTTP "Enable HTTP input plugin" No)
option(FLB_IN_MEM "Enable Memory input plugin" Yes)
option(FLB_IN_KMSG "Enable Kernel log input plugin" Yes)
option(FLB_IN_LIB "Enable library mode input plugin" Yes)
option(FLB_IN_RANDOM "Enable random input plugin" Yes)
option(FLB_IN_SERIAL "Enable Serial input plugin" Yes)
option(FLB_IN_STDIN "Enable Standard input plugin" Yes)
option(FLB_IN_SYSLOG "Enable Syslog input plugin" Yes)
option(FLB_IN_TAIL "Enable Tail input plugin" Yes)
option(FLB_IN_TCP "Enable TCP input plugin" Yes)
option(FLB_IN_MQTT "Enable MQTT Broker input plugin" Yes)
option(FLB_IN_HEAD "Enable Head input plugin" Yes)
option(FLB_IN_PROC "Enable Process input plugin" Yes)
option(FLB_IN_SYSTEMD "Enable Systemd input plugin" Yes)
option(FLB_IN_DUMMY "Enable Dummy input plugin" Yes)
option(FLB_IN_NETIF "Enable NetworkIF input plugin" Yes)
option(FLB_OUT_COUNTER "Enable Counter output plugin" Yes)
option(FLB_OUT_ES "Enable Elasticsearch output plugin" Yes)
option(FLB_OUT_EXIT "Enable Exit output plugin" Yes)
option(FLB_OUT_FORWARD "Enable Forward output plugin" Yes)
option(FLB_OUT_HTTP "Enable HTTP output plugin" Yes)
option(FLB_OUT_INFLUXDB "Enable InfluxDB output plugin" Yes)
option(FLB_OUT_NATS "Enable NATS output plugin" Yes)
option(FLB_OUT_PLOT "Enable Plot output plugin" Yes)
option(FLB_OUT_FILE "Enable file output plugin" Yes)
option(FLB_OUT_TD "Enable Treasure Data output plugin" Yes)
option(FLB_OUT_RETRY "Enable Retry test output plugin" No)
option(FLB_OUT_STDOUT "Enable STDOUT output plugin" Yes)
option(FLB_OUT_LIB "Enable library mode output plugin" Yes)
option(FLB_OUT_NULL "Enable dev null output plugin" Yes)
option(FLB_OUT_FLOWCOUNTER "Enable flowcount output plugin" Yes)
option(FLB_OUT_KAFKA "Enable Kafka output plugin" No)
option(FLB_OUT_KAFKA_REST "Enable Kafka Rest output plugin" Yes)
option(FLB_FILTER_GREP "Enable grep filter" Yes)
option(FLB_FILTER_STDOUT "Enable stdout filter" Yes)
option(FLB_FILTER_PARSER "Enable parser filter" Yes)
option(FLB_FILTER_KUBERNETES "Enable kubernetes filter" Yes)
option(FLB_FILTER_RECORD_MODIFIER "Enable record_modifier filter" Yes)
# Enable all features
if(FLB_ALL)
# Global
set(FLB_DEBUG 1)
set(FLB_TLS 1)
set(FLB_BUFFERING 1)
# Input plugins
set(FLB_IN_CPU 1)
set(FLB_IN_MEM 1)
set(FLB_IN_KMSG 1)
set(FLB_IN_MQTT 1)
set(FLB_IN_SERIAL 1)
set(FLB_IN_STDIN 1)
set(FLB_IN_HEAD 1)
set(FLB_IN_PROC 1)
set(FLB_IN_DISK 1)
set(FLB_IN_DUMMY 1)
set(FLB_IN_NETIF 1)
set(FLB_IN_EXEC 1)
# Output plugins
set(FLB_OUT_ES 1)
set(FLB_OUT_FORWARD 1)
set(FLB_OUT_HTTP 1)
set(FLB_OUT_NATS 1)
set(FLB_OUT_NULL 1)
set(FLB_OUT_PLOT 1)
set(FLB_OUT_FILE 1)
set(FLB_OUT_RETRY 1)
set(FLB_OUT_TD 1)
set(FLB_OUT_STDOUT 1)
set(FLB_OUT_LIB 1)
set(FLB_OUT_FLOWCOUNTER 1)
endif()
if(FLB_DEV)
set(FLB_DEBUG On)
set(FLB_TRACE On)
set(FLB_METRICS On)
set(FLB_HTTP_SERVER On)
set(FLB_TESTS_INTERNAL On)
endif()
# Macro to set definitions
macro(FLB_DEFINITION var)
add_definitions(-D${var})
set(FLB_BUILD_FLAGS "${FLB_BUILD_FLAGS}#ifndef ${var}\n#define ${var}\n#endif\n")
set(FLB_INFO_FLAGS "${FLB_INFO_FLAGS} ${var}")
endmacro()
macro(FLB_OPTION option value)
set(${option} ${value} CACHE "" INTERNAL FORCE)
endmacro()
# Enable Debug symbols if specified
if(FLB_DEBUG)
set(CMAKE_BUILD_TYPE "Debug")
endif()
# General Headers
include_directories(
include/
lib/
lib/flb_libco
lib/sha1
lib/msgpack-2.1.3/include
${MONKEY_INCLUDE_DIR}
)
# On Windows, the core uses libevent
if(CMAKE_SYSTEM_NAME MATCHES "Windows")
include_directories(
lib/monkey/mk_core/deps/libevent/include
${PROJECT_BINARY_DIR}/lib/monkey/mk_core/deps/libevent/include
)
endif()
# mk_core is aware about jemalloc usage, we need to disable this as
# fluent-bit do not use it.
set(WITH_SYSTEM_MALLOC 1 CACHE BOOL "Use system memory allocator")
# MsgPack options
option(MSGPACK_ENABLE_CXX OFF)
option(MSGPACK_ENABLE_SHARED OFF)
option(MSGPACK_BUILD_TESTS OFF)
option(MSGPACK_BUILD_EXAMPLES OFF)
add_subdirectory(lib/msgpack-2.1.3 EXCLUDE_FROM_ALL)
# Lib: build the core libraries used by Fluent-Bit
FLB_DEFINITION(JSMN_PARENT_LINKS)
FLB_DEFINITION(JSMN_STRICT)
add_subdirectory(lib/jsmn)
if(FLB_BUFFERING)
add_subdirectory(lib/sha1)
endif()
# MK Core
macro(MK_SET_OPTION option value)
set(${option} ${value} CACHE "" INTERNAL FORCE)
endmacro()
MK_SET_OPTION(MK_SYSTEM_MALLOC ON)
if(FLB_HTTP_SERVER)
add_subdirectory(lib/monkey/ EXCLUDE_FROM_ALL)
else()
add_subdirectory(lib/monkey/mk_core EXCLUDE_FROM_ALL)
endif()
# SSL/TLS: add encryption support
if(FLB_OUT_TD)
set(FLB_TLS ON)
endif()
if(FLB_TLS)
FLB_DEFINITION(FLB_HAVE_TLS)
option(ENABLE_TESTING OFF)
option(ENABLE_PROGRAMS OFF)
option(INSTALL_MBEDTLS_HEADERS OFF)
add_subdirectory(lib/mbedtls-2.5.1 EXCLUDE_FROM_ALL)
include_directories(lib/mbedtls-2.5.1/include)
endif()
# Metrics
if(FLB_METRICS)
FLB_DEFINITION(FLB_HAVE_METRICS)
endif()
if(FLB_IN_TAIL)
set(FLB_SQLDB ON)
endif()
if(FLB_SQLDB)
FLB_DEFINITION(FLB_HAVE_SQLDB)
add_subdirectory(lib/sqlite-amalgamation-3200000)
include_directories(lib/sqlite-amalgamation-3200000)
endif()
if(FLB_BUFFERING)
FLB_DEFINITION(FLB_HAVE_BUFFERING)
endif()
if(FLB_TRACE)
FLB_DEFINITION(FLB_HAVE_TRACE)
endif()
if(FLB_STATS)
FLB_DEFINITION(FLB_HAVE_STATS)
endif()
if(FLB_HTTP_SERVER)
FLB_DEFINITION(FLB_HAVE_HTTP_SERVER)
endif()
FLB_DEFINITION(FLB_HAVE_FLUSH_LIBCO)
if(NOT TARGET co)
add_subdirectory(lib/flb_libco)
endif()
# Systemd Journald support
if(JOURNALD_FOUND)
FLB_DEFINITION(FLB_HAVE_SYSTEMD)
else()
FLB_OPTION(FLB_IN_SYSTEMD OFF)
endif()
# Valgrind support
check_c_source_compiles("
#include <valgrind/valgrind.h>
int main() {
return 0;
}" FLB_HAVE_VALGRIND)
if(FLB_VALGRIND OR FLB_HAVE_VALGRIND)
FLB_DEFINITION(FLB_HAVE_VALGRIND)
endif()
# fork(2) support
check_c_source_compiles("
#include <unistd.h>
int main() {
fork();
return 0;
}" FLB_HAVE_FORK)
if(FLB_HAVE_FORK)
FLB_DEFINITION(FLB_HAVE_FORK)
endif()
# mtrace support
if(FLB_MTRACE)
check_c_source_compiles("
#include <mcheck.h>
int main() {
return 0;
}" FLB_HAVE_MTRACE)
if(FLB_HAVE_MTRACE AND FLB_DEBUG)
FLB_DEFINITION(FLB_HAVE_MTRACE)
endif()
endif()
if(FLB_TD)
FLB_DEFINITION(FLB_IS_TD_AGENT)
FLB_OPTION(FLB_JEMALLOC ON)
set(FLB_PROG_NAME "TD Agent Bit")
set(FLB_OUT_NAME "td-agent-bit")
set(WITHOUT_HEADERS On)
else()
set(FLB_PROG_NAME "Fluent Bit")
set(FLB_OUT_NAME "fluent-bit")
endif()
if(FLB_PROXY_GO AND (NOT CMAKE_SYSTEM_NAME MATCHES "Windows"))
FLB_DEFINITION(FLB_HAVE_PROXY_GO)
else()
if(FLB_PROXY_GO)
unset(FLB_PROXY_GO CACHE)
endif()
endif()
if("${GNU_HOST}" STREQUAL "")
set(AUTOCONF_HOST_OPT "")
else()
set(AUTOCONF_HOST_OPT "--host=${GNU_HOST}")
endif()
# Memory Allocator
# ================
if(FLB_JEMALLOC AND ${CMAKE_SYSTEM_NAME} MATCHES "Linux")
FLB_DEFINITION(FLB_HAVE_JEMALLOC)
FLB_DEFINITION(JEMALLOC_MANGLE)
# Link to Jemalloc as an external dependency
ExternalProject_Add(jemalloc
SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/lib/jemalloc
CONFIGURE_COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/lib/jemalloc/configure ${AUTOCONF_HOST_OPT} --with-lg-quantum=3 --enable-cc-silence --prefix=<INSTALL_DIR>
CFLAGS=-std=gnu99\ -Wall\ -pipe\ -g3\ -O3\ -funroll-loops
BUILD_COMMAND ${MAKE}
INSTALL_DIR ${CMAKE_CURRENT_BINARY_DIR}/
INSTALL_COMMAND $(MAKE) install_lib_static install_include)
add_library(libjemalloc STATIC IMPORTED GLOBAL)
set_target_properties(libjemalloc PROPERTIES IMPORTED_LOCATION "${CMAKE_CURRENT_BINARY_DIR}/lib/libjemalloc_pic.a")
add_dependencies(libjemalloc jemalloc)
include_directories("${CMAKE_CURRENT_BINARY_DIR}/include/")
else()
FLB_OPTION(FLB_JEMALLOC OFF)
endif()
# Onigmo (Regex Engine)
# =====================
if(FLB_REGEX)
ExternalProject_Add(onigmo
SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/lib/onigmo
CONFIGURE_COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/lib/onigmo/configure ${AUTOCONF_HOST_OPT} --with-pic --disable-shared --enable-static --prefix=<INSTALL_DIR>
CFLAGS=-std=gnu99\ -Wall\ -pipe\ -g3\ -O3\ -funroll-loops
BUILD_COMMAND ${MAKE}
INSTALL_DIR ${CMAKE_CURRENT_BINARY_DIR}/
INSTALL_COMMAND $(MAKE) install)
add_library(libonigmo STATIC IMPORTED GLOBAL)
set_target_properties(libonigmo PROPERTIES IMPORTED_LOCATION "${CMAKE_CURRENT_BINARY_DIR}/lib/libonigmo.a")
add_dependencies(libonigmo onigmo)
include_directories("${CMAKE_CURRENT_BINARY_DIR}/include/")
FLB_DEFINITION(FLB_HAVE_REGEX)
endif()
# Pthread Local Storage
# =====================
# By default we expect the compiler already support thread local storage
# through __thread type, otherwise Fluent Bit fallback to the old POSIX
# pthread mode (pthread_key_t), or it can be forced setting FLB_POSIX_TLS
# for testing/compatibility purposes.
if(NOT FLB_POSIX_TLS)
check_c_source_compiles("
__thread int a;
int main() {
__tls_get_addr(0);
return 0;
}" FLB_HAVE_C_TLS)
if(FLB_HAVE_C_TLS)
FLB_DEFINITION(FLB_HAVE_C_TLS)
endif()
endif()
# setjmp
check_c_source_compiles("
#include <setjmp.h>
int main() {
return 0;
}" FLB_HAVE_SETJMP)
if(FLB_HAVE_SETJMP)
FLB_DEFINITION(FLB_HAVE_SETJMP)
endif()
# accept(4)
check_c_source_compiles("
#define _GNU_SOURCE
#include <stdio.h>
#include <sys/socket.h>
int main() {
accept4(0, NULL, NULL, 0);
return 0;
}" FLB_HAVE_ACCEPT4)
if(FLB_HAVE_ACCEPT4)
FLB_DEFINITION(FLB_HAVE_ACCEPT4)
endif()
# inotify_init(2)
if(NOT FLB_WITHOUT_INOTIFY)
check_c_source_compiles("
#include <sys/inotify.h>
int main() {
return inotify_init1(0);
}" FLB_HAVE_INOTIFY)
if(FLB_HAVE_INOTIFY)
FLB_DEFINITION(FLB_HAVE_INOTIFY)
endif()
endif()
configure_file(
"${PROJECT_SOURCE_DIR}/include/fluent-bit/flb_info.h.in"
"${PROJECT_SOURCE_DIR}/include/fluent-bit/flb_info.h"
)
configure_file(
"${PROJECT_SOURCE_DIR}/include/fluent-bit/flb_version.h.in"
"${PROJECT_SOURCE_DIR}/include/fluent-bit/flb_version.h"
)
# Instruct CMake to build the Fluent Bit Core
add_subdirectory(include)
add_subdirectory(plugins)
add_subdirectory(src)
if(NOT FLB_WITHOUT_EXAMPLES)
add_subdirectory(examples)
endif()
if(FLB_TESTS_RUNTIME)
enable_testing()
add_subdirectory(tests/runtime/)
endif()
if(FLB_TESTS_INTERNAL)
enable_testing()
add_subdirectory(tests/internal/)
endif()
### CPACK / RPM
set(CPACK_PACKAGE_VERSION ${FLB_VERSION_STR})
set(CPACK_GENERATOR "RPM")
set(CPACK_PACKAGE_NAME "td-agent-bit")
set(CPACK_PACKAGE_RELEASE 1)
set(CPACK_PACKAGE_CONTACT "Eduardo Silva <eduardo@treasure-data.com>")
set(CPACK_PACKAGE_VENDOR "Treasure Data")
set(CPACK_PACKAGING_INSTALL_PREFIX "/opt/td-agent-bit")
set(CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}-${CPACK_PACKAGE_VERSION}-${CPACK_PACKAGE_RELEASE}.${CMAKE_SYSTEM_PROCESSOR}")
set(CPACK_RPM_PACKAGE_GROUP "System Environment/Daemons")
set(CPACK_RPM_PACKAGE_LICENSE "Apache v2.0")
set(CPACK_PACKAGE_DESCRIPTION_FILE "${PROJECT_SOURCE_DIR}/cpack/description")
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Fast data collector for Linux")
set(CPACK_RPM_SPEC_MORE_DEFINE "%define ignore \#")
set(CPACK_RPM_USER_FILELIST
"%ignore /lib"
"%ignore /lib/systemd"
"%ignore /lib/systemd/system"
"%ignore /lib64"
"%ignore /lib64/pkgconfig"
"%ignore /opt"
"%ignore /etc")
set(CPACK_PACKAGING_INSTALL_PREFIX "/")
include(CPack)