forked from parseablehq/parseable
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvalues.yaml
501 lines (485 loc) · 13.1 KB
/
values.yaml
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
491
492
493
494
495
496
497
498
499
500
501
parseable:
image:
repository: containers.parseable.com/parseable/parseable
tag: "v1.7.2"
pullPolicy: Always
## object store can be local-store, s3-store, blob-store or gcs-store.
store: local-store
## Set to true if you want to deploy Parseable in a HA mode (multiple ingestors + hot tier)
## Please note that highAvailability is not supported in local mode
highAvailability:
enabled: false
ingestor:
port: 8000
podAnnotations: {}
nodeSelector: {}
tolerations: []
labels:
app: parseable
component: ingestor
count: 3
env:
RUST_LOG: warn
## Use this endpoint to send events to ingestors
## Console (UI) is available on the other service (that points to the query pod)
service:
type: ClusterIP
port: 80
readinessProbe:
httpGet:
path: /api/v1/readiness
port: 8000
resources:
limits:
cpu: 500m
memory: 4Gi
requests:
cpu: 250m
memory: 1Gi
## Enable audit logging on parseable nodes
auditLogging:
enabled: false
p_server: "http://parseable-ingestor-service.parseable.svc.cluster.local"
p_username: "admin"
p_password: "admin"
## Add environment variables to the Parseable Deployment
env:
RUST_LOG: warn
## Enable to create a log stream and then add retention configuration
## for that log stream
# logstream:
# - name: "vectordemo"
# retention:
# action: "delete"
# duration: "30d"
# - name: "fluentbitdemo"
# retention:
# action: "delete"
# duration: "30d"
## enable persistence using PVC for the Data and Staging directories
## Note that Data directory is needed only for local mode
persistence:
staging:
enabled: false
storageClass: ""
accessMode: ReadWriteOnce
size: 5Gi
ingestor:
enabled: false
storageClass: ""
accessMode: ReadWriteOnce
size: 5Gi
data:
enabled: false
storageClass: ""
accessMode: ReadWriteOnce
size: 5Gi
## enabling the disk on querier adds the hot-tier.
## local-store is not supported on hot-tier.
querier:
enabled: false
storageClass: ""
accessMode: ReadWriteOnce
size: 100Gi
## comment out the secrets depending upon deployment option
## localModeSecret if store is set to local
## blobModeSecret if store is set to blob-store
## s3ModeSecret if store is set to s3-store
localModeSecret:
enabled: false
secrets:
- name: parseable-env-secret
prefix: P_
keys:
- addr
- username
- password
- staging.dir
- fs.dir
blobModeSecret:
enabled: false
secrets:
- name: parseable-env-secret
prefix: P_
keys:
- addr
- username
- password
- azr.access_key
- azr.account
- azr.container
- azr.url
s3ModeSecret:
enabled: false
secrets:
- name: parseable-env-secret
prefix: P_
keys:
- addr
- username
- password
- staging.dir
- fs.dir
- s3.url
- s3.access.key
- s3.secret.key
- s3.bucket
- s3.region
gcsModeSecret:
enabled: false
secrets:
- name: parseable-env-secret
prefix: P_
keys:
- addr
- username
- password
- staging.dir
- fs.dir
- gcs.url
- gcs.access.key
- gcs.secret.key
- gcs.bucket
- gcs.region
serviceAccount:
create: true
name: "parseable"
annotations: {}
service:
type: ClusterIP
port: 80
readinessProbe:
httpGet:
path: /api/v1/readiness
port: 8000
toleration: []
resources:
limits:
cpu: 500m
memory: 4Gi
requests:
cpu: 250m
memory: 1Gi
## works only when highAvailability is enabled
## Set it to true if you want to deploy Parseable
## Query node with a sidecar
sidecar:
enabled: false
image:
repository: busybox
tag: latest
pullPolicy: IfNotPresent
command: []
args: []
env:
RUST_LOG: warn
ports: 8000
volumeMounts:
- name: test-volume
mountPath: /parseable/test
volumeClaimTemplates:
- metadata:
name: test-volume
spec:
accessModes: [ "ReadWriteOnce" ]
resources:
requests:
storage: 1Gi
resources:
limits:
cpu: 500m
memory: 4Gi
requests:
cpu: 250m
memory: 1Gi
securityContext:
allowPrivilegeEscalation: false
podAnnotations:
prometheus.io/scrape: "true"
prometheus.io/port: "80"
prometheus.io/path: "/api/v1/metrics"
podSecurityContext:
runAsUser: 1000
runAsGroup: 1000
fsGroup: 1000
fsGroupChangePolicy: "Always"
nameOverride: ""
fullnameOverride: ""
nodeSelector: {}
affinity: {}
podLabels:
app: parseable
component: query
tolerations: []
## Use this section to create ServiceMonitor object for
## this Parseable deployment. Read more on ServiceMonitor
## here: https://prometheus-operator.dev/docs/api-reference/api/#monitoring.coreos.com/v1.ServiceMonitor
metrics:
serviceMonitor:
enabled: false
labels: {}
namespace: ""
spec:
jobLabel: ""
targetLabels: []
podTargetLabels: []
endpoints: []
selector: {}
namespaceSelector: {}
sampleLimit: 0
scrapeProtocols: []
targetLimit: 0
labelLimit: 0
labelNameLengthLimit: 0
labelValueLengthLimit: 0
keepDroppedTargets: 0
attachMetadata: {}
scrapeClass: ""
bodySizeLimit: {}
# Default values for Vector
# See Vector helm documentation to learn more:
# https://vector.dev/docs/setup/installation/package-managers/helm/
vector:
enabled: false
role: "Agent"
rollWorkload: true
image:
repository: timberio/vector
pullPolicy: IfNotPresent
pullSecrets: []
tag: ""
sha: ""
replicas: 1
podManagementPolicy: OrderedReady
podDisruptionBudget:
enabled: false
minAvailable: 1
maxUnavailable:
rbac:
create: true
serviceAccount:
create: true
annotations: {}
name:
automountToken: true
podLabels:
vector.dev/exclude: "true"
args:
- --config-dir
- "/etc/vector/"
terminationGracePeriodSeconds: 60
service:
enabled: true
type: "ClusterIP"
annotations: {}
topologyKeys: []
ports: []
externalTrafficPolicy: ""
loadBalancerIP: ""
ipFamilyPolicy: ""
ipFamilies: []
serviceHeadless:
enabled: true
dnsPolicy: ClusterFirst
customConfig:
data_dir: /vector-data-dir
api:
enabled: true
address: 127.0.0.1:8686
playground: false
sources:
kubernetes_logs:
type: kubernetes_logs
sinks:
parseable:
type: http
method: post
batch:
max_bytes: 10485760
max_events: 1000
timeout_secs: 10
compression: gzip
inputs:
- kubernetes_logs
encoding:
codec: json
uri: 'http://parseable.parseable.svc.cluster.local/api/v1/ingest'
auth:
strategy: basic
user: admin
password: admin
request:
headers:
X-P-Stream: vectordemo
healthcheck:
enabled: true
path: 'http://parseable.parseable.svc.cluster.local/api/v1/liveness'
port: 80
# Default values for fluent-bit.
# See fluent-bit helm documentation to learn more:
# https://github.com/fluent/helm-charts/tree/main/charts/fluent-bit
fluent-bit:
enabled: false
kind: DaemonSet
serverHost: parseable-ingestor-service.parseable.svc.cluster.local
serverUsername: admin
serverPassword: admin
serverStream: $NAMESPACE
excludeNamespaces: kube-system, default
replicaCount: 1
image:
repository: parseable/fluent-bit
tag: "v2"
pullPolicy: Always
testFramework:
enabled: true
image:
repository: busybox
pullPolicy: Always
tag: latest
serviceAccount:
create: true
annotations: {}
name:
rbac:
create: true
nodeAccess: false
eventsAccess: true
dnsPolicy: ClusterFirst
service:
type: ClusterIP
port: 2020
loadBalancerClass:
loadBalancerSourceRanges: []
labels: {}
livenessProbe:
httpGet:
path: /
port: http
readinessProbe:
httpGet:
path: /api/v1/health
port: http
flush: 1
metricsPort: 2020
## https://docs.fluentbit.io/manual/administration/configuring-fluent-bit/classic-mode/configuration-file
config:
service: |
[SERVICE]
Daemon Off
Flush {{ .Values.flush }}
Log_Level {{ .Values.logLevel }}
Parsers_File parsers.conf
Parsers_File custom_parsers.conf
HTTP_Server On
HTTP_Listen 0.0.0.0
HTTP_Port {{ .Values.metricsPort }}
Health_Check On
## https://docs.fluentbit.io/manual/pipeline/inputs
inputs: |
[INPUT]
Name tail
Path /var/log/containers/*.log
multiline.parser docker, cri
Tag kube.*
Mem_Buf_Limit 5MB
Skip_Long_Lines On
# [INPUT]
# Name tail
# Path /var/log/containers/{NGINX_POD_NAME}-*.log
# Parser nginx_access
# Tag kube.*
# Mem_Buf_Limit 5MB
# Skip_Long_Lines On
# [INPUT]
# Name tail
# Path /var/log/containers/{NGINX_POD_NAME}-*.log
# Parser nginx_error
# Tag kube.*
# Mem_Buf_Limit 5MB
# Skip_Long_Lines On
[INPUT]
name kubernetes_events
tag k8s_events
[INPUT]
Name systemd
Tag host.*
Systemd_Filter _SYSTEMD_UNIT=kubelet.service
Read_From_Tail On
## https://docs.fluentbit.io/manual/pipeline/filters
filters: |
[FILTER]
Name kubernetes
Match kube.*
Merge_Log On
Keep_Log Off
K8S-Logging.Parser On
K8S-Logging.Exclude On
## https://docs.fluentbit.io/manual/pipeline/outputs
outputs: |
[OUTPUT]
Name parseable
Match kube.*
Server_Host {{ .Values.serverHost }}
Username {{ .Values.serverUsername }}
Password {{ .Values.serverPassword }}
Server_Port 80
Stream {{ .Values.serverStream }}
Exclude_Namespaces {{ .Values.excludeNamespaces }}
[OUTPUT]
Name parseable
Match k8s_events
Server_Host {{ .Values.serverHost }}
Server_Port 80
Username {{ .Values.serverUsername }}
Password {{ .Values.serverPassword }}
Stream k8s-events
upstream: {}
customParsers: |
[PARSER]
Name docker_no_time
Format json
Time_Keep Off
Time_Key time
Time_Format %Y-%m-%dT%H:%M:%S.%L
# [PARSER]
# Name nginx_error
# Format regex
# Regex ^(?<timestamp>\S+Z) stderr F (?<error_timestamp>\S+ \S+) \[(?<log_level>\S+)\] (?<process_id>\d+#\d+): \*(?<request_id>\d+) (?<error_message>.*?) client: (?<client_ip>\S+), server: (?<server_name>\S+), request: "(?<request_method>\S+) (?<request_path>\S+) HTTP/\S+", upstream: "(?<upstream_url>[^"]+)", host: "(?<host>\S+)"$
# Time_Key timestamp
# Time_Format %Y/%m/%d %H:%M:%S
# [PARSER]
# Name nginx_access
# Format regex
# Regex (?<remote_addr>[^ ]*) - (?<remote_user>[^ ]*) \[(?<timestamp>[^\]]*)\] "(?<method>\S+)(?: +(?<request>[^\"]*?)(?: +\S*)?)?" (?<status>[^ ]*) (?<body_bytes_sent>[^ ]*) "(?<http_referer>[^\"]*)" "(?<http_user_agent>[^\"]*)" (?<request_length>[^ ]*) (?<request_time>[^ ]*) \[(?<proxy_upstream_name>[^ ]*)\] \[(?<proxy_alternative_upstream_name>[^ ]*)\] (?<upstream_addr>[^,]*),?(?:[^,]*),?(?:[^ ]*) (?<upstream_response_length>[^,]*),?(?:[^,]*),?(?:[^ ]*) (?<upstream_response_time>[^,]*),?(?:[^,]*),?(?:[^ ]*) (?<upstream_status>[^,]*),?(?:[^,]*),?(?:[^ ]*) (?<req_id>[^ ]*)
# Time_Key timestamp
# Time_Format %d/%b/%Y:%H:%M:%S %z
# The config volume is mounted by default, either to the existingConfigMap value, or the default of "fluent-bit.fullname"
volumeMounts:
- name: config
mountPath: /fluent-bit/etc/fluent-bit.conf
subPath: fluent-bit.conf
- name: config
mountPath: /fluent-bit/etc/custom_parsers.conf
subPath: custom_parsers.conf
daemonSetVolumes:
- name: varlog
hostPath:
path: /var/log
- name: varlibdockercontainers
hostPath:
path: /var/lib/docker/containers
- name: etcmachineid
hostPath:
path: /etc/machine-id
type: File
daemonSetVolumeMounts:
- name: varlog
mountPath: /var/log
- name: varlibdockercontainers
mountPath: /var/lib/docker/containers
readOnly: true
- name: etcmachineid
mountPath: /etc/machine-id
readOnly: true
logLevel: info