{"id":164,"date":"2020-03-14T19:38:01","date_gmt":"2020-03-14T10:38:01","guid":{"rendered":"http:\/\/www.skyer9.pe.kr\/wordpress\/?p=164"},"modified":"2020-03-28T22:05:34","modified_gmt":"2020-03-28T13:05:34","slug":"filebeat-kafka-logstash","status":"publish","type":"post","link":"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=164","title":{"rendered":"Filebeat + Kafka + Logstash"},"content":{"rendered":"<h1>Filebeat + Kafka + Logstash<\/h1>\n<p>\uc5b4\ub5a0\ud55c \uc774\uc720\ub85c ELK \uc2a4\ud0dd\uc774 \ub2e4\uc6b4\ub418\uc5c8\uc744 \ub54c, \uc800\uc7a5\ud558\uc9c0 \ubabb\ud55c \ub85c\uadf8\ub97c \ubcf4\uad00\ud558\uae30 \uc704\ud574 <code>Apache Kafka<\/code> \ub97c \uc774\uc6a9\ud569\ub2c8\ub2e4.<\/p>\n<p>JAVA 8 \uc774\uc0c1\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\uc73c\uba74 <a href=\"\/wordpress\/?p=140\">\uc5ec\uae30<\/a> \ub97c \ucc38\uc870\ud574\uc11c \uc124\uce58\ud569\ub2c8\ub2e4.<\/p>\n<p>ELK \uc2a4\ud0dd\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\ub2e4\uba74 <a href=\"\/wordpress\/?p=142\">\uc5ec\uae30<\/a> \ub97c \ucc38\uc870\ud574\uc11c \uc124\uce58\ud569\ub2c8\ub2e4.<\/p>\n<p>Filebeat \uac00 \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\ub2e4\uba74 <a href=\"\/wordpress\/?p=158\">\uc5ec\uae30<\/a> \ub97c \ucc38\uc870\ud574\uc11c \uc124\uce58\ud569\ub2c8\ub2e4.<\/p>\n<p>Kafka \uac00 \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\uc73c\uba74 <a href=\"\/wordpress\/?p=169\">\uc5ec\uae30<\/a> \ub97c \ucc38\uc870\ud558\uc5ec \uc124\uce58\ud569\ub2c8\ub2e4.<\/p>\n<h2>Kafka \ub85c \ub85c\uadf8 \uc804\uc1a1\ud558\uae30<\/h2>\n<p>\uae30\uc874\uc5d0 filebeat \uc5d0\uc11c logstash \ub85c \uc9c1\uc811 \ub85c\uadf8\ub97c \uc804\uc1a1\ud558\ub358 \ubc29\uc2dd\uc5d0\uc11c, Kafka \ub97c \uac70\uccd0 \uc804\uc1a1\ub418\ub3c4\ub85d \uc218\uc815\ud569\ub2c8\ub2e4.<\/p>\n<p>\uc6b0\uc120 filebeat \uac00 Kafka \ub85c \ub85c\uadf8\ub97c \uc804\uc1a1\ud558\ub3c4\ub85d \uc218\uc815\ud569\ub2c8\ub2e4.<\/p>\n<pre><code class=\"language-bash\">sudo vi \/etc\/filebeat\/filebeat.yml<\/code><\/pre>\n<pre><code class=\"language-configuration\">filebeat.inputs:\n- type: log\n  paths:\n    - \/var\/log\/nginx\/*.log\n  exclude_files: [&#039;\\.gz$&#039;]\n  # scan_frequency: 10s\n\noutput.kafka:\n  hosts: [&quot;&lt;\uce74\ud504\uce74\uc11c\ubc84\uc544\uc774\ud53c&gt;:9092&quot;]\n  codec.format:\n    string: &#039;%{[message]}&#039;\n  topic: &#039;skyer9.pe.kr&#039;\n  partition.round_robin:\n    reachable_only: false\n\n# output.logstash:\n#   hosts: [&quot;172.31.31.196:5400&quot;]\n#   # ssl.certificate_authorities: [&quot;\/etc\/elk-certs\/elk-ssl.crt&quot;]\n#   # ssl.certificate: &quot;\/etc\/elk-certs\/elk-ssl.crt&quot;\n#   # ssl.key: &quot;\/etc\/elk-certs\/elk-ssl.key&quot;<\/code><\/pre>\n<p>\uc11c\ube44\uc2a4\ub97c \uc7ac\uc2dc\uc791 \ud569\ub2c8\ub2e4.<\/p>\n<pre><code class=\"language-bash\">sudo systemctl restart filebeat<\/code><\/pre>\n<h2>Logstash \uc5d0\uc11c \ub85c\uadf8 \uc218\uc2e0\ud558\uae30<\/h2>\n<pre><code class=\"language-bash\">sudo vi \/etc\/logstash\/conf.d\/logstash-nginx-es.conf<\/code><\/pre>\n<pre><code class=\"language-configuration\">input {\n    kafka {\n        bootstrap_servers =&gt; &quot;&lt;\uce74\ud504\uce74\uc11c\ubc84\uc544\uc774\ud53c&gt;:9092&quot;\n            topics =&gt; [&quot;skyer9.pe.kr&quot;]\n            consumer_threads =&gt; 2\n            # group_id =&gt; &quot;Your group&quot;\n    }\n}\n\nfilter {\n    grok {\n        match =&gt; [ &quot;message&quot; , &quot;%{COMBINEDAPACHELOG}+%{GREEDYDATA:extra_fields}&quot;]\n        overwrite =&gt; [ &quot;message&quot; ]\n    }\n    mutate {\n        convert =&gt; [&quot;response&quot;, &quot;integer&quot;]\n        convert =&gt; [&quot;bytes&quot;, &quot;integer&quot;]\n        convert =&gt; [&quot;responsetime&quot;, &quot;float&quot;]\n    }\n    # geoip {\n    #     source =&gt; &quot;clientip&quot;\n    #     target =&gt; &quot;geoip&quot;\n    #     add_tag =&gt; [ &quot;nginx-geoip&quot; ]\n    # }\n    date {\n        match =&gt; [ &quot;timestamp&quot; , &quot;dd\/MMM\/YYYY:HH:mm:ss Z&quot; ]\n        remove_field =&gt; [ &quot;timestamp&quot; ]\n    }\n    useragent {\n        source =&gt; &quot;agent&quot;\n    }\n}\n\noutput {\n    elasticsearch {\n        hosts =&gt; [&quot;localhost:9200&quot;]\n        index =&gt; &quot;weblogs-%{+YYYY.MM.dd}&quot;\n        document_type =&gt; &quot;nginx_logs&quot;\n    }\n    stdout { codec =&gt; rubydebug }\n}<\/code><\/pre>\n<p>\uc11c\ube44\uc2a4\ub97c \uc7ac\uc2dc\uc791\ud569\ub2c8\ub2e4.<\/p>\n<pre><code class=\"language-bash\">sudo systemctl restart logstash<\/code><\/pre>\n<p>\uc778\ub371\uc2a4\uc5d0 \uc785\ub825\uc774 \uc798 \uc548\ub420 \ub54c\ub294 \uc778\ub371\uc2a4\ub97c \uc0ad\uc81c\ud558\uace0 \ub2e4\uc2dc \ud14c\uc2a4\ud2b8 \ud569\ub2c8\ub2e4.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Filebeat + Kafka + Logstash \uc5b4\ub5a0\ud55c \uc774\uc720\ub85c ELK \uc2a4\ud0dd\uc774 \ub2e4\uc6b4\ub418\uc5c8\uc744 \ub54c, \uc800\uc7a5\ud558\uc9c0 \ubabb\ud55c \ub85c\uadf8\ub97c \ubcf4\uad00\ud558\uae30 \uc704\ud574 Apache Kafka \ub97c \uc774\uc6a9\ud569\ub2c8\ub2e4. JAVA 8 \uc774\uc0c1\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\uc73c\uba74 \uc5ec\uae30 \ub97c \ucc38\uc870\ud574\uc11c \uc124\uce58\ud569\ub2c8\ub2e4. ELK \uc2a4\ud0dd\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\ub2e4\uba74 \uc5ec\uae30 \ub97c \ucc38\uc870\ud574\uc11c \uc124\uce58\ud569\ub2c8\ub2e4. Filebeat \uac00 \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\ub2e4\uba74 \uc5ec\uae30 \ub97c \ucc38\uc870\ud574\uc11c \uc124\uce58\ud569\ub2c8\ub2e4. Kafka \uac00 \uc124\uce58\ub418\uc5b4 \uc788\uc9c0 \uc54a\uc73c\uba74\u2026 <span class=\"read-more\"><a href=\"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=164\">Read More &raquo;<\/a><\/span><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[6],"tags":[],"class_list":["post-164","post","type-post","status-publish","format-standard","hentry","category-elasticsearch"],"_links":{"self":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/164","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=164"}],"version-history":[{"count":9,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/164\/revisions"}],"predecessor-version":[{"id":347,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/164\/revisions\/347"}],"wp:attachment":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=164"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=164"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=164"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}