elasticsearch 2.3.4 java API 连接,ik分词器,设置集群节点,创建index,mapping的几种方式
2016-07-16 13:04
726 查看
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=我是中国人"
相关文章推荐
- Android ServiceConnection类的onServiceDisconnected(ComponentName name)在什么时候执行
- JsonObject的optString()和getString()的区别
- Android 微信支付接入
- 【小松教你手游开发】【系统模块开发】unity 数据储存到本地为二进制文件(聊天记录本地储存)
- RxAndroid用法
- Android RxJava 自定义操作符基础和Subject介绍
- ViewPager + Fragment 实现类微信界面
- mappingResources、mappingLocations、mappingDirectoryLocations、mappingJarLocations
- Android Service
- Swift基础(十)协议的委托代理
- Android Activity各启动模式的差异
- Android Animation学习 实现 IOS 滤镜退出动画
- Android Camera 流程梳理
- 加速Android Studio的Gradle构建速度
- ubuntu下,Android Studio 卡在 Scanning project directories
- Android图片添加阴影效果的两种方式
- Android本地文件点击视频播放器vitamio版
- iOS实现自定义的弹出视图(HWPopTool)
- 移动端1px边框实现
- webView js交互