我安装了elasticsearch 5.0.1和相应的摄取附件。尝试从Shell脚本索引PDF文档,如下所示

#!/bin/ksh
var=$(base64 file_name.pdf)

var1=$(curl -XPUT 'http://localhost:9200/my_index4/my_type/my_id?pipeline=attachment&pretty' -d' { "data" : $var }')
echo $var1
I got error as
{ "error" : { "root_cause" : [ { "type" : "exception", "reason" :
"java.lang.IllegalArgumentException: ElasticsearchParseException[Error parsing document in field
[data]]; nested: IllegalArgumentException[Illegal base64 character 24];",
 "header" : { "processor_type" : "attachment" } } ]...

任何人都可以帮助解决上述问题。不确定我是否传递了无效的base64字符?

请注意,当我这样通过时,它起作用了!
var1=$(curl -XPUT 'http://localhost:9200/my_index4/my_type/my_id?pipeline=attachment&pretty'
-d' { "data" : "e1xydGYxXGFuc2kNCkxvcmVtIGlwc3VtIGRvbG9yIHNpdCBhbWV0DQpccGFyIH0=" }')

最佳答案

我猜想问题在于 shell 不能在单引号内扩展变量,您需要双引号将其扩展。即

更改-d' { "data" : $var }'

-d '{"data" : "'"$(base64 file_name.pdf)"'"}'

直接传递base64流。

(要么)
-d '{"data" : "'"$var"'"}'

有关ksh here中的引号和变量的更多信息。

10-01 17:11
查看更多