基于spring data的Elastic Search的配置示例

基于spring data的Elastic Search的配置示例



import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.ArrayList;

import org.apache.commons.lang3.tuple.ImmutablePair;
import org.apache.commons.lang3.tuple.Pair;
import org.elasticsearch.client.Client;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
import org.springframework.data.elasticsearch.core.ElasticsearchOperations;
import org.springframework.data.elasticsearch.core.ElasticsearchTemplate;
import org.springframework.data.elasticsearch.repository.config.EnableElasticsearchRepositories;

import com.xxx.cms.config.props.EsProps;
xxx
@Configuration
@EnableElasticsearchRepositories(
basePackages={"com.xxx.cms.elasticsearch.repositories"}
)
public class ElasticSearchConfig {

private Logger logger = LoggerFactory.getLogger(getClass());

@Autowired
Environment env;

@Bean
public ElasticsearchOperations elasticsearchTemplate() {
return new ElasticsearchTemplate(elasticsearchClient());
}

@Bean
public EsProps esProps(){

EsProps esProps = new EsProps();
esProps.setInit(Boolean.valueOf(env.getProperty("hs.cms.srv.es.init")));
return esProps;
}

@Bean
public Client elasticsearchClient(){

String esNodes = env.getProperty("hs.cms.srv.es.cluster.nodes"),
clusterName = env.getProperty("hs.cms.srv.es.cluster.name");
ArrayList<Pair<String, Integer>> nodePairs = new ArrayList<>();
for (String nodeStr : esNodes.split(",")) {

String[] nodeSpliArr = nodeStr.split(":");
Pair<String, Integer> pair = new ImmutablePair<>(nodeSpliArr[0], Integer.valueOf(nodeSpliArr[1]));
nodePairs.add(pair);
}

Settings settings = Settings.settingsBuilder()
.put("cluster.name", clusterName)
.build();
TransportClient client = TransportClient.builder()
.settings(settings)
.build();
for (Pair<String, Integer> pair : nodePairs) {

try {
client.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName(pair.getLeft()), pair.getRight()));
} catch (UnknownHostException e) {

logger.error("初始化Es配置出错", e);
return null;
}
}
return client;
}

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值