Skip to content

springboot自动化配置、多数据源组件、Redis多数据源组件、全链路日志追踪、Netty、AOP、springcloud、consul、feign、resttemple、基础工具包、异常处理等等

Notifications You must be signed in to change notification settings

hahaho/spring-parent

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EmilyInfrustructure基础框架

maven父pom和子pom的版本号批量修改

1 设置新的版本号
./mvnw versions:set -DnewVersion=2.4.1
2 撤销设置
./mvnw versions:revert
3 提交设置
./mvnw versions:commit
4.项目打包(同时处理项目所依赖的包)
mvn clean install -pl emily-spring-boot-starter -am

./mvnw clean install -pl emily-spring-boot-starter -am
参数 全程 说明
-pl --projects 选项后可跟随{groupId}:{artifactId}或者所选模块的相对路径(多个模块以逗号分隔)
-am --also-make 表示同时处理选定模块所依赖的模块
-amd --also-make-dependents 表示同时处理依赖选定模块的模块
-N --non- 表示不递归子模块
-rf --resume-frm 表示从指定模块开始继续处理

打tag标签

1.添加tag
git tag -a version1.0 -m 'first version'
2.提交tag
git push origin --tags

其它tag操作参考:tag操作指南


自研框架-emily(小米粒)配置

#设置开启用户请求日志拦截器模式默认:true
spring.emily.api-log.enable=true
#设置开启日志debug模式默认:false
spring.emily.api-log.debug=false
#是否开启抛出的异常拦截默认true
spring.emily.exception.enable=true
#是否开启json转换器配置,默认true
spring.emily.jackson2.converter.enable=true

#设置开启返回结果包装默认:true
spring.emily.return-value.enable=true
#设置https配置开关,默认false
spring.emily.https.enable=false
#RedisTemplate组件开关默认:false
spring.emily.redis.enable=false
#限流组件开关默认:false
spring.emily.rate-limit.enable=true
#防止重复提交组件开关默认:false
spring.emily.idempotent.enable=false

#RestTemplate组件
#Http RestTemplate组件开关默认true
spring.emily.http-client.enable=true
#Http RestTemplate拦截器开关记录请求响应日志默认true
spring.emily.http-client.enable-interceptor=true
#http连接读取超时时间默认5000毫秒
spring.emily.http-client.read-time-out=5000
#http连接连接超时时间默认10000毫秒
spring.emily.http-client.connect-time-out=10000

#RestTemplate组件-Spring Cloud客户端负载均衡
#Http RestTemplate组件开关默认true
spring.emily.cloud.http-client-loadbalancer.enable=true
#Http RestTemplate拦截器开关记录请求响应日志默认true
spring.emily.cloud.http-client-loadbalancer.enable-interceptor=true
#http连接读取超时时间默认1000毫秒
spring.emily.cloud.http-client-loadbalancer.read-time-out=1000
#http连接连接超时时间默认1000毫秒
spring.emily.cloud.http-client-loadbalancer.connect-time-out=1000

#异步线程池
#异步线程池组件开关默认false
spring.emily.async-thread-pool.enable=true
#核心线程数,默认Java虚拟机可用线程数
spring.emily.async-thread-pool.core-pool-size=4
#线程池最大线程数,默认10000
spring.emily.async-thread-pool.max-pool-size=10000
#线程队列最大线程数,默认20000
spring.emily.async-thread-pool.queue-capacity=20000
#自定义线程名前缀默认Async-ThreadPool-
spring.emily.async-thread-pool.thread-name-prefix=Async-ThreadPool-
#线程池中线程最大空闲时间默认60单位
spring.emily.async-thread-pool.keep-alive-seconds=60
#核心线程是否允许超时默认false
spring.emily.async-thread-pool.allow-core-thread-time-out=false
#IOC容器关闭时是否阻塞等待剩余的任务执行完成默认:false必须设置setAwaitTerminationSecondsspring.emily.async-thread-pool.wait-for-tasks-to-complete-on-shutdown=false
#阻塞IOC容器关闭的时间默认10必须设置setWaitForTasksToCompleteOnShutdownspring.emily.async-thread-pool.await-termination-seconds=10

##API路由设置
#是否开启所有接口的前缀prefix,默认前面添加api
spring.emily.web.path.enable-all-prefix=true
#自定义添加前缀,默认api
spring.emily.web.path.prefix=api
#区分大小写,默认false
spring.emily.web.path.case-sensitive=false
#是否缓存匹配规则,默认null等于true
spring.emily.web.path.cache-patterns=true
#是否去除前后空格,默认false
spring.emily.web.path.trim-tokens=false
#设置URL末尾是否支持斜杠默认true,/a/b/有效,/a/b也有效
spring.emily.web.path.use-trailing-slash-match=true
#忽略URL前缀控制器设置,默认空
spring.emily.web.path.ignore-controller-url-prefix=

