微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

springmvc+双数据源+redis+thymeleaf+spring-data-jpa

因为闲来无事在工作中写了个小项目,先看配置:

配置文件采用携程的apollo自动注入。

1. mvc使用权自动配置,由springboot完成自动配置,具体的请求路径由requestmapping设置。

2. 双数据源

2.1 设置数据源

 上图设置了一个DataSourceProperties,至于为什么设置另一个Properties,是因为apollo下来的密码是密文,有一个密钥,这个密钥的key在DataSourceProperties中没有这样的key值,且DataSourceProperties不能单独取值或者设置值,因此只能再生成一个备用Properties。另外DataSourceProperties需要加上@Primary注解,以便让Springboot放弃自己配置此Bean,而是使用我们配置的这个Bean。还有Properties的Bean的名字设置为2222,也是为了区分Springboot自己设置的Properties。

 上面设置了两个数据源,这两个数据源属于除了用户名其他都是相同的,注意第一个因为加了@Primary注解,所以可以不用写bean的名字,后面再给data-jpa的EntityManagerFactory Bean注入数据源的时候,认是注入加了@Primary注解的主数据源,而第二个数据源因为是备用数据源,因此需要加上名字,以便在给备用EntityManagerFactory Bean设置数据源的时候可以按照名字注入。可以看到Properties主要是为了取用户名然后设置到DataSourceProperties中,还有密码。

2.2 设置EntityManagerFactory

 设置双数据源很简单,无论是mybatis或者spring-data-jpa,或者是其他的都是一样的,mybatis是设置不同的sqlSessionFactory,Spring-data-jpa设置EntityManagerFactory。

注意第二个注解是关键,它是告诉Springboot按照手动操作来完成此次生成EntityManagerFactory Bean的流程。第一个参数告诉Spring由哪个管理器工厂类进行数据库Dao接口的生成,第二个参数指定了扫描的具体仓库包范围。另外这里注入DataSource只需要@AutoWired即可,因为主数据源会被自动化注入。

 第二个和第一个大同小异,区别是注入数据源的时候需要额外加上@Qualifier按照名字注入数据源。

3. redis

 就是比较简单的配置了一个,没什么特殊的,记得配置序列化器,在开始的时候,因为误以为Springboot会自动帮我配置序列化器,但是由于我没有指定Redistemplate的泛型,导致Springboot不知道给我设置了个啥序列化器,然后就怎么也获取不到redis的数据,但是也不报错,然后就痛苦的找了一天的问题,因为redis数据源连接是成功的,获取删除数据也不报错,配置都没有问题,哇简直痛苦,然后看到了一篇文章,我大概明白了可能是由于错误序的列化器导致数据乱码无法正确获取到数据。

4. thymeleaf

这个属于半前端框架,可以让后端开发触摸到前端开发的乐趣,我很喜欢这玩意,由于是简单的使用,所以所有的配置操作都交给SpringBoot做了,所有的设置按照认配置设置,目录结构是这样的

一个简单的页面内容如下:

thymeleaf为了减轻学习的成本,他的基本上所有语法都是在html语法前面加上 th: ,然后就可以完成thymeleaf的注入,这个th: 表签的作用是当对象数据被获取到后会替换掉本身html中设置的值,如果为空就啥也不做,因此即使没有后台数据传入,thymeleaf也可以被html正确的解析, 注意在页面加上下面的声明,否则th: 语法不会被识别:

static放置静态文件,templates放置html页面以及其他服务器资源文件,但是不建议把其他文件在这个目录下,这个目录下的文件只能通过内部服务获取,即Controller才有权限获取,这是thymeleaf的规定。js,css等资源放在static即可。

5. data-jpa

Spring-Data是Spring针对数据库范围设置的顶层接口,下辖接口实现类可以操作sql,nosql等所有数据库,野心勃勃的Spring。而关系型数据库的实现类是spring-data-jpa,操作redis除了redistemplate还可以使用spring-data-redis,然后就可以写接口,实现crudRepository接口,就可以按照接口操作redis。具体的配置参考上面的双数据源设置。

 上面是一个简单的按照名字的分页功能实现,我觉得jpa这种接口的形式写sql,挺带感的,既可以脱离平台,又可以减少人为sql的失误,我觉得比mybatis的事事亲为,要好的多,当然个人意见。

以上就是全部内容

*希望你我都可以绽放自己*

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