Logstash 数据管道测试案例:从 Filebeat 接收日志并输出至黑屏幕与 Elasticsearch(基于Rocky Linux 9.6)

测试案例-编写logstash配置文件(logstash节点执行)

这里采用循序渐进的方式展开,可以先写一个简单的测试输出到屏幕。 编写一个将数据输出到屏幕的配置文件:

复制代码
vi /etc/logstash/conf.d/test01.conf
input {
  beats {
    port => 5044 #接收来自192.168.92.17运行的filebeat,发送给192.168.92.16:5044
  }
}

output {
  stdout { } #这里是默认输出到192.168.92.16(logstash节点)的黑屏幕上面
}

修改/etc/logstash/logstash.yml文件,添加如下字段:

复制代码
#文件的87行,设置管道配置文件路径为/etc/logstash/conf.d
path.config: /etc/logstash/conf.d #conf.d目录自己创建

手动启动 Logstash 进程并加载指定的配置文件,启动方式如下:(-f后面的文件使用绝对路径来测试,没问题)

复制代码
logstash -f /etc/logstash/conf.d/test01.conf

出现 Successfully started Logstash APl endpoint 就表示启动成功。

启动成功后,我们尝试访问nginx站点,然后生成的日志数据输出到屏幕上。

复制代码
{
           "ecs" => {
        "version" => "1.12.0"
    },
         "agent" => {
                  "id" => "029c6c1b-a31d-422d-a8f3-467785cacc07",
             "version" => "7.17.10",
            "hostname" => "filebeat01",
        "ephemeral_id" => "dbe22ac1-7219-4b78-a1cf-9c3cb6052a83",
                "name" => "filebeat01",
                "type" => "filebeat"
    },
      "@version" => "1",
          "tags" => [
        [0] "beats_input_codec_plain_applied"
    ],
         "event" => {
         "dataset" => "nginx.ingress_controller",
          "module" => "nginx",
        "timezone" => "+08:00"
    },
       "message" => "192.168.92.1 - - [13/Mar/2026:13:33:19 +0800] \"GET /icons/poweredby.png HTTP/1.1\" 200 15443 \"http://192.168.92                   .17/\" \"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/143.0.0.0 Safari/537.36 Edg/143.0.0.0                   \" \"-\"",
    "@timestamp" => 2026-03-13T12:51:29.768Z,
       "service" => {
        "type" => "nginx"
    },

日志文件已经传输过来了,接下来测试把这些数据写入到elasticsearch中。

重新编写配置文件:(vi /etc/logstash/conf.d/test02.conf)(修改地点是logstash节点)

复制代码
input {
  beats {
    port => 5044
  }
}

output {
  elasticsearch {
    hosts => ["192.168.92.14"]
    index => "nginx-%{+YYYY.MM.dd}"
  }
}

手动启动 Logstash 进程并加载指定的配置文件,启动方式如下:(-f后面的文件使用绝对路径来测试,没问题)

复制代码
logstash -f /etc/logstash/conf.d/test02.conf

尝试访问nginx(浏览器上输入192.168.92.17:80)查看 elasticsearch-head中是否有新的索引被创建出来。

相关推荐
用户3946235365245 分钟前
Uboot - DM框架
linux
huangdong_11 分钟前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案
大数据·前端·数据库
Java 码思客19 分钟前
【ElasticSearch从入门到架构师】第9章:ES 读写底层流程深度拆解
大数据·elasticsearch·搜索引擎
ttt606_40 分钟前
门店业绩上报系统功能拆解:门店业绩上报如何提高数据精确度与时效性?
大数据·人工智能
ACP广源盛139246256731 小时前
GSV2221@ACP#DP 1.4 MST 多屏转换芯片,物理 AI 多模态交互的视觉中枢
大数据·人工智能·嵌入式硬件·gpt·spark
鹤落晴春1 小时前
RH124问答5:管理本地用户和组
linux·运维·服务器
其实防守也摸鱼2 小时前
软件安全与漏洞--Windows底层原理与软件逆向工程基础
linux·网络·数据库·算法·安全·安全架构·软件安全与漏洞
云栖梦泽2 小时前
Linux内核与驱动:pinctl子系统和GPIO子系统
linux·单片机·嵌入式硬件
blue_dou2 小时前
灵活拓展能力对决:多款CRM自定义与数据互通实测
大数据·人工智能
tianxingjian20192 小时前
科技创新核心工具,TRIZ理论助力技术难题高效突破
大数据·人工智能·科技