elasticsearch 2.3.4 java API 连接,ik分词器,设置集群节点,创建index,mapping的几种方式
来源:互联网 发布:国内网络婚纱品牌排行 编辑:程序博客网 时间:2024/05/20 18:17
1、默认集群连接
Client client = TransportClient.builder().build() .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("localhost"), 9300));
2、自定义集群连接
Settings settings = Settings.settingsBuilder().put("cluster.name", "cluster-lhy").build();Client client = TransportClient.builder().settings(settings).build().addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("localhost"), 9300));
3、index创建
client.admin().indices().prepareCreate("phone12").get();
4、mapping创建
有四种方式,只提倡前两种(json字符串格式和XContentBuilder),都是一个方法,不同类型参数
Client client = TransportClient.builder().build() .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("localhost"), 9300)); new XContentFactory(); XContentBuilder builder=XContentFactory.jsonBuilder() .startObject()//注意不要加index和type .startObject("properties") .startObject("id1").field("type", "integer").field("store", "yes").endObject() .startObject("kw1").field("type", "string").field("store", "yes").field("analyzer", "ik").endObject() .startObject("edate33").field("type", "date").field("store", "yes").endObject() .endObject() .endObject(); /** * 创建并添加方式1 */ /* client.admin().indices().prepareCreate("twitter1") .addMapping("tweet", "{\n" + " \"tweet\": {\n" + " \"properties\": {\n" + " \"message1\": {\n" + " \"type\": \"string\",\n" + " \"indexAnalyzer\": \"ik\"\n"+ " }\n" + " }\n" + " }\n" + " }") .get();*/ /** * 创建并添加方式2 */ //client.admin().indices().prepareCreate("phone1").addMapping("jingdong", builder).get(); /** * 修改type中属性 方式1 */ /* client.admin().indices().preparePutMapping(new String[]{"phone"}) .setType("jingdong") .setSource("{\n" + " \"properties\": {\n" + " \"nameaaa\": {\n" + " \"type\": \"string\"\n" + " }\n" + " }\n" + "}") .get();*/ /** * 修改type中属性 方式2 */ /*client.admin().indices().preparePutMapping(new String[]{"phone"}) .setType("jingdong").setSource(builder) .get();*/ /** * 方式3不推荐 */ /* Map map=new HashMap(); Map map2=new HashMap(); map2.put("type", "string"); Map map3=new HashMap(); map.put("ooooooooo",map2); map3.put("properties", map); client.admin().indices().preparePutMapping(new String[]{"phone"}) .setType("jingdong").setSource(map3) .get(); client.close();*/
5、2.3.4版本elasticsearch的ik分词器配置注意
不需要再在elasticsearch配置文件elasticsearch.yml中配置
1.从https://github.com/medcl/elasticsearch-analysis-ik下载elasticsearch-analysis-ik-master.zip
2.解压elasticsearch-analysis-ik-master.zip
unzip elasticsearch-analysis-ik-master.zip
3.进入elasticsearch-analysis-ik-master,编译源码
cd elasticsearch-analysis-ik-master
mvn clean package
编译后会放在 elasticsearch-analysis-ik-master/target/releases目录下
4.在$ES_HOME/plugins文件夹下创建ik
mkdir ik
5、找到将编译后生成的elasticsearch-analysis-ik-1.9.4.zip解压到$ES_HOME/plugins/ik下
测试分词器curl -XPOST "http://localhost:9200/索引/_analyze?analyzer=ik&pretty=true&text=我是中国人"
0 0
- elasticsearch 2.3.4 java API 连接,ik分词器,设置集群节点,创建index,mapping的几种方式
- Elasticsearch教程,Elasticsearch Java API创建Mapping,指定分词器
- elasticsearch java api 使用ik 分词器
- Elasticsearch中使用ik分词器 java api
- elasticsearch-2.3.4 ik分词器
- Elasticsearch Java API 之Index type mapping json创建修改
- ElasticSearch java API--创建mapping
- java api访问elasticsearch下ik-pinyin分词基本使用
- elasticsearch 配置ik分词器
- Elasticsearch 集成IK分词器
- elasticsearch配置ik分词器
- elasticsearch 安装ik 分词器
- elasticSearch安装ik分词器
- Elasticsearch集成ik分词器
- Elasticsearch安装IK分词器
- elasticsearch ik分词器安装
- elasticsearch安装ik分词器
- Elasticsearch安装IK分词器
- Android Camera 流程梳理
- 算发导论第五章部分课后习题
- 图像处理中二次曲线拟合
- Android Animation学习 实现 IOS 滤镜退出动画
- warning: incompatible implicit declaration of built-in function ‘exit’
- elasticsearch 2.3.4 java API 连接,ik分词器,设置集群节点,创建index,mapping的几种方式
- LeetCode-208.Implement Trie (Prefix Tree)
- 机器学习实战1:朴素贝叶斯模型:文本分类+垃圾邮件分类
- Looper Handler MessageQueue Message 探究
- Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)
- Android — 如何创建和修改 fragment 及相关注意事项
- Android Activity各启动模式的差异
- Swift基础(十)协议的委托代理
- 机器学习实战2:关联规则:议会投票+毒蘑菇