##跨域设置
#开启跨域设置默认false
spring.emily.web.cors.enable=false
#设置允许哪些源来访问,多个源用逗号分开
spring.emily.web.cors.allowed-origins=
#允许HTTP请求方法
spring.emily.web.cors.allowed-methods=GET,POST
#设置用户可以拿到的字段
spring.emily.web.cors.allowed-headers=
#设置浏览器是否应该发送凭据cookie
spring.emily.web.cors.allow-credentials=true
#设置响应HEAD,默认无任何设置不可以使用*
spring.emily.web.cors.exposed-headers=
#设置多长时间内不需要发送预检验请求可以缓存该结果默认1800秒
spring.emily.web.cors.max-age=1800


##swagger配置
spring.emily.swagger.enable=true
#分组使用英文单词逗号隔开group1,group2,group3
spring.emily.swagger.group=emily,rabbit,framework
#分组名称使用逗号隔开,跟group一一对应groupName1,groupName2,groupName3
spring.emily.swagger.group-name=小米粒,RabbitMQ测试,框架
#扫描包使用逗号隔开com.emily.boot,com.emily.test
spring.emily.swagger.base-package=com.yaomy.control.test.api.rabbit,com.yaomy.control.test.api.emily,com.emily.boot
#标题
spring.emily.swagger.api-info.title=Springboot2.3.3 API接口文档
#描述
spring.emily.swagger.api-info.description=小米粥是以小米作为主要食材熬制而成的一种独具特色的北方粥点口味清淡清香味具有简单易制健胃消食的特点煮粥时一定要先烧开水然后放入洗净后的小米先煮沸然后用文火熬汤粘稠后即可关火。
#版本号
spring.emily.swagger.api-info.version=V2.1.6.RELEASE

#日志组件
#启动日志访问组件默认false
spring.emily.accesslog.enable=true
#日志级别,即该等级之上才会输出ERROR > WARN > INFO > DEBUG > TRACE >ALL, 默认DEBUG
spring.emily.accesslog.level=debug
#通用日志输出格式默认:[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] [%-5level] [%-36.36logger{36}:%-4.4line] : %msg%n
spring.emily.accesslog.common-pattern=[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] [%-5level] [%-36.36logger{36}:%-4.4line] : %msg%n
#模块日志输出格式默认:%msg%n
spring.emily.accesslog.module-pattern=%msg%n
#是否将模块日志输出到控制台默认false
spring.emily.accesslog.enable-module-consule=false
#日志文件存放路径默认是:./logs
spring.emily.accesslog.path=./logs
#设置要保留的最大存档文件数,默认 7
spring.emily.accesslog.max-history=7
#是否开启基于文件大小和时间的SizeAndTimeBasedRollingPolicy归档策略
#默认是基于TimeBasedRollingPolicy的时间归档策略默认false
spring.emily.accesslog.enable-size-and-time-rolling-policy=true
#最大日志文件大小 KBMBGB默认500MB
spring.emily.accesslog.max-file-size=500MB
#文件总大小限制 KBMBGB默认5GB
spring.emily.accesslog.total-size-cap=5GB
#是否开启异步记录Appender默认false
spring.emily.accesslog.enable-async-appender=true
#队列的最大容量默认为 256
spring.emily.accesslog.async-queue-size=256
#默认当队列还剩余 20% 的容量时会丢弃级别为 TRACE, DEBUG  INFO 的日志仅仅只保留 WARN  ERROR 级别的日志想要保留所有的事件可以设置为 0
spring.emily.accesslog.async-discarding-threshold=0
# 根据所引用 appender 队列的深度以及延迟AsyncAppender 可能会耗费长时间去刷新队列。
#  LoggerContext 被停止时AsyncAppender stop 方法会等待工作线程指定的时间来完成。
# 使用 maxFlushTime 来指定最大的刷新时间单位为毫秒在指定时间内没有被处理完的事件将会被丢弃这个属性的值的含义与 Thread.join(long)) 相同
# 默认是 1000毫秒
spring.emily.accesslog.async-max-flush-time=1000
# 在队列满的时候 appender 会阻塞而不是丢弃信息设置为 trueappender 不会阻塞你的应用而会将消息丢弃默认为 false
spring.emily.accesslog.async-never-block=false
consul服务查询、删除接口
  • 查询服务接口Get
http://127.0.0.1:8500/v1/agent/checks
  • 删除consul服务接口PUT方法
http://127.0.0.1:8500/v1/agent/service/deregister/instance-id(实例ID)
IDEA快捷键
  • 查询类的所有方法:

    F+command+F12
    

About

springboot自动化配置、多数据源组件、Redis多数据源组件、全链路日志追踪、Netty、AOP、springcloud、consul、feign、resttemple、基础工具包、异常处理等等

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 97.9%
  • HTML 1.6%
  • Other 0.5%