elasticsearch6.1在java中的连接基于xpack实现权限访问配置

最近项目中用到elastic,做个记录。     

1、maven项目在pom文件中加入需要的包配置

<!-- 加入elasticsearch -->
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>x-pack-transport</artifactId>
    <version>6.1.1</version>
</dependency>
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>transport</artifactId>
    <version>6.1.1</version>
</dependency>
<dependency>  
    <groupId>org.elasticsearch</groupId>  
    <artifactId>elasticsearch</artifactId>  
    <version>6.1.1</version>  
</dependency>
2、java中连接ElasticConfig代码
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.transport.TransportAddress;
import org.elasticsearch.xpack.client.PreBuiltXPackTransportClient;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.FactoryBean;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;

@Configuration
@PropertySource(value = "classpath:/elasticsearch.properties")
public class EsConfig implements FactoryBean<TransportClient>, InitializingBean, DisposableBean {

	private static final Logger logger = LoggerFactory.getLogger(EsConfig.class);
	
	@Value("${spring.data.elasticsearch.cluster-nodes}")
	private String clusterNodes;

	@Value("${spring.data.elasticsearch.cluster-name}")
	private String clusterName;
	
	private TransportClient client;
	private PreBuiltXPackTransportClient preBuiltTransportClient;

	@Override
	public void destroy() throws Exception {
		try {
            logger.info("Closing elasticSearch client");
            if (client != null) {
                client.close();
            }
        } catch (final Exception e) {
            logger.error("Error closing ElasticSearch client: ", e);
        }
	}

	@Override
	public void afterPropertiesSet() throws Exception {
		 buildClient();
	}

	@Override
	public TransportClient getObject() throws Exception {
		return client;
	}

	@Override
	public Class<TransportClient> getObjectType() {
		 return TransportClient.class;
	}

	@Override
	public boolean isSingleton() {
		return false;
	}

	protected void buildClient()  {
        try {
        	preBuiltTransportClient = new PreBuiltXPackTransportClient(settings());

			String InetSocket[] = clusterNodes.split(":");
			String address = InetSocket[0];
			Integer port = Integer.valueOf(InetSocket[1]);
			client = preBuiltTransportClient.addTransportAddress(new TransportAddress(InetAddress.getByName(address), port));
        } catch (UnknownHostException e) {
            logger.error(e.getMessage());
        }
    }
	
	private Settings settings(){
		Settings settings = Settings.builder()
	               .put("cluster.name", clusterName) //设置ES实例的名称
	               .put("xpack.security.transport.ssl.enabled",false)//设置xpack权限用户
	               .put("xpack.security.user","elastic:asd123")
	               .put("client.transport.sniff", true) //自动嗅探整个集群的状态,把集群中其他ES节点的ip添加到本地的客户端列表中
	               .build();
        return settings;
    }

}
3、业务类中通过注入获取连接实例
@Autowired
private TransportClient client;

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值