当前位置:   article > 正文

springcloud中用到的配置项,kafka、Validator、swagger等_spring cloud validator

spring cloud validator

swagger:

swagger 引入

  1. <!-- swagger -->
  2. <dependency>
  3. <groupId>io.springfox</groupId>
  4. <artifactId>springfox-swagger-ui</artifactId>
  5. <version>2.7.0</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>io.springfox</groupId>
  9. <artifactId>springfox-swagger2</artifactId>
  10. <version>2.7.0</version>
  11. </dependency>


swagger引入到spring容器

 

 

  1. /**
  2. * 创建API应用
  3. * apiInfo() 增加API相关信息
  4. * 通过select()函数返回一个ApiSelectorBuilder实例,用来控制哪些接口暴露给Swagger来展现,
  5. * 本例采用指定扫描的包路径来定义指定要建立API的目录。
  6. *
  7. */
  8. @Bean
  9. public Docket createRestApi() {
  10. return new Docket(DocumentationType.SWAGGER_2)
  11. .apiInfo(apiInfo())
  12. .select()
  13. .apis(RequestHandlerSelectors.basePackage(swagerPackage)) //swagget扫描目录
  14. .paths(PathSelectors.any())
  15. .build();
  16. }
  17. /**
  18. * 创建该API的基本信息(这些基本信息会展现在文档页面中)
  19. * 访问地址:http://项目实际地址/swagger-ui.html
  20. * demo
  21. */
  22. protected ApiInfo apiInfo() {
  23. return new ApiInfoBuilder()
  24. .title("Swagger2构建RESTful APIs")
  25. .description("China DaaS Technology Corp., Ltd")
  26. .termsOfServiceUrl("http://www.chinadaas.com/")
  27. .version("1.0")
  28. .build();
  29. }

 

 

 

 

 

Validator

spring-cloud-starter-eureka中包含spring-boot-starter-web中包含Validator,不需要重复引入依赖

 

  1. <dependency>
  2. <groupId>org.hibernate</groupId>
  3. <artifactId>hibernate-validator</artifactId>
  4. <version>5.3.5.Final</version>
  5. </dependency>

 

 

引入到spring容器

    // 一次不通过就停止校验
  1. @Bean
  2. public Validator validator() {
  3. ValidatorFactory validatorFactory = Validation.byProvider(HibernateValidator.class).configure().addProperty("hibernate.validator.fail_fast", "true").buildValidatorFactory();
  4. Validator validator = validatorFactory.getValidator();
  5. return validator;
  6. }


参考:https://www.cnblogs.com/mr-yang-localhost/p/7812038.html

 

kafka

kafka引入依赖

 

  1. <!--kafka-->
  2. <dependency>
  3. <groupId>org.springframework.kafka</groupId>
  4. <artifactId>spring-kafka</artifactId>
  5. </dependency>


kafka生产者配置项:

 

 

  1. kafka:
  2. producer:
  3. max-request-size: 10485760
  4. bootstrap-servers: 10.80.111.214:9092
  5. request-required-acks: 1
  6. retries: 5
  7. batch-size: 16384
  8. linger: 1
  9. buffer-memory: 134217728
  10. block-on-buffer-full: false
  11. key-serializer: org.apache.kafka.common.serialization.StringSerializer
  12. value-serializer: org.apache.kafka.common.serialization.StringSerializer


kafka生产者配置到spring 容器

 

 

  1. @Value("${kafka.producer.max-request-size}")
  2. private String maxRequestSize;
  3. @Value("${kafka.producer.bootstrap-servers}")
  4. private String servers;
  5. @Value("${kafka.producer.request-required-acks}")
  6. private String requiredAcks;
  7. @Value("${kafka.producer.retries}")
  8. private String retries;
  9. @Value("${kafka.producer.batch-size}")
  10. private String batchSize;
  11. @Value("${kafka.producer.linger}")
  12. private String linger;
  13. @Value("${kafka.producer.buffer-memory}")
  14. private String bufferMemory;
  15. @Value("${kafka.producer.key-serializer}")
  16. private String key;
  17. @Value("${kafka.producer.value-serializer}")
  18. private String value;
  19. @Bean("kafkaTemplate")
  20. public KafkaTemplate<String, String> kafkaTemplate() {
  21. return new KafkaTemplate<String, String>(producerFactory());
  22. }
  23. public ProducerFactory<String, String> producerFactory() {
  24. Map<String, Object> properties = new HashMap<>();
        properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, servers);
  1. //重试次数 如果请求失败,生产者会自动重试,如果启用重试,则会有重复消息的可能性
  2. properties.put(ProducerConfig.RETRIES_CONFIG, retries);
