es 创建索引报错_ES添加映射报错analyzer [ik_max_word] not found for field [title]

在尝试为Elasticsearch索引创建映射时遇到了'mapper_parsing_exception',原因是analyzer [ik_max_word]未找到。错误的根本原因是缺少ik分词插件。解决此问题需要安装与Elasticsearch版本匹配的ik分词插件,例如通过命令 './bin/elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.3.2/elasticsearch-analysis-ik-6.3.2.zip' 安装。安装时确保ik分词插件的版本与ES版本一致,否则会引发不兼容错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

给索引创建映射报错

{

"error":{

"root_cause":[

{

"type":"mapper_parsing_exception",

"reason":"analyzer [ik_max_word] not found for field [title]"

}

],

"type":"mapper_parsing_exception",

"reason":"analyzer [ik_max_word] not found for field [title]"

},

"status":400

}

原因

未安装ik分词插件

解决办法

安装分词插件

./bin/elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.3.2/elasticsearch-analysis-ik-6.3.2.zip

注意

ik分词和es的版本要保持一致,不然安装分词插件的时候会报错如下错误

Exception in thread "main" java.lang.IllegalArgumentException: Plugin [analysis-ik] was built for Elasticsearch version 6.3.0 but version 6.3.2 is running

at org.elasticsearch.plugins.PluginsService.verifyCompatibility(PluginsService.java:421)

at org.elasticsearch.plugins.InstallPluginCommand.loadPluginInfo(InstallPluginCommand.java:596)

at org.elasticsearch.plugins.InstallPluginCommand.installPlugin(InstallPluginCommand.java:717)

at org.elasticsearch.plugins.InstallPluginCommand.install(InstallPluginCommand.java:641)

at org.elasticsearch.plugins.InstallPluginCommand.execute(InstallPluginCommand.java:225)

at org.elasticsearch.plugins.InstallPluginCommand.execute(InstallPluginCommand.java:210)

at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:86)

at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:124)

at org.elasticsearch.cli.MultiCommand.execute(MultiCommand.java:79)

at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:124)

at org.elasticsearch.cli.Command.main(Command.java:90)

at org.elasticsearch.plugins.PluginCli.main(PluginCli.java:48)

启动ES加载插件

./bin/elasticsearch &

[2020-09-12T11:01:02,369][INFO ][o.e.p.PluginsService ] [zvSqFpX] loaded plugin [analysis-ik]

### 回答1: fieldType = FieldType.TEXT 表示该字段是文本类型。 analyzer = Analyzer.IK_SMART 表示使用 IK_SMART 分词器对该字段进行分词。 searchAnalyzer = Analyzer.IK_MAX_WORD 表示使用 IK_MAX_WORD 分词器对该字段进行搜索。 ### 回答2: 根据提供的信息,我理解您遇到了一个问题:在进行es特殊字符查询时无法查找到结果。根据您提供的字段的设置,将为您解释可能的原因。 首先,您指定了字段类型为FieldType.TEXT,这意味着该字段将被分析器处理为文本类型数据。接下来,您指定了分析器为Analyzer.IK_SMART,搜索分析器为Analyzer.IK_MAX_WORDIK分析器是一种面向中文文本的分析器,可以将文本拆分成合适的词语以便更准确的进行搜索。IK分析器有两种模式可供选择:IK_SMART和IK_MAX_WORDIK_SMART模式是一种智能模式,会尽量将文本进行最准确的拆分,以尽可能包含更多的搜索结果。而IK_MAX_WORD模式会将文本切分为更多的词语,以尽可能获取更多的搜索结果。 然而,如果您遇到特殊字符查询不到结果的情况,可能是因为您所使用的查询方式不适用于特殊字符。在进行使用特殊字符的查询时,可能需要使用其他的操作符或查询方法来确保能够正确匹配到特殊字符。例如,您可以使用正则表达式查询来匹配特殊字符,或者使用原始查询语法来确保特殊字符被正确解析。 另外,还有一种可能性是特殊字符在被分析器处理时发生了改变,导致不能正确匹配到您预期的结果。这时您可以尝试更改分析器配置或者选择其他的分析器来处理特殊字符。 总结来说,要在es特殊字符查询中获得正确的结果,您需要确保使用合适的操作符或查询方法,并确保您所选择的分析器正确处理特殊字符。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值