2014-04-22 260 views
8

如何使用Elasticsearch Nest API重新創建以下索引?創建索引Nest

這裏是包括映射索引中的JSON:

{ 
    "settings": { 
     "analysis": { 
      "filter": { 
       "trigrams_filter": { 
        "type":  "ngram", 
        "min_gram": 3, 
        "max_gram": 3 
       } 
      }, 
      "analyzer": { 
       "trigrams": { 
        "type":  "custom", 
        "tokenizer": "standard", 
        "filter": [ 
         "lowercase", 
         "trigrams_filter" 
        ] 
       } 
      } 
     } 
    }, 
    "mappings": { 
     "data": { 
     "_all" : {"enabled" : true}, 
      "properties": { 
       "text": { 
        "type":  "string", 
        "analyzer": "trigrams" 
       } 
      } 
     } 
    } 
} 

這裏是我的嘗試:

var newIndex = client.CreateIndexAsync(indexName, index => index 
      .NumberOfReplicas(replicas) 
      .NumberOfShards(shards) 
      .Settings(settings => settings 
       .Add("merge.policy.merge_factor", "10") 
       .Add("search.slowlog.threshold.fetch.warn", "1s") 
       .Add("mapping.allow_type_wrapper", true)) 
      .AddMapping<Object>(mapping => mapping 
       .IndexAnalyzer("trigram") 
       .Type("string")) 
); 

的文件沒有提到這事?

UPDATE:

研究發現,使用 var index = new IndexSettings()

this後,然後將分析字符串文字JSON。

index.Add("analysis", @"{json});

一個在哪裏可以找到更多像這樣的例子,做這項工作?

+0

如果你不想處理lambda代碼,答案在http://stackoverflow.com/questions/29026007/elasticsearch-nest-create-an-index-through-elasticclient-by-specifying-json/29068816#29068816描述如何將原始json傳遞給ElasticClient創建索引。在某些使用情況下,這可能更容易或更靈活。 – mcating

回答

10

有作爲Nest Create Index Documentation概述,你可以做到這一點主要有兩種方式:

在這裏你直接申報索引設置,流利的字典條目的方式。就像你在上面的例子中所做的一樣。我在本地測試了它,它產生了與上面的JSON匹配的索引設置。

var response = client.CreateIndex(indexName, s => s 
     .NumberOfReplicas(replicas) 
     .NumberOfShards(shards) 
     .Settings(settings => settings 
     .Add("merge.policy.merge_factor", "10") 
     .Add("search.slowlog.threshold.fetch.warn", "1s") 
     .Add("mapping.allow_type_wrapper", true) 
     .Add("analysis.filter.trigrams_filter.type", "nGram") 
     .Add("analysis.filter.trigrams_filter.min_gram", "3") 
     .Add("analysis.filter.trigrams_filter.max_gram", "3") 
     .Add("analysis.analyzer.trigrams.type", "custom") 
     .Add("analysis.analyzer.trigrams.tokenizer", "standard") 
     .Add("analysis.analyzer.trigrams.filter.0", "lowercase") 
     .Add("analysis.analyzer.trigrams.filter.1", "trigrams_filter") 
     ) 
     .AddMapping<Object>(mapping => mapping 
      .Type("data") 
      .AllField(af => af.Enabled()) 
      .Properties(prop => prop 
      .String(sprop => sprop 
       .Name("text") 
       .IndexAnalyzer("trigrams") 
      ) 
      ) 
     ) 
    ); 

請注意,NEST還包括使用強類型類創建索引設置的功能。如果我有時間完成它,我會在後面舉一個例子。

希望這會有所幫助。

3

小例如:

  EsClient.CreateIndex("indexname", c => c 
       .NumberOfReplicas(replicasNr) 
       .NumberOfShards(shardsNr) 
      .Settings(s => s 
       .Add("merge.policy.merge_factor", "10") 
       .Add("search.slowlog.threshold.fetch.warn", "15s") 
      ) 

      #region Analysis 
      .Analysis(descriptor => descriptor 
       .Analyzers(bases => bases 
        .Add("folded_word", new CustomAnalyzer() 
        { 
         Filter = new List<string> { "icu_folding", "trim" }, 
         Tokenizer = "standard" 
        } 
        ) 

      .TokenFilters(i => i 
         .Add("engram", new EdgeNGramTokenFilter 
         { 
          MinGram = 1, 
          MaxGram = 20 
         } 
         ) 
      ) 
      .CharFilters(cf => cf 
         .Add("drop_chars", new PatternReplaceCharFilter 
         { 
          Pattern = @"[^0-9]", 
          Replacement = "" 
         } 

      ) 
      #endregion 

      #region Mapping Categories 
      .AddMapping<Categories>(m => m 
       .Properties(props => props 
        .MultiField(mf => mf 
          .Name(n => n.Label_en) 
          .Fields(fs => fs 
           .String(s => s.Name(t => t.Label_en).Analyzer("folded_word")) 
           ) 
         ) 
      ) 
      #endregion 
    ); 
9

萬一人有NEST 2.0時,.NumberOfReplicas(x)的.NumberOfShards(y)是在設置區域現在設置下蘭巴表達內,從而指定。

 EsClient.CreateIndex("indexname", c => c 
     .Settings(s => s 
      .NumberOfReplicas(replicasNr) 
      .NumberOfShards(shardsNr) 
     ) 

NEST 2.0有很多變化,並且移動了一些東西,因此這些答案肯定是一個很好的起點。您可能需要爲NEST 2.0更新進行一些調整。

+0

謝謝你 - 在文檔中找不到它。當然,直到這個評論我真的不知道我在找什麼。 :-) – hardba11

2

如果有人已經遷移到NEST 2.4,並且具有相同的問題 - 你需要定義在這樣的指標設置您的自定義過濾器和分析器:

 elasticClient.CreateIndex(_indexName, i => i 
      .Settings(s => s 
       .Analysis(a => a 
        .TokenFilters(tf => tf 
         .EdgeNGram("edge_ngrams", e => e 
          .MinGram(1) 
          .MaxGram(50) 
          .Side(EdgeNGramSide.Front))) 
         .Analyzers(analyzer => analyzer 
          .Custom("partial_text", ca => ca 
           .Filters(new string[] { "lowercase", "edge_ngrams" }) 
           .Tokenizer("standard")) 
          .Custom("full_text", ca => ca 
           .Filters(new string[] { "standard", "lowercase" }) 
           .Tokenizer("standard"))))));