//重试次数 如果请求失败,生产者会自动重试,如果启用重试,则会有重复消息的可能性 properties.put(ProducerConfig.RETRIES_CONFIG, retries);
  1. //最大消息大小
  2. properties.put(ProducerConfig.MAX_REQUEST_SIZE_CONFIG, maxRequestSize);
//最大消息大小 properties.put(ProducerConfig.MAX_REQUEST_SIZE_CONFIG, maxRequestSize);
  1.         /**
  2.          * Server完成 producer request 前需要确认的数量。 acks=0时,producer不会等待确认,直接添加到socket等待发送;
  3.          * acks=1时,等待leader写到local log就行; acks=all或acks=-1时,等待isr中所有副本确认 (注意:确认都是 broker
  4.          * 接收到消息放入内存就直接返回确认,不是需要等待数据写入磁盘后才返回确认,这也是kafka快的原因)
  5.          */
  6. properties.put(ProducerConfig.ACKS_CONFIG, requiredAcks);
  1.         /**
  2.          * Producer可以将发往同一个Partition的数据做成一个Produce
  3.          * Request发送请求,即Batch批处理,以减少请求次数,该值即为每次批处理的大小。
  4.          * 另外每个Request请求包含多个Batch,每个Batch对应一个Partition,且一个Request发送的目的Broker均为这些partition的leader副本。
  5.          * 若将该值设为0,则不会进行批处理
  6.          */
  7. properties.put(ProducerConfig.BATCH_SIZE_CONFIG, batchSize);
  1.         /**
  2.          * 默认缓冲可立即发送,即遍缓冲空间还没有满,但是,如果你想减少请求的数量,可以设置linger.ms大于0。
  3.          * 这将指示生产者发送请求之前等待一段时间,希望更多的消息填补到未满的批中。这类似于TCP的算法,例如上面的代码段,
  4.          * 可能100条消息在一个请求发送,因为我们设置了linger(逗留)时间为1毫秒,然后,如果我们没有填满缓冲区,
  5.          * 这个设置将增加1毫秒的延迟请求以等待更多的消息。 需要注意的是,在高负载下,相近的时间一般也会组成批,即使是
  6.          * linger.ms=0。在不处于高负载的情况下,如果设置比0大,以少量的延迟代价换取更少的,更有效的请求。
  7.          */
  8. properties.put(ProducerConfig.LINGER_MS_CONFIG, linger);
  1.         /**
  2.          * 控制生产者可用的缓存总量,如果消息发送速度比其传输到服务器的快,将会耗尽这个缓存空间。
  3.          * 当缓存空间耗尽,其他发送调用将被阻塞,阻塞时间的阈值通过max.block.ms设定, 之后它将抛出一个TimeoutException。
  4.          */
  5. properties.put(ProducerConfig.BUFFER_MEMORY_CONFIG, bufferMemory);
  6. properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, key);
  7. properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, value);
  8. return new DefaultKafkaProducerFactory<String, String>(properties);
  9. }


参考博客:http://blog.csdn.net/yy756127197/article/details/78252432 、http://blog.csdn.net/suifeng3051/article/details/48053965

 

 

 

feign

  1. /**
  2. * 启动feign日志
  3. * @return
  4. */
  5. @Bean
  6. public Logger.Level feignLoggerLevel() {
  7. return feign.Logger.Level.FULL;
  8. }


配置具体的类开启debug

 

logging.level.com.**.demo.feign.**: debug

 

 

Log

  1. logging:
  2. path: ${user.dir}/logs
  3. file: ${logging.path}/cloud-demo.log
  4. level:
  5. root: info
  6. com.**: debug

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/58775
推荐阅读
相关标签
  

闽ICP备14008679号