Elasti c Поиск GeoLocation не соответствует типу geo_point с помощью NEST - PullRequest
0 голосов
/ 17 июня 2020

Я создаю индекс Dynami c с помощью NEST (версия 7.7.1) в C#. Данные содержат геолокацию, которую необходимо сохранить как geo_point в поиске elasti c (версия 7.6.1 на elasti c .co). Но картографирования не происходит. он всегда принимает его как объект вместо geo_point.

Я пробовал несколько вариантов, таких как 1) Автоматическое сопоставление 2) Ручное сопоставление 3) Автоматическое сопоставление с ручным сопоставлением.

следующий код

Uri EsInstance = new Uri(EsUrl);
ConnectionSettings EsConfiguration = new ConnectionSettings(EsInstance);

if (!string.IsNullOrWhiteSpace(EsUser))
    EsConfiguration.BasicAuthentication(EsUser, EsPass);
EsClient = new ElasticClient(EsConfiguration);

var settings = new IndexSettings { NumberOfReplicas = 2, NumberOfShards = 5 };
indexConfig = new IndexState
{
    Settings = settings
};


var res = await EsClient.CreateIndex(indexName,
                            c => c.Index(indexName)
                                  .Map<TripInsightDocument>(
                                        m => m.Properties(ps => ps)
                                            .AutoMap()
                                            .Properties(ps => ps
                                                .Object<TripInsightLeg>(o => o
                                                    .Name(n => n.legs)
                                                    .AutoMap()
                                                    .Properties(lp => lp
                                                        .GeoPoint(gp => gp.Name(fn => fn.fpos).IgnoreMalformed(true))
                                                        .GeoPoint(gp => gp.Name(fn => fn.tpos).IgnoreMalformed(true))
                                                    )
                                                )
                                                .Object<TripInsightStop>(o => o
                                                    .Name(n => n.stops)
                                                    //.AutoMap()
                                                    .Properties(lp => lp
                                                        .GeoPoint(gp => gp.Name(fn => fn.pos).IgnoreMalformed(true))
                                                     )
                                                )
                                                .Object<TripInsightSegmt>(o => o
                                                    .Name(n => n.segmts)
                                                    //.AutoMap()
                                                    .Properties(lp => lp.GeoPoint(gp => gp.Name(fn => fn.fpos).IgnoreMalformed(true))
                                                                        .GeoPoint(gp => gp.Name(fn => fn.tpos).IgnoreMalformed(true))
                                                    )
                                                )
                                                .Object<TripInsightGFence>(o => o
                                                    .Name(n => n.gfence)
                                                    //.AutoMap()
                                                    .Properties(lp => lp.GeoPoint(gp => gp.Name(fn => fn.pos).IgnoreMalformed(true)))
                                                )
                                            )
                                   ).RequestConfiguration(r => r
                                        .DisableDirectStreaming()
                                   )
                                  .InitializeUsing(esh.indexConfig));

Ниже приведен результат сопоставления

{
  "mapping": {
    "_doc": {
      "properties": {
        "avgspeed": {
          "type": "float"
        },
        "cap": {
          "type": "float"
        },
        "cewbno": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "cid": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "dest": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "dfrq": {
          "type": "float"
        },
        "dfrqug": {
          "type": "float"
        },
        "did": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "dkts": {
          "type": "long"
        },
        "drv2mob": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "drv2nm": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "drvmob": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "drvnm": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "etm": {
          "type": "date"
        },
        "gfence": {
          "properties": {
            "gfname": {
              "type": "text",
              "fields": {
                "keyword": {
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "indt": {
              "type": "date"
            },
            "outdt": {
              "type": "date"
            },
            "pos": {
              "properties": {
                "lat": {
                  "type": "float"
                },
                "lon": {
                  "type": "float"
                }
              }
            },
            "stime": {
              "type": "float"
            }
          }
        },
        "legs": {
          "properties": {
            "aat": {
              "type": "date"
            },
            "adt": {
              "type": "date"
            },
            "arvrmk": {
              "type": "text",
              "fields": {
                "keyword": {
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "avgspeed": {
              "type": "float"
            },
            "deprmk": {
              "type": "text",
              "fields": {
                "keyword": {
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "floc": {
              "type": "text",
              "fields": {
                "keyword": {
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "fpos": {
              "properties": {
                "lat": {
                  "type": "float"
                },
                "lon": {
                  "type": "float"
                }
              }
            },
            "gat": {
              "type": "date"
            },
            "gdt": {
              "type": "date"
            },
            "lname": {
              "type": "text",
              "fields": {
                "keyword": {
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "lno": {
              "type": "long"
            },
            "sta": {
              "type": "date"
            },
            "std": {
              "type": "date"
            },
            "stime": {
              "type": "float"
            },
            "tloc": {
              "type": "text",
              "fields": {
                "keyword": {
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "todist": {
              "type": "float"
            },
            "totime": {
              "type": "float"
            },
            "tpos": {
              "properties": {
                "lat": {
                  "type": "float"
                },
                "lon": {
                  "type": "float"
                }
              }
            }
          }
        },
        "load": {
          "type": "float"
        },
        "mfs": {
          "type": "long"
        },
        "mrktveh": {
          "type": "boolean"
        },
        "org": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "pkgs": {
          "type": "float"
        },
        "portdiv": {
          "type": "boolean"
        },
        "prepby": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "prov": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "remarks": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "rutcd": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "rutnm": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "segmts": {
          "properties": {
            "avgspeed": {
              "type": "float"
            },
            "fpos": {
              "properties": {
                "lat": {
                  "type": "float"
                },
                "lon": {
                  "type": "float"
                }
              }
            },
            "ftime": {
              "type": "date"
            },
            "segid": {
              "type": "long"
            },
            "todist": {
              "type": "float"
            },
            "totime": {
              "type": "float"
            },
            "tpos": {
              "properties": {
                "lat": {
                  "type": "float"
                },
                "lon": {
                  "type": "float"
                }
              }
            },
            "trdist": {
              "type": "float"
            },
            "trtime": {
              "type": "float"
            },
            "ttime": {
              "type": "date"
            }
          }
        },
        "stm": {
          "type": "date"
        },
        "stops": {
          "properties": {
            "ftime": {
              "type": "date"
            },
            "pos": {
              "properties": {
                "lat": {
                  "type": "float"
                },
                "lon": {
                  "type": "float"
                }
              }
            },
            "seqid": {
              "type": "long"
            },
            "stime": {
              "type": "float"
            },
            "trdist": {
              "type": "float"
            },
            "ttime": {
              "type": "date"
            }
          }
        },
        "stpnts": {
          "type": "long"
        },
        "tgpnts": {
          "type": "long"
        },
        "todist": {
          "type": "float"
        },
        "totime": {
          "type": "float"
        },
        "tripdt": {
          "type": "date"
        },
        "tripid": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "tugpnts": {
          "type": "long"
        },
        "vid": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "vndnm": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "vol": {
          "type": "float"
        },
        "wt": {
          "type": "float"
        }
      }
    }
  }
}

1 Ответ

0 голосов
/ 18 июня 2020

Проблема заключалась в том, что я выполнял сопоставление перед инициализацией index. Просто поменял местами порядок выполнения, и теперь он работает правильно

var res = await EsClient.CreateIndex(indexName,
                            c => c.Index(indexName)
                                  //Initialized index before updating mapping
                                  .InitializeUsing(esh.indexConfig) 
                                  .Map<TripInsightDocument>(
                                        m => m.Properties(ps => ps)
                                            .AutoMap()
                                            .Properties(ps => ps
                                                .Object<TripInsightLeg>(o => o
                                                    .Name(n => n.legs)
                                                    .AutoMap()
                                                    .Properties(lp => lp
                                                        .GeoPoint(gp => gp.Name(fn => fn.fpos).IgnoreMalformed(true))
                                                        .GeoPoint(gp => gp.Name(fn => fn.tpos).IgnoreMalformed(true))
                                                    )
                                                )
                                                .Object<TripInsightStop>(o => o
                                                    .Name(n => n.stops)
                                                    //.AutoMap()
                                                    .Properties(lp => lp
                                                        .GeoPoint(gp => gp.Name(fn => fn.pos).IgnoreMalformed(true))
                                                     )
                                                )
                                                .Object<TripInsightSegmt>(o => o
                                                    .Name(n => n.segmts)
                                                    //.AutoMap()
                                                    .Properties(lp => lp.GeoPoint(gp => gp.Name(fn => fn.fpos).IgnoreMalformed(true))
                                                                        .GeoPoint(gp => gp.Name(fn => fn.tpos).IgnoreMalformed(true))
                                                    )
                                                )
                                                .Object<TripInsightGFence>(o => o
                                                    .Name(n => n.gfence)
                                                    //.AutoMap()
                                                    .Properties(lp => lp.GeoPoint(gp => gp.Name(fn => fn.pos).IgnoreMalformed(true)))
                                                )
                                            )
                                   ).RequestConfiguration(r => r
                                        .DisableDirectStreaming()
                                   ));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...