webentwicklung-frage-antwort-db.com.de

zuordnungen von Python-Elasticsearch-Clients während Indexerstellung

Ich kann Zuordnungen des Indexes, die im curl-Befehl erstellt werden, wie folgt festlegen:

{  
  "mappings":{  
    "logs_june":{  
      "_timestamp":{  
        "enabled":"true"
      },
      "properties":{  
        "logdate":{  
          "type":"date",
          "format":"dd/MM/yyy HH:mm:ss"
        }
      }
    }
  }
}

Aber ich muss diesen Index mit Elasticsearch Client in Python erstellen und Mappings setzen. Wie ist der Weg? Ich habe etwas ausprobiert, aber nicht gearbeitet:

self.elastic_con = Elasticsearch([Host], verify_certs=True)
self.elastic_con.indices.create(index="accesslog", ignore=400)
params = "{\"mappings\":{\"logs_june\":{\"_timestamp\": {\"enabled\": \"true\"},\"properties\":{\"logdate\":{\"type\":\"date\",\"format\":\"dd/MM/yyy HH:mm:ss\"}}}}}"
self.elastic_con.indices.put_mapping(index="accesslog",body=params)
28
user4005632

Sie können das Mapping einfach wie folgt in den Aufruf create einfügen:

from elasticsearch import Elasticsearch

self.elastic_con = Elasticsearch([Host], verify_certs=True)
mapping = '''
{  
  "mappings":{  
    "logs_june":{  
      "_timestamp":{  
        "enabled":"true"
      },
      "properties":{  
        "logdate":{  
          "type":"date",
          "format":"dd/MM/yyy HH:mm:ss"
        }
      }
    }
  }
}'''
self.elastic_con.indices.create(index='test-index', ignore=400, body=mapping)
43
Val

Nun, mit der allgemeinen Python-Syntax gibt es einen einfacheren Weg:

from elasticsearch import Elasticsearch
# conntect es
es = Elasticsearch([{'Host': config.elastic_Host, 'port': config.elastic_port}])
# delete index if exists
if es.indices.exists(config.elastic_urls_index):
    es.indices.delete(index=config.elastic_urls_index)
# index settings
settings = {
    "settings": {
        "number_of_shards": 1,
        "number_of_replicas": 0
    },
    "mappings": {
        "urls": {
            "properties": {
                "url": {
                    "type": "string"
                }
            }
        }
     }
}
# create index
es.indices.create(index=config.elastic_urls_index, ignore=400, body=settings)
21
Elzor

Die Arbeit mit dem Python-API-Client kann schwierig sein, und Sie müssen häufig die inneren Teile der JSON-Spezifikationsdokumentationen für Schlüsselwortargumente bereitstellen.

Bei der Methode put_mapping müssen Sie anstelle des vollständigen JSON-Dokuments "Zuordnungen" den Parameter document_type und nur den inner -Abschnitt des Dokuments "Zuordnungen" angeben:

self.client.indices.put_mapping(
    index="accesslog",
    doc_type="logs_june",
    body={
        "_timestamp": {  
            "enabled":"true"
        },
        "properties": {  
            "logdate": {  
                "type":"date",
                "format":"dd/MM/yyy HH:mm:ss"
            }
        }
    }
)
10
James Murty

Ein weiteres Python-Client-Beispiel zum Erhöhen des Feldlimits durch den Index zum Erstellen 

from elasticsearch import Elasticsearch

es = Elasticsearch([{'Host': config.elastic_Host, 'port': config.elastic_port}])
raiseFieldLimit = '''
{  
  "index.mapping.total_fields.limit": 2000
}'''

es.indices.create(index='myindex', body=raiseFieldLimit)
0
Pari Rajaram