SpringBoot全家桶
前言
Spring简化了Java的开发,而SpringBoot简化了Spring。本文用SpringBoot采用分层的结构整合了filter,aspect,mybaits,logback,redis,rocketmq和dubbo等框架。这是一个比较接近实际项目的版本。
mybaits
在application.properties配置数据源和目录就行了,不用配置SqlSessionFactory和TransactionManager,如下
#mysql
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mysql?serverTimezone=GMT%2B8
spring.datasource.username=root
spring.datasource.password=111111
# mybatis
# mybatis.config-location=classpath:/mybatis/mybatis-config.xml
mybatis.mapper-locations=classpath*:/mappers/*.xml
mybatis.type-aliases-package=com.example.demo.repository.entity
另外还需要设置MapperScan,如
@SpringBootApplication(scanBasePackages = "com.example.demo")
@MapperScan("com.example.demo.repository.dao")
public class StartApplication { public static void main(String[] args) {
SpringApplication.run(StartApplication.class, args);
} }
logback
springboot支持logback,log4j等日志框架。如果用logback的话,springboot会默认寻找logback.xml或者logback-spring.xml。所以只需要配置一下,如
<?xml version="1.0" encoding="UTF-8" ?> <configuration scan="true">
<!-- Convert mvn placeholder to a logback managed property -->
<property name="log.home" value="../logs"/>
<property name="log.level" value="INFO"/> <!--=============================================================
=== Appender definition ===
=============================================================-->
<appender name="ROOT" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.home}/root.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${log.home}/root.log.%d{yyyy-MM-dd}</fileNamePattern>
<maxHistory>10</maxHistory>
</rollingPolicy>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
</appender> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
</appender> <appender name="biz-appender" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.home}/biz.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${log.home}/biz.log.%d{yyyy-MM-dd}</fileNamePattern>
<maxHistory>10</maxHistory>
</rollingPolicy>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
</appender> <!-- default -->
<root level="${log.level:-INFO}">
<appender-ref ref="ROOT"/>
<appender-ref ref="STDOUT"/>
</root> <logger name="com.example.demo.biz" level="${log.level:-INFO}" additivity="false">
<appender-ref ref="biz-appender"/>
</logger>
</configuration>
redis
redis配置非常简单,只需要加入依赖和配置就行
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
# Redis服务器地址
spring.redis.host=localhost
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=
rocketmq
需要加入一个依赖,如
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
</dependency>
消费者,如
@Component
@RocketMQMessageListener(topic="${rocketmq.topic}", consumerGroup = "${rocketmq.consumer.group}")
public class MyConsumer implements RocketMQListener<String> { private final static org.slf4j.Logger logger = LoggerFactory.getLogger(MyConsumer.class);
@Override
public void onMessage(String s) {
logger.info(s);
}
}
生产者,如
@Component
public class MyProducer { @Value("${rocketmq.topic}")
private String topic; @Autowired(required = false)
private RocketMQTemplate rocketMQTemplate; public void sendMessage(Object message){
rocketMQTemplate.convertAndSend(topic, message);
}
}
dubbo
dubbo要用到zookeeper作为注册中心,所以要加入以下依赖,不过记得要排除slj4的依赖,不然会依赖冲突
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
</dependency>
<!-- Dubbo -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo</artifactId>
</dependency>
<!-- Zookeeper dependencies -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-dependencies-zookeeper</artifactId>
</dependency>
属性配置
# Spring boot application
spring.application.name=dubbo-auto-configuration-provider-demo
# Base packages to scan Dubbo Component: @org.apache.dubbo.config.annotation.Service
dubbo.scan.base-packages=com.example.demo.biz.service.apiimpl
dubbo.protocol.name=dubbo
dubbo.protocol.port=20880
dubbo.registry.address=zookeeper://127.0.0.1:2181
服务提供者,需要注意的是注解@Service是org.apache.dubbo.config.annotation.Service
@Service
public class MyFacadeImpl implements MyFacade { @Override
public List<GoodVO> getHotGoodList() {
List<GoodVO> list=new ArrayList<>();
GoodVO vo=new GoodVO();
vo.setName("可乐");
vo.setPrice(new BigDecimal(2.33));
list.add(vo);
return list;
}
}
服务消费者
@Reference(check = false)
MyFacade myFacade;
源码
源码地址 https://github.com/mycaizilin/springbootdemo
划重点
重点来了。虽然我看博客也写博客,但是不建议学习技术只看博客。首先,博客上的知识不一定是对的。其次,大多数博客都是作者的当时零碎记录,是不够全面和成体系的,而且可能是过期的。我比较推荐的是看官方文档,如官网上和GitHub上的,看官方的文档看不懂再来找其他资料也不迟。下面是springboot相关的一些官方文档。
springboot官方文档: https://docs.spring.io/spring-boot/docs/2.1.4.RELEASE/reference/htmlsingle/
Dubbo Spring Boot : https://github.com/apache/incubator-dubbo-spring-boot-project/blob/master/README_CN.md
Dubbo 官方文档:: http://dubbo.apache.org/zh-cn/docs/user/quick-start.html
Rocketmq springboot文档: https://github.com/apache/rocketmq-spring/blob/master/README_zh_CN.md
Rocketmq 官方文档: http://rocketmq.apache.org/docs/motivation/
mybaits springboot: http://www.mybatis.org/spring-boot-starter/mybatis-spring-boot-autoconfigure/
SpringBoot全家桶的更多相关文章
- Spring全家桶–SpringBoot Rest API
Spring Boot通过提供开箱即用的默认依赖或者转换来补充Spring REST支持.在Spring Boot中编写RESTful服务与SpringMVC没有什么不同.总而言之,基于Spring ...
- Spring全家桶系列–SpringBoot之AOP详解
//本文作者:cuifuan //本文将收录到菜单栏:<Spring全家桶>专栏中 面向方面编程(AOP)通过提供另一种思考程序结构的方式来补充面向对象编程(OOP). OOP中模块化的关 ...
- Spring全家桶系列–SpringBoot渐入佳境
//本文作者:cuifuan //本文将收录到菜单栏:<Spring全家桶>专栏中 首发地址:https://www.javazhiyin.com/20913.html 萌新:小哥,我在实 ...
- Spring全家桶系列–[SpringBoot入门到跑路]
//本文作者:cuifuan Spring全家桶————[SpringBoot入门到跑路] 对于之前的Spring框架的使用,各种配置文件XML.properties一旦出错之后错误难寻,这也是为什么 ...
- Spring全家桶——SpringBoot之AOP详解
Spring全家桶--SpringBoot之AOP详解 面向方面编程(AOP)通过提供另一种思考程序结构的方式来补充面向对象编程(OOP). OOP中模块化的关键单元是类,而在AOP中,模块化单元是方 ...
- Spring全家桶——SpringBoot渐入佳境
Spring全家桶系列--SpringBoot渐入佳境 萌新:小哥,我在实体类写了那么多get/set方法,看着很迷茫 小哥:那不是可以自动生成吗? 萌新:虽然可以自动生成,但是如果我要修改某个变量的 ...
- Spring全家桶一一SpringBoot与Mybatis
Spring全家桶系列一一SpringBoot与Mybatis结合 本文授权"Java知音"独家发布. Mybatis 是一个持久层ORM框架,负责Java与数据库数据交互,也可以 ...
- 10分钟详解Spring全家桶7大知识点
Spring框架自2002年诞生以来一直备受开发者青睐,它包括SpringMVC.SpringBoot.Spring Cloud.Spring Cloud Dataflow等解决方案.有人亲切的称之为 ...
- 【Spring Cloud】全家桶介绍(一)
一.微服务架构 1.微服务架构简介 1.1.分布式:不同的功能模块部署在不同的服务器上,减轻网站高并发带来的压力. 1.2.集群:多台服务器上部署相同应用构成一个集群,通过负载均衡共同向外提供服务. ...
随机推荐
- Winter-1-D Max Sum 解题报告及测试数据
Time Limit:1000MS Memory Limit:32768KB Description Given a sequence a[1],a[2],a[3]......a[n], your j ...
- 关于http响应状态码
http状态返回代码 1xx(临时响应) 表示临时响应并需要请求者继续执行操作的状态代码. http状态返回代码 代码 说明 100 (继续) 请求者应当继续提出请求. 服务器返回此代码表示已 ...
- PV、TPS、QPS是怎么计算出来的?
PV=page viewTPS=transactions per secondQPS=queries per secondRPS=requests per second RPS=并发数/平均响应时间 ...
- win 7 64 安装 MondgoDB 3.4
https://jingyan.baidu.com/article/f3e34a12ac10cef5eb653583.html mongod --dbpath "D:\Program Fil ...
- GRUB2 分析 (二)
接上一篇 实际上在512字节的MBR中,真正可用的空间并不多.除了一开始的跳转指令外,起始部分是一个被称为BPB的区域,即BIOS参数块(BISO Parameter Block).主要是FAT和NT ...
- 前端学习笔记之BOM和DOM
前言 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互,我们需要继续学习BOM和DO ...
- HCNP学习笔记之PXE原理详解及实践
一.PXE简介 PXE(preboot execute environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服 ...
- windows库
1.windows库的存在方式 1.1.静态库:不能被加载的程序,可以理解为目标程序的归档:*.lib. 1.2.动态库:是可以被加载的程序:*.dll. 2.静态库 2.1.静态库的特点 目标 ...
- vmware基于主机模式实现上网(win10)
首先查看本机win10的网络情况: 网卡VMnet1就是主机模式的网卡,确认本机win10共享了网络给vmnet1这张网卡,如果没有共享,那么进行设置: 进行上述设置,然后在vmnet1网卡上设置ip ...
- 20145303《Java程序设计》实验三实验报告
20145303<Java程序设计>实验三实验报告 ssh公钥配置及git安装: eclipse中git配置: 队友链接: http://www.cnblogs.com/5321z/p/5 ...