본문으로 건너뛰기

ECK Operator

설치

wget https://download.elastic.co/downloads/eck/2.1.0/crds.yaml -O eck-crds.yaml
kubectl apply -f eck-crds.yaml
wget https://download.elastic.co/downloads/eck/2.1.0/operator.yaml -O eck-operator.yaml
kubectl apply -f eck-operator.yaml
elasticsearch.yaml
apiVersion: elasticsearch.k8s.elastic.co/v1
kind: Elasticsearch
metadata:
name: elasticsearch
namespace: elastic-system
spec:
version: 8.2.0
http:
tls:
selfSignedCertificate:
disabled: true
updateStrategy:
changeBudget:
maxSurge: 3
maxUnavailable: 1
nodeSets:
- name: master
config:
node.roles:
- master
- data
- ingest
- transform
node.store.allow_mmap: false
count: 1
podTemplate:
metadata:
labels:
app: elasticsearch
version: v1
spec:
containers:
- name: elasticsearch
env:
- name: ES_JAVA_OPTS
value: "-Xms2g -Xmx2g"
resources:
limits:
memory: 4Gi
requests:
cpu: 500m
memory: 4Gi
volumeClaimTemplates:
- metadata:
name: elasticsearch-data
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 20Gi
kubectl apply -f elasticsearch.yaml
kibana.yaml
apiVersion: kibana.k8s.elastic.co/v1
kind: Kibana
metadata:
name: kibana
namespace: elastic-system
spec:
version: 8.2.0
count: 1
http:
tls:
selfSignedCertificate:
disabled: true
elasticsearchRef:
name: elasticsearch
namespace: elastic-system
podTemplate:
metadata:
labels:
app: kibana
version: v1
spec:
containers:
- name: kibana
resources:
requests:
cpu: 200m
memory: 1Gi
limits:
memory: 2Gi
kubectl apply -f kibana.yaml

Fluent Bit

fluent-bit-values.yaml
env:
- name: ES_HOST
value: elasticsearch-es-http.elastic-system.svc.cluster.local
- name: ES_PORT
value: "9200"
- name: ES_USER
value: "elastic"
- name: ES_PASSWORD
valueFrom:
secretKeyRef:
name: elasticsearch-es-elastic-user
key: elastic

config:
# indent를 4칸으로 맞춰야 합니다.
outputs: |
# https://docs.fluentbit.io/manual/pipeline/outputs/elasticsearch
[OUTPUT]
Name es
Match *
Host ${ES_HOST}
Port ${ES_PORT}
HTTP_User ${ES_USER}
HTTP_Passwd ${ES_PASSWORD}
Trace_Error On
Buffer_Size 64K
Logstash_Format On
Logstash_DateFormat %Y.%m
Logstash_Prefix_Key tag
Current_Time_Index On
Suppress_Type_Name On
Retry_Limit 5

Fluentd

fluentd-values.yaml
env:
- name: ES_HOST
value: elasticsearch-es-http.elastic-system.svc.cluster.local
- name: ES_PORT
value: "9200"
- name: ES_USER
value: "elastic"
- name: ES_PASSWORD
valueFrom:
secretKeyRef:
name: elasticsearch-es-elastic-user
key: elastic

fileConfigs:
output-es.conf: |
# https://github.com/uken/fluent-plugin-elasticsearch
<match **>
@type elasticsearch
@id out_es
@log_level info
include_tag_key true
scheme http
host "#{ENV['ES_HOST']}"
port "#{ENV['ES_PORT']}"
user "#{ENV['ES_USER']}"
password "#{ENV['ES_PASSWORD']}"
reload_connections false
reconnect_on_error true
reload_on_failure true
request_timeout 30s
logstash_format true
logstash_prefix ${tag}
logstash_dateformat %Y.%m
sniffer_class_name Fluent::Plugin::ElasticsearchSimpleSniffer
suppress_type_name true
<buffer>
flush_at_shutdown true
flush_interval 10s
flush_thread_count 4
retry_max_interval 30s
</buffer>
</match>