Elasticsearch教程(六) elasticsearch Client创建

soゝso 2016-08-23 00:13:53 93967

Elasticsearch  目录

Elasticsearch  创建Client有几种方式。

首先在 Elasticsearch  的配置文件 elasticsearch.yml中。定义cluster.name。如下:

cluster.name: sojson-application

创建方式一:

import static org.elasticsearch.node.NodeBuilder.*;
//节点方式创建。
Node node = nodeBuilder().clusterName("yourclustername").node();
Client client = node.client();
/*
还有很多节点方式的创建方式,查看下面的官网地址。
https://www.elastic.co/guide/en/elasticsearch/client/java-api/2.0/node-client.html
*/ 

创建方式二:

/**
 * 指定 ip地址创建
 */
// on startup
Client client = TransportClient.builder().build()
        .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("host1"), 9300))
        .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("host2"), 9300));

// on shutdown
client.close();

创建方式三:

//按集群名称创建
Settings settings = Settings.settingsBuilder()
        .put("cluster.name", "sojson-application").build();
Client client = TransportClient.builder().settings(settings).build();
//Add transport addresses and do something with the client...

创建方式四:

//同一内网Ip段,嗅的方式自己查找,组成集群。
Settings settings = Settings.settingsBuilder()
        .put("client.transport.sniff", true).build();
TransportClient client = TransportClient.builder().settings(settings).build();
/*
客户端允许嗅其余的集群,它将数据节点添加到列表的机器使用。在这种情况下要注意,将使用的IP地址的其他节点开始(“publish”地址)。启用它,设置client.transport.sniff为 true:
*/

其实还有很多方式。具体使用哪种,看自己需求。

我的工具类:

package com.sojson.core.elasticsearch.utils;

import java.net.InetAddress;

import org.elasticsearch.client.Client;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.transport.InetSocketTransportAddress;

import com.sojson.common.utils.LoggerUtils;
import com.sojson.core.config.IConfig;

public class ESTools {
	
	public final static Client client =  build();
	
	public final static Class clazz = ESTools.class;
	

	
	/**
	 * 创建一次
	 * @return
	 */
	private static Client build(){
		if(null != client){
			return client;
		}
		Client client = null;
		String ip = IConfig.get("es_ip");
		LoggerUtils.fmtDebug(clazz, "获取ESIP地址:%s", ip);
		try {
			LoggerUtils.fmtDebug(clazz, "创建Elasticsearch Client 开始");
			Settings settings = Settings
				.settingsBuilder()
					.put("cluster.name","sojson-application")
						.put("client.transport.sniff", true)
							.build();
			client = TransportClient.builder().settings(settings).build()
			.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName(ip), 9300));
			LoggerUtils.fmtDebug(clazz, "创建Elasticsearch Client 结束");
		} catch (Exception e) {
			LoggerUtils.fmtError(clazz, e, "创建Client异常");
		}
		return client;
	}
	
	/**
	 * 关闭
	 */
	public static void close(){
		if(null != client){
			try {
				client.close();
			} catch (Exception e) {
				
			}
		}
	}
	
}

后面的讲解,我都是采用这个工具类。


版权所属:SO JSON在线解析

原文地址:https://www.sojson.com/blog/87.html

转载时必须以链接形式注明原始出处及本声明。

本文主题:

如果本文对你有帮助,那么请你赞助我,让我更有激情的写下去,帮助更多的人。

关于作者
一个低调而闷骚的男人。
相关文章
Elasticsearch教程(五) elasticsearch Mapping的创建
Elasticsearch教程Elasticsearch Java API创建Mapping,指定分词器
Elasticsearch教程Elasticsearch count 查询,Elasticsearch 查询是否存在
Elasticsearch教程Elasticsearch配置文件 — elasticsearch.yml
Elasticsearch 教程Elasticsearch部署阿里云集群,支持外网请求方式
Elasticsearch教程(八) elasticsearch delete 删除数据(Java)
Elasticsearch 教程Elasticsearch 日期查询详解,Elasticsearch Date 查询Java API
Elasticsearch教程(九) elasticsearch 查询数据 | 分页查询
Elasticsearch教程(四) elasticsearch head 插件安装和使用
Elasticsearch教程Elasticsearch安全篇,通过Nginx http basic 限制访问
最新文章
使用七牛云存储实现图片API,自动删除图片方案合集 1005
神速ICP备案经验分享,ICP备案居然一天就通过了 2138
百度加强推送URL链接,百度SEO强行推送链接JavaScript代码案例讲解。 2867
SOJSON 拓展服务器被DDos攻击了一晚上,是如何解决的? 3177
湖南地区备案“新增网站需提交组网方案或解释说明”,关于备案做简单叙述 3226
企查查你是个什么企业,骗子的帮凶,诈骗的集中营,通过企查查骚扰企业电话不断,为所欲为的企查查 9493
Java爬取百度云观测对网站的检测数据,获取子域名及域名的安全信息 2503
【2020年】百度搜索词获取,获取百度搜索的关键词【真实有效】 6825
Nodejs环境安装,Nodejs环境安装一篇就够了 1778
iOS版淘宝打开提示“您使用的程序是内测版本,将于2020-03-28到期,到期将无法使用,请尽快下载最新版本” 2480
最热文章
苹果电脑Mac怎么恢复出厂系统?苹果系统怎么重装系统? 430432
我为什么要选择RabbitMQ ,RabbitMQ简介,各种MQ选型对比 416974
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 350123
最新MyEclipse8.5注册码,有效期到2020年 (已经更新) 309427
免费天气API,天气JSON API,不限次数获取十五天的天气预报 286008
Elasticsearch教程(四) elasticsearch head 插件安装和使用 220175
Jackson 时间格式化,时间注解 @JsonFormat 用法、时差问题说明 175288
谈谈斐讯路由器劫持,你用斐讯路由器,你需要知道的事情 135878
Elasticsearch教程(一),全程直播(小白级别) 119018
Elasticsearch教程(五) elasticsearch Mapping的创建 98636

骚码加入我们 / 千人QQ群:259217951

入群需要5元为的是没有垃圾广告,如果没有QQ钱包,可以加群主拉进。

二维码生成 来自 >> 二维码生成器

支付扫码

所有赞助/开支都讲公开明细,用于网站维护:赞助名单查看

查看我的收藏

正在加载... ...