我写了一个bash脚本,它在指定的文件夹中找到CSV文件,并使用正确的配置文件将它们管道到logstash中.但是,当运行此脚本时,我遇到以下错误,说关闭进程停止,导致无限循环,直到我用ctrl c手动停止它:

[2018-03-22T08:59:53,833][INFO ][logstash.runner ] Starting Logstash {"logstash.version"=>"6.2.3"}

[2018-03-22T08:59:54,211][INFO ][logstash.agent ] Successfully started Logstash API endpoint {:port=>9600}

[2018-03-22T08:59:57,970][INFO ][logstash.pipeline ] Starting pipeline {:pipeline_id=>"main", "pipeline.workers"=>2, "pipeline.batch.size"=>125, "pipeline.batch.delay"=>50}

[2018-03-22T08:59:58,116][INFO ][logstash.pipeline ] Pipeline started succesfully {:pipeline_id=>"main", :thread=>"#<0xf6851b3 run>"}0xf6851b3>

[2018-03-22T08:59:58,246][INFO ][logstash.agent ] Pipelines running {:count=>1, :pipelines=>["main"]}

[2018-03-22T08:59:58,976][INFO ][logstash.outputs.file ] Opening file {:path=>"/home/kevin/otrs_customer_user"}

[2018-03-22T09:00:06,471][WARN ][logstash.shutdownwatcher ] {"inflight_count"=>0, "stalling_thread_info"=>{["LogStash::Filters::CSV", {"separator"=>";", "columns"=>["IOT", "OID", "SUM", "XID", "change_by", "change_time", "city", "company", "company2", "create_by", "create_time", "customer_id", "email", "fax", "first_name", "id", "inst_city", "inst_first_name", "inst_last_name", "inst_street", "inst_zip", "last_name", "login", "mobile", "phone", "phone2", "street", "title", "valid_id", "varioCustomerId", "zip"], "id"=>"f1c74146d6672ca71f489aac1b4c2a332ae515996657981e1ef44b441a7420c8"}]=>[{"thread_id"=>23, "name"=>nil, "current_call"=>"[...]/logstash-core/lib/logstash/util/wrapped_synchronous_queue.rb:90:in `read_batch'"}]}}

[2018-03-22T09:00:06,484][ERROR][logstash.shutdownwatcher ] The shutdown process appears to be stalled due to busy or blocked plugins. Check the logs for more information.

[2018-03-22T09:00:11,438][WARN ][logstash.shutdownwatcher ] {"inflight_count"=>0, "stalling_thread_info"=>{["LogStash::Filters::CSV", {"separator"=>";", "columns"=>["IOT", "OID", "SUM", "XID", "change_by", "change_time", "city", "company", "company2", "create_by", "create_time", "customer_id", "email", "fax", "first_name", "id", "inst_city", "inst_first_name", "inst_last_name", "inst_street", "inst_zip", "last_name", "login", "mobile", "phone", "phone2", "street", "title", "valid_id", "varioCustomerId", "zip"], "id"=>"f1c74146d6672ca71f489aac1b4c2a332ae515996657981e1ef44b441a7420c8"}]=>[{"thread_id"=>23, "name"=>nil, "current_call"=>"[...]/logstash-core/lib/logstash/util/wrapped_synchronous_queue.rb:90:in `read_batch'"}]}}

当我用bash logstash -f xyz.config

input {

stdin {

id => "${LS_FILE}"

}

}

filter {

mutate {

add_field => { "foo_type" => "${FOO_TYPE}" }

add_field => { "[@metadata][LS_FILE]" => "${LS_FILE}"}

}

if [@metadata][LS_FILE] == "contacts.csv" {

csv {

separator => ";"

columns =>

[

"IOT",

"OID",

"SUM",

"XID",

"kundenid"

]

}

if [kundenid]{

mutate {

update => { "kundenid" => "n-%{kundenid}" }

}

}

}

}

output {

if [@metadata][LS_FILE] == "contacts.csv" {

file{

path => "~/contacts_file"

codec => json_lines

}

}

}

示例脚本:

LOGSTASH="/customer/app/logstash-6.2.3/bin/logstash"

for file in $(find $TARGETPATH -name *.csv) # Loop each file in given path

do

if [[ $file = *"foo"* ]]; then

echo "Importing $file"

export LS_FILE=$(basename $file)

bash $LOGSTASH -f $CFG_FILE < $file # Starting logstash

echo "file $file imported."

fi

done

我在bash脚本中导出环境变量,并将它们设置为logstash配置中的元数据,以便为不同的输入文件执行一些条件.文件中JSON的输出仅用于测试目的.

linux 启动logstash_linux – 从bash脚本启动时Logstash shutdown停止相关推荐

  1. linux logstash启动脚本,在Linux中从bash脚本启动时Logstash shutdown停止

    我写了一个bash脚本,它在指定的文件夹中找到CSV文件,并使用正确的配置文件将它们管道到logstash中.但是,当运行此脚本时,我遇到以下错误,说关闭进程停止,导致无限循环,直到我用ctrl c手 ...

  2. 解决Linux下无法利用shell脚本启动conda虚拟环境问题

    解决Linux下无法利用shell脚本启动conda虚拟环境问题 问题 直接在脚本中激活conda环境时遇到了一个问题 解决 查看.bashrc文件 .bashrc文件在 /home/用户名 里面,因 ...

  3. linux启动sh文件命令,Linux下如何写 .sh 脚本启动 项目

    Linux下如何写 .sh 脚本启动 项目 创建文件   mealcoupon.sh 内容如下: #!/bin/bash #这里可替换为你自己的执行程序,其他代码无需更改 APP_NAME=xhqy_ ...

  4. bash shell sleep_如何使用Linux Sleep命令暂停Bash脚本

    原标题:如何使用Linux Sleep命令暂停Bash脚本 Sleep是一个命令行实用程序,允许您将调用进程挂起一段指定的时间.也就是说,sleep命令在给定的时间内暂停下一个命令的执行. 当在bas ...

  5. bash脚本 sleep_如何使用Linux Sleep命令暂停Bash脚本

    bash脚本 sleep Fatmawati Achmad Zaenuri/Shutterstock.com Fatmawati Achmad Zaenuri / Shutterstock.com T ...

  6. shell 启动java程序_Shell 脚本启动java程序

    最近,做好了一段儿程序,但是在ubuntu系统下需要用命令行输入命令启动.于是研究了一下Shell脚本启动的方法. 刚开始接触Shell脚本,一头雾水.不过最终还是实现了,和大家分享一下: 不过需要注 ...

  7. Linux下杂乱无章的Bash脚本传入参数--如何解析?

    无论是外置的getopt命令,亦或是bash内置的getopts函数,都对bash脚本的传入参数做了一些规定,比如强制规定了短参数"-t 1",长参数"--test 1& ...

  8. 在linux里面怎么启动. run.sh,Shell脚本启动django 的runserver

    #! /bin/sh #echo $0 文件名 #echo $1 第一个参数 #echo "$*" 所有参数列表 #echo "$@" 所有参数列表 #myna ...

  9. Linux——编写简单的Bash脚本

    一.创建和执行Bash shell脚本: 借助Bash shell环境和脚本编写功能,可以将linux命令与shell脚本组合在一起,从而解决实际问题,可以通过文本编辑器打开新的空文件来创建Bash ...

最新文章

  1. SAP PM 入门系列12 - IW32 下达一个维护订单
  2. boost::asio与ACE的对比
  3. 从白盒测试到单元测试基础原理
  4. java mysql读取多条数据_myeclipse 使用Java访问mysql数据库,数据库中有多条记录,为何只能读出一条数据??...
  5. 教你消灭 Java 代码的“坏味道”
  6. 机器学习笔记(四)---- 逻辑回归的多分类
  7. MVC框架中的值提供机制(二)
  8. Java拓展(数据类型及其大小)
  9. 结构型设计模式(2)—— 外观模式(Facade Pattern)
  10. 06.大厂面试题:请讲下SpringBoot的日志框架原理
  11. java无头浏览器_PuppeteerSharp无头浏览器.Net Sdk(Puppeteer)
  12. 如何安装ioncube扩展
  13. 标题:史丰收速算 史丰收速算法的革命性贡献是:从高位算起,预测进位。不需要九九表,彻底颠覆了传统手算! 速算的核心基础是:1位数乘以多位数的乘法。 其中,乘以7是最复杂
  14. 定义一个复数类Complex,使得代码能够进行下面的工作:
  15. IM模块-UiCollectionView列表显示气泡图片
  16. 在PR中如何调整图像大小的分辨率
  17. ubuntu16.04更新系统后桌面出错的解决办法
  18. 为什么要建议用自增列做主键
  19. 第 8 章 Python 计算生态
  20. Mangopi MQ-R:T113-s3编译Tina Linux系统

热门文章

  1. 迪士尼的“元宇宙梦”醒了
  2. 370、合格弱电工程师必备的120条基础常识
  3. EA下载问题解决方案
  4. 解决使用GPU时遇到的问题
  5. 鸿蒙大陆鸿蒙战凯,鸿蒙大陆10.2
  6. Windows 下如何使用管理员的身份运行 DOS 窗口
  7. 易语言随机生成MAC源码
  8. 前端可视化大屏设置全屏模式方法
  9. Navicat v15
  10. 用布谷鸟算法求解基站选址