EEST的ElasticSearch索引/插入失败

时间:2016-03-03 23:41:36

标签: c# json elasticsearch kibana nest

我正在尝试将一些JSON数据插入到弹性搜索中进行测试。

这是代码:

    var node = new Uri("http://localhost:9200");
    var settings = new ConnectionSettings(node);        
    settings.DefaultIndex("FormId");

    var client = new ElasticClient(settings);

    var myJson = @"{ ""hello"" : ""world"" }";
    var response = client.Index(myJson, i => i.Index("FormId")
                        .Type("resp")
                        .Id((int)r.id)
                        .Refresh()
                        );

没有插入任何内容,我从ES收到以下错误: {在PUT上对无效的低级别调用构建无效的NEST响应:/ FormId / resp / 1?refresh = true}

我试图找到一些例子,但都使用预定义的数据结构,而我想使用非结构化数据的JSON数据。

以上错误消息来自NEST。 弹性回复(并在日志中写入)以下消息: MapperParsingException [无法解析]; nested- NotXContentException [只能在某些xcontent字节或压缩的xcontent字节上调用Compressor检测];

无法解析{“”hello“”:“”world“”} ????

1 个答案:

答案 0 :(得分:10)

一些观察结果:

  • 索引名称必须为小写
  • 虽然可以在配置中关闭此功能,但在将文档编入索引时将自动创建索引。如果您还希望控制文档的映射,最好先创建索引。
  • 使用匿名类型来表示您要发送的json(如果您愿意,可以使用低级客户端发送json字符串,即client.LowLevel,但使用匿名类型可能更容易)。
  • 响应中的.DebugInformation应包含请求失败原因的所有详细信息

以下是演示如何入门的示例

void Main()
{
    var node = new Uri("http://localhost:9200");
    var settings = new ConnectionSettings(node)
    // lower case index name
    .DefaultIndex("formid");

    var client = new ElasticClient(settings);

    // use an anonymous type
    var myJson = new { hello = "world" };

    // create the index if it doesn't exist
    if (!client.IndexExists("formid").Exists)
    {
        client.CreateIndex("formid");
    }

    var indexResponse = client.Index(myJson, i => i
        .Index("formid")
        .Type("resp")
        .Id(1)
        .Refresh()
    );
}

现在,如果我们向http://localhost:9200/formid/resp/1发出GET请求,我们会收回文件

{
   "_index": "formid",
   "_type": "resp",
   "_id": "1",
   "_version": 1,
   "found": true,
   "_source": {
      "hello": "world"
   }
}