Spring Cloud 初级
一、 Spring Boot 回顾
1 什么是 Spring Boot?
Spring Boot 是在 Spring 的基础之上产生的(确切的说是在 Spring4.0 的版本的基础之上),
其中“Boot”的意思就是“引导”,意在简化开发模式,是开发者能够快速的开发出基于
Spring 的应用。Spring Boot 含有一个内嵌的 web 容器。我们开发的 web 应用不需要作为 war
包部署到 web 容器中,而是作为一个 jar 包,在启动时根据 web 服务器的配置进行加载。
2 在没有使用 Spring Boot 开发时项目时什么样的?
2.1在项目中存在大量的 xml 文件,配置相当繁琐
2.2整合第三方框架时的配置问题
2.3低效的开发效率与部署效率问题3 Spring Boot 解决了什么?
3.1Spring Boot 使配置简单
3.2Spring Boot 使编码加单
3.3Spring Boot 使部署简单
3.4Spring Boot 使监控简单
二、 Spring Boot 快速构建项目
1 打开 Spring Boot 的官网
https://projects.spring.io/spring-boot/
https://start.spring.io/ 构建 Spring Boot 的页面
2 使用 Spring Boot 官网构建项目
2.1会自动的帮助我们生成启动类
2.2会自动生成存放静态资源的目录,还会生成全局配置文件
2.3会自动生成测试代码,当然只是的一个结构。
2.4Spring Boot 官方推荐的 jdk 版本为 1.8 或者更高
3 构建项目目录结构
三、 Spring Boot 全局配置文件讲解
1 修改内嵌容器的端口号
server.port=8888
2 自定义属性配置
msg=Hello World
@Value("${msg}")
private String msg;
3 配置变量引用
hello=bjsxt
msg=Hello World ${hello}
@Value("${msg}")
private String msg;
4 随机值配置
4.1配置随机值
num=${random.int}
msg=Hello World ${num}
@Value("${msg}")
private String msg;
用处:配置随机值,在程序中如果有一些运算需要一个随机值,那么可以使用该方式来
生成。注意,只生成一次。
4.2配置随机端口
server.port=${random.int[1024,9999]}用处:在 SpringCloud 的微服务中,我们是不需要记录 IP 与端口号的。那么我们也就不
需要去维护服务的端口号。让他随机生成就可以了。
四、 yml 配置文件
是 Spring Boot 中新增的一种配置文件格式。特点:具备天然的树状结构
1 yml 配置文件与 properties 文件的区别
1.1配置文件的扩展名有变化
1.2配置文件中的语法有变化
2 yml 配置文件的语法
2.1在 properties 文件中单词与单词之间是以“.”进行分割,在 yml 中使用“:”进行分割
2.2yml 的数据格式和 json 的格式很像,都是 K-V 结构的。并且是通过“:”赋值
2.3在 yml 中缩进一定不能使用 TAB 件,否则会报错。
2.4每个 K 的冒号后面一定要加一个空格
2.5最后一层key可以直接跟value
五、 logback 日志记录讲解
1 导入相关的 jar 包
2 添加 logback.xml 配置文件
<?xml version="1.0" encoding="UTF-8" ?> <configuration> <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径--> <property name="LOG_HOME" value="${catalina.base}/logs/" /> <!-- 控制台输出 --> <appender name="Stdout" class="ch.qos.logback.core.ConsoleAppender"> <!-- 日志输出编码 --> <layout class="ch.qos.logback.classic.PatternLayout"> <!--格式化输出:%d 表示日期,%thread 表示线程 名,%-5level:级别从左显示 5 个字符宽度%msg:日志消息,%n 是换行符--> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n </pattern> </layout> </appender> <!-- 按照每天生成日志文件 --> <appender name="RollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--日志文件输出的文件名--> <FileNamePattern>${LOG_HOME}/server.%d{yyyy-MM-dd}.log</FileNa mePattern> <MaxHistory>30</MaxHistory> </rollingPolicy> <layout class="ch.qos.logback.classic.PatternLayout"> <!--格式化输出:%d 表示日期,%thread 表示线程 名,%-5level:级别从左显示 5 个字符宽度%msg:日志消息,%n 是换行符--> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n </pattern> </layout> <!--日志文件最大的大小--> <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"> <MaxFileSize>10MB</MaxFileSize> </triggeringPolicy> </appender> <!-- 日志输出级别 --> <root level="info"> <appender-ref ref="Stdout" /> <appender-ref ref="RollingFile" /> </root> <!--日志异步到数据库 --> <!-- <appender name="DB" class="ch.qos.logback.classic.db.DBAppender"> 日志异步到数据库 <connectionSource class="ch.qos.logback.core.db.DriverManagerConnectionSource"> 连接池 <dataSource class="com.mchange.v2.c3p0.ComboPooledDataSource"> <driverClass>com.mysql.jdbc.Driver</driverClass> <url>jdbc:mysql://127.0.0.1:3306/databaseName</url> <user>root</user> <password>root</password> </dataSource> </connectionSource> </appender> --> </configuration>
六、 Spring Boot 的配置文件 - 多环境配置
profile:代表的就是一个环境变量
语法结构:application-{profile}.properties
1 需求:
application-dev.properties 开发环境
application-test.properteis 测试环境
application-prod.properteis 生产环境
2 运行项目:
java -jar xxx.jar --spring.profiles.active={profile}
3 完成的命令:
java -jar springboot-helloworld-0.0.1-SNAPSHOT.jar --spring.profiles.active=test|dev|prod
七、 Spring Boot 核心注解讲解
@SpringBootApplication:代表是 SpringBoot 的启动类。
@SpringBootConfiguration:通过 bean 对象来获取配置信息
@Configuration:通过对 bean 对象的操作替代 spring 中 xml 文件
@EnableAutoConfiguration:完成一些初始化环境的配置。
@ComponentScan:来完成 spring 的组件扫描。替代之前我们在 xml 文件中配置组件扫描的
配置<context:component-scan pacage=”....”>
@RestController:1,表示一个 Controller。2,表示当前这个 Controller 下的所有的方法都会以
json 格式的数据响应。
八、 回顾 SpringBoot 异常处理:
@ControllerAdvice+@ExceptionHandler 注解处理异常
代码
@ControllerAdvice public class MyControllerAdvice { @ResponseBody @ExceptionHandler(value=java.lang.Exception.class) public Map<String, Object> myException(Exception ex) { Map<String, Object> map = new HashMap<>(); map.put("code", 500); map.put("msg", "出错了。"); return map; } @ResponseBody @ExceptionHandler(value=java.lang.NullPointerException.c lass) public Map<String, Object> myException2(Exception ex) { Map<String, Object> map = new HashMap<>(); map.put("code", -500); map.put("msg", "空指针异常"); return map; } @ResponseBody @ExceptionHandler(value=com.bjsxt.springboothelloworld.e xception.ApplicationException.class) public Map<String, Object> myException3(Exception ex) { Map<String, Object> map = new HashMap<>(); map.put("code", -800); map.put("msg", ex.getMessage()); return map; } }
九、 如何监控 Spring Boot 的健康状况
1 使用 Actuator 检查与监控的步骤
1.1在 pom 文件中添加 Actuator 的坐标
1.2在全局配置文件中设置关闭安全限制
2 使用可视化的监控报表-Spring Boot Admin
2.1使用 Spring Boot Admin 的步骤
2.1.1搭建服务端
服务端其实也是一个 SpringBoot 项目
2.1.1.1 创建项目
2.1.1.2 访问 Spring Boot Admin 的首页
https://github.com/codecentric/spring-boot-admin
修改 pom 文件添加 Spring Boot Admin 坐标
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-starter-server</artifactId>
<version>1.5.7</version>
</dependency>
2.1.1.3 修改启动类,添加@EnableAdminServer
@SpringBootApplication @EnableAdminServer public class SpringbootServerApplication { public static void main(String[] args) { SpringApplication.run(SpringbootServerApplication.class, args); } }
2.1.2搭建客户端
其实客户端就是我们需要监控的工程。
2.1.2.1 修改客户端的 pom 文件添加依赖
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-starter-client</artifactId>
<version>1.5.7</version>
</dependency>
2.1.2.2 修改客户端的 application.properteis 配置文件
management.security.enabled=false
#http://localhost:9090 表示是 Spring Boot Admin 服务单的 IP 地
址以及端口号
spring.boot.admin.url: http://localhost:9090
2.2监控信息讲解