user11118940
user11118940

Reputation:

illegal_argument_exception in elasticsearch

I am trying to implement fuzzy,synonym,autocomplete,ngram search on "name" and " name_auto" field. but i am getting an illegal exception error.
If i remove the synonym search only then my search works fine.but below i cant even create index.what might be the issue here please help.

   {
            "settings": {
                "index": {
                    "analysis": {
                        "filter": {
                            "synonym": {
                                "type": "synonym",
                                "format": "wordnet",
                                "synonyms_path": "analysis/wn_s.pl"
                            },
                            "english_stop": {
                                "type": "stop",
                                "stopwords": "_english_"
                            },
                            "english_stemmer": {
                                "type": "stemmer",
                                "language": "english"
                            }
                        },
                        "analyzer": {
                            "synonym": {
                                "tokenizer": "standard",
                                "filter": ["english_stop", "english_stemmer", "synonym"]
                            },

                            "keyword_analyzer": {
                                "filter": [
                                    "lowercase",
                                    "asciifolding",
                                    "trim"
                                ],
                                "char_filter": [],
                                "type": "custom",
                                "tokenizer": "keyword"
                            },
                            "edge_ngram_analyzer": {
                                "filter": [
                                    "lowercase"
                                ],
                                "tokenizer": "edge_ngram_tokenizer"
                            },
                            "edge_ngram_search_analyzer": {
                                "tokenizer": "lowercase"
                            }
                        },

                        "tokenizer": {
                            "edge_ngram_tokenizer": {
                                "type": "edge_ngram",
                                "min_gram": 1,
                                "max_gram": 25,
                                "token_chars": [
                                    "letter"
                                ]
                            }

                        },
                        "mappings": {
                            "properties": {
                                "firebaseId": {
                                    "type": "text"
                                },
                                "name": {
                                    "fielddata": true,
                                    "type": "text",
                                    "analyzer": "standard"
                                },
                                "name_auto": {
                                    "type": "text",

                                    "fields": {
                                        "keywordstring": {
                                            "type": "text",
                                            "analyzer": "keyword_analyzer"
                                        },
                                        "edgengram": {
                                            "type": "text",
                                            "analyzer": "edge_ngram_analyzer",
                                            "search_analyzer": "edge_ngram_search_analyzer"
                                        },
                                        "completion": {
                                            "type": "completion"
                                        },
                                        "synonym_analyzer": {
                                            "type": "string",
                                            "analyzer": "synonym"
                                        }
                                    }
                                }

                            }
                        }
                    }
                }
            }
        }

Below is the response i am getting

{
    "error": {
        "root_cause": [
            {
                "type": "illegal_argument_exception",
                "reason": "failed to build synonyms"
            }
        ],
        "type": "illegal_argument_exception",
        "reason": "failed to build synonyms",
        "caused_by": {
            "type": "parse_exception",
            "reason": "Invalid synonym rule at line 109",
            "caused_by": {
                "type": "illegal_argument_exception",
                "reason": "term: course of action analyzed to a token (action) with position increment != 1 (got: 2)"
            }
        }
    },
    "statu

s": 400 }

Upvotes: 1

Views: 1491

Answers (1)

user11118940
user11118940

Reputation:

The solution was pretty simple i had to remove the "english_stop", "english_stemmer" filter.it seems like it wasnt supporting .

  {
            "settings": {
                "index": {
                    "analysis": {
                        "filter": {
                            "synonym": {
                                "type": "synonym",
                                "format": "wordnet",
                                "synonyms_path": "analysis/wn_s.pl"
                            }

                        },
                        "analyzer": {
                            "synonym": {
                                "tokenizer": "standard",
                                "filter": ["synonym"]
                            },

                            "keyword_analyzer": {
                                "filter": [
                                    "lowercase",
                                    "asciifolding",
                                    "trim"
                                ],
                                "char_filter": [],
                                "type": "custom",
                                "tokenizer": "keyword"
                            },
                            "edge_ngram_analyzer": {
                                "filter": [
                                    "lowercase"
                                ],
                                "tokenizer": "edge_ngram_tokenizer"
                            },
                            "edge_ngram_search_analyzer": {
                                "tokenizer": "lowercase"
                            }
                        },

                        "tokenizer": {
                            "edge_ngram_tokenizer": {
                                "type": "edge_ngram",
                                "min_gram": 1,
                                "max_gram": 25,
                                "token_chars": [
                                    "letter"
                                ]
                            }

                        },
                        "mappings": {
                            "properties": {
                                "firebaseId": {
                                    "type": "text"
                                },
                                "name": {
                                    "fielddata": true,
                                    "type": "text",
                                    "analyzer": "standard"
                                },
                                "name_auto": {
                                    "type": "text",

                                    "fields": {
                                        "keywordstring": {
                                            "type": "text",
                                            "analyzer": "keyword_analyzer"
                                        },
                                        "edgengram": {
                                            "type": "text",
                                            "analyzer": "edge_ngram_analyzer",
                                            "search_analyzer": "edge_ngram_search_analyzer"
                                        },
                                        "completion": {
                                            "type": "completion"
                                        },
                                        "synonym_analyzer": {
                                            "type": "string",
                                            "analyzer": "synonym"
                                        }
                                    }
                                }

                            }
                        }
                    }
                }
            }
        }

Upvotes: 1

Related Questions