热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在Spring中注入ElasticSearch实例

在企业级项目开发中,大多数公司都会集成Spring来简化开发成本,要使用Spring自然

在企业级项目开发中,大多数公司都会集成Spring来简化开发成本,要使用Spring自然少不了一大堆需要依赖注入的Bean,通常情况下,我们会选择在spring的xml中,配置一些类的实例,比如连接池,或者配置文件初始化类,或者集成duboo时配置一些Service的引用等等。 

有些类的实例生成比较复杂,直接在xml中,是没法进行配置的,比如我想在Spring注入ElasticSearch的Client实例,注意(这里并不是使用的spring-data-elasticsearch项目),而是使用原始的ElasticSearch的API。 

我们先看下,在非Spring的项目中,如何初始化ElasticSearch的Client实例: 


Java代码  

  1. //es的客户端实例    

  2.  static Client client=null;    

  3.  static {    

  4.     //设置集群名字  

  5.     Settings settings = ImmutableSettings.settingsBuilder()  

  6.             .put("cluster.name""search")  

  7.             .put("client.transport.sniff"true)  

  8.            . build();  

  9.       //连接单台机器,注意ip和端口号,不能写错    

  10.       client=new TransportClient(settings)  

  11.       .addTransportAddress(new InetSocketTransportAddress("192.168.1.187"9300))  

  12.       .addTransportAddress(new InetSocketTransportAddress("192.168.1.121"9300))  

  13.       .addTransportAddress(new InetSocketTransportAddress("192.168.1.122"9300));  

  14.     }  




由于ElasticSearch的Client实例是通过各种组装加工而成,并没法直接在Spring的xml中使用Bean标签进行初始化,这时候我们可以使用@Configuration注解,来在Java类中,生成bean实例,这个注解和使用spring的xml进行注入功能大致相同,只不过能直接在Java类生成一个类实例,比较灵活而已。最终的代码如下: 

Java代码  

  1. package cn.bizbook.product.elk.config;  

  2.   

  3. import org.elasticsearch.client.Client;  

  4. import org.elasticsearch.client.transport.TransportClient;  

  5. import org.elasticsearch.common.settings.ImmutableSettings;  

  6. import org.elasticsearch.common.settings.Settings;  

  7. import org.elasticsearch.common.transport.InetSocketTransportAddress;  

  8. import org.springframework.beans.factory.annotation.Autowired;  

  9. import org.springframework.context.annotation.Bean;  

  10. import org.springframework.context.annotation.Configuration;  

  11.   

  12. /** 

  13.  * Created by qindongliang on 2016/4/6. 

  14.  */  

  15. @Configuration  

  16. public class FactoryBean {  

  17.   

  18.     //配置文件工具类  

  19.     @Autowired  

  20.     private ESConf esConf;  

  21.   

  22.   

  23.     //注入的ElasticSearch实例  

  24.     @Bean(name = "client")  

  25.     public Client getESClient(){  

  26.         //设置集群名字  

  27.         Settings settings = ImmutableSettings.settingsBuilder()  

  28.                 .put("cluster.name", esConf.getClusterName())  

  29.                 .build();  

  30.        Client  client=new TransportClient(settings);  

  31.         //读取的ip列表是以逗号分隔的  

  32.         for(String ip:esConf.getIps().split(",")){  

  33.             ((TransportClient)client).addTransportAddress(new InetSocketTransportAddress(ip,esConf.getPort()));  

  34.         }  

  35.         return client;  

  36.     }  

  37.   

  38. }  




最后来看下,如何在DAO层,引用client实例,非常easy: 

Java代码  

  1. @Resource(name = "client")  

  2.  private  Client client;  




推荐阅读
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • 解决java.lang.IllegalStateException: ApplicationEventMulticaster not initialized错误的方法和原因
    本文介绍了解决java.lang.IllegalStateException: ApplicationEventMulticaster not initialized错误的方法和原因。其中包括修改包名、解决service name重复、处理jar包冲突和添加maven依赖等解决方案。同时推荐了一个人工智能学习网站,该网站内容通俗易懂,风趣幽默,值得一看。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • Spring学习(4):Spring管理对象之间的关联关系
    本文是关于Spring学习的第四篇文章,讲述了Spring框架中管理对象之间的关联关系。文章介绍了MessageService类和MessagePrinter类的实现,并解释了它们之间的关联关系。通过学习本文,读者可以了解Spring框架中对象之间的关联关系的概念和实现方式。 ... [详细]
  • 本文介绍了OpenStack的逻辑概念以及其构成简介,包括了软件开源项目、基础设施资源管理平台、三大核心组件等内容。同时还介绍了Horizon(UI模块)等相关信息。 ... [详细]
author-avatar
_我是谁谁谁__950
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有