Springboot与nosql-elasticsearch

作者: 阿亮私语 | 来源:发表于2017-09-25 09:26 被阅读350次

    前言

    在前面一篇已经写了elasticsearch的环境的搭建,那么这一篇就写下springboot与elasticsearch环境的整合。如果没有搭建环境,请参考:es环境搭建

    项目生成

    • 1、像之前一样,访问 start.spring.io,选择对应组件完成,如下图


    • 2、生成项目后倒入idea

    代码编写

    • 需求描述:
      我们利用es做一个简单的用户添加获取的功能。
    • 1、编写用户类
    @Document(indexName = "user", type = "student")
    public class UserInfo implements Serializable{
        private String id;
        private String username;
        private int age;
    
        public String getId() {
            return id;
        }
    
        public void setId(String id) {
            this.id = id;
        }
    
        public String getUsername() {
            return username;
        }
    
        public void setUsername(String username) {
            this.username = username;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            this.age = age;
        }
    
        @Override
        public String toString() {
            return "UserInfo{" +
                    "id='" + id + '\'' +
                    ", username='" + username + '\'' +
                    ", age=" + age +
                    '}';
        }
    }
    
    • 此处id属性必须有,或者改为别的如userId属性,必须添加@Id注解,并且必须为String类型,这是因为后面UserRepository需要泛型为第一个参数为bean的类型,第二个参数为id
    • Spring-data-elasticsearch为我们提供了@Document、@Field等注解,如果某个实体需要建立索引,只需要加上这些注解即可

    这是一个简单的用户类,并且生成了getter,setter方法。

    • 2、dao的编写
      这里我们采用jpa的方式整合es,使用接口,继承ElasticsearchRepository,如下
    @Repository
    public interface UserRepository extends ElasticsearchRepository<UserInfo,String> {
    }
    
    
    
    • service的编写
    @Service
    public class Uservice {
        @Autowired
        UserRepository userRepository;
        public UserInfo getById(String id){
            return userRepository.findOne(id);
        }
    
        public void save(UserInfo userInfo){
            userRepository.save(userInfo);
        }
    
    }
    
    
    • controller的编写
      这里直接使用rest风格的接口
    @RestController
    public class UserController {
        Logger logger = LoggerFactory.getLogger(this.getClass());
        @Autowired
        UserInfoService userInfoService;
        @GetMapping("/user/{id}")
        public UserInfo get(@PathVariable String id){
            UserInfo userInfo = userInfoService.getById(id);
            logger.info("---${user}:{}",userInfo.toString());
            return userInfo;
        }
    
        @PostMapping("/user/create/{id}")
        public UserInfo create(@PathVariable String id,@RequestBody UserInfo userInfo){
            userInfo.setId(id);
            userInfoService.save(userInfo);
            return userInfo;
        }
    }
    

    这里只简单的编写了一个添加和一个获取的方法,接下来我们运行项目
    抛出了一个异常,如下

    java.lang.ClassNotFoundException: com.sun.jna.Native
        at java.net.URLClassLoader.findClass(URLClassLoader.java:381) ~[na:1.8.0_111]
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~[na:1.8.0_111]
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331) ~[na:1.8.0_111]
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~[na:1.8.0_111]
        at java.lang.Class.forName0(Native Method) ~[na:1.8.0_111]
        at java.lang.Class.forName(Class.java:264) ~[na:1.8.0_111]
    
    

    这是是jna包的原因,我们将此jar添加到pom.xml

    <dependency>
        <groupId>net.java.dev.jna</groupId>
        <artifactId>jna</artifactId>
        <version>4.4.0</version>
    </dependency>
    
    • 测试
      我们先利用postman做一个接口测试,如下图



      测试成功,已经将数据添加到es中。

    • 获取



      至此,es的添加和获取已经完成,后期es的更深入的东西后期请持续关注。

    相关文章

      网友评论

        本文标题:Springboot与nosql-elasticsearch

        本文链接:https://www.haomeiwen.com/subject/rlsrextx.html