Turbine使用
一、简介
Turbine是聚合服务器发送事件流数据的一个工具,Hystrix的监控中,只能监控单个节点,实际生产中都为集群,因此可以通过Turbine来监控集群下Hystrix的metrics情况
Turbine的github地址:https://github.com/Netflix/Turbine
二、基本环境
- 一个eureka模块
- 两个消费者模块
- 一个turbine监控模块
三、创建eureka模块
(1)创建项目
创建一个spring boot项目

(2)依赖
- 
<?xml version="1.0" encoding="UTF-8"?>
- 
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- 
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- 
    <modelVersion>4.0.0</modelVersion>
- 
 
- 
    <groupId>com.abc</groupId>
- 
    <artifactId>00-eurekaserver-8000</artifactId>
- 
    <version>0.0.1-SNAPSHOT</version>
- 
    <packaging>jar</packaging>
- 
 
- 
    <parent>
- 
        <groupId>org.springframework.boot</groupId>
- 
        <artifactId>spring-boot-starter-parent</artifactId>
- 
        <version>2.1.7.RELEASE</version>
- 
        <relativePath/> <!-- lookup parent from repository -->
- 
    </parent>
- 
 
- 
    <properties>
- 
        <java.version>1.8</java.version>
- 
        <spring-cloud.version>Greenwich.SR2</spring-cloud.version>
- 
    </properties>
- 
 
- 
    <dependencies>
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
- 
        </dependency>
- 
 
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-starter-test</artifactId>
- 
            <scope>test</scope>
- 
        </dependency>
- 
 
- 
        <!--热部署依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-devtools</artifactId>
- 
            <optional>true</optional>
- 
        </dependency>
- 
    </dependencies>
- 
 
- 
    <dependencyManagement>
- 
        <dependencies>
- 
            <dependency>
- 
                <groupId>org.springframework.cloud</groupId>
- 
                <artifactId>spring-cloud-dependencies</artifactId>
- 
                <version>${spring-cloud.version}</version>
- 
                <type>pom</type>
- 
                <scope>import</scope>
- 
            </dependency>
- 
        </dependencies>
- 
    </dependencyManagement>
- 
 
- 
    <build>
- 
        <plugins>
- 
            <plugin>
- 
                <groupId>org.springframework.boot</groupId>
- 
                <artifactId>spring-boot-maven-plugin</artifactId>
- 
            </plugin>
- 
        </plugins>
- 
    </build>
- 
 
- 
</project>
(3)application.yml配置
- 
server:
- 
  port: 8000
- 
 
- 
eureka:
- 
  instance:
- 
    hostname: localhost  # 指定Eureka主机
- 
  client:
- 
    register-with-eureka: false   # 指定当前主机是否向Eureka服务器进行注册
- 
    fetch-registry: false    # 指定当前主机是否要从Eurka服务器下载服务注册列表
- 
    service-url:   # 服务暴露地址
- 
     defaultZone: http://localhost:8000/eureka
- 
#     defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka
- 
 
- 
#  server:
- 
#    enable-self-preservation: false    # 关闭自我保护
(4)启动类
- 
package com.abc.eureka;
- 
 
- 
import org.springframework.boot.SpringApplication;
- 
import org.springframework.boot.autoconfigure.SpringBootApplication;
- 
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
- 
 
- 
@SpringBootApplication
- 
@EnableEurekaServer   // 开启Eureka服务
- 
public class EurekaServerApplication {
- 
 
- 
    public static void main(String[] args) {
- 
        SpringApplication.run(EurekaServerApplication.class, args);
- 
    }
- 
}
四、创建消费者09-consumer-turbine-8080
(1)创建项目
创建一个spring boot项目

(2)依赖
- 
<?xml version="1.0" encoding="UTF-8"?>
- 
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- 
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- 
    <modelVersion>4.0.0</modelVersion>
- 
    <parent>
- 
        <groupId>org.springframework.boot</groupId>
- 
        <artifactId>spring-boot-starter-parent</artifactId>
- 
        <version>2.1.7.RELEASE</version>
- 
        <relativePath/> <!-- lookup parent from repository -->
- 
    </parent>
- 
    <groupId>com.abc</groupId>
- 
    <artifactId>09-consumer-turbine-8080</artifactId>
- 
    <version>0.0.1-SNAPSHOT</version>
- 
    <name>09-consumer-turbine-8080</name>
- 
    <description>Demo project for Spring Boot</description>
- 
 
- 
    <properties>
- 
        <java.version>1.8</java.version>
- 
        <spring-cloud.version>Greenwich.SR2</spring-cloud.version>
- 
    </properties>
- 
 
- 
    <dependencies>
- 
 
- 
        <!--hystrix依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
- 
        </dependency>
- 
 
- 
        <!--feign依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-openfeign</artifactId>
- 
        </dependency>
- 
 
- 
        <!-- hystrix-dashboard依赖 -->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
- 
        </dependency>
- 
 
- 
        <!--actuator依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-starter-actuator</artifactId>
- 
        </dependency>
- 
 
- 
        <!--eureka客户端依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
- 
        </dependency>
- 
 
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-starter-web</artifactId>
- 
        </dependency>
- 
 
- 
        <!-- https://mvnrepository.com/artifact/org.webjars.bower/jquery -->
- 
        <dependency>
- 
            <groupId>org.webjars.bower</groupId>
- 
            <artifactId>jquery</artifactId>
- 
            <version>2.1.1</version>
- 
        </dependency>
- 
 
- 
        <dependency>
- 
            <groupId>org.projectlombok</groupId>
- 
            <artifactId>lombok</artifactId>
- 
            <optional>true</optional>
- 
        </dependency>
- 
 
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-turbine</artifactId>
- 
        </dependency>
- 
        <!--热部署依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-devtools</artifactId>
- 
            <optional>true</optional>
- 
        </dependency>
- 
 
- 
    </dependencies>
- 
 
- 
    <dependencyManagement>
- 
        <dependencies>
- 
            <dependency>
- 
                <groupId>org.springframework.cloud</groupId>
- 
                <artifactId>spring-cloud-dependencies</artifactId>
- 
                <version>${spring-cloud.version}</version>
- 
                <type>pom</type>
- 
                <scope>import</scope>
- 
            </dependency>
- 
        </dependencies>
- 
    </dependencyManagement>
- 
 
- 
    <build>
- 
        <plugins>
- 
            <plugin>
- 
                <groupId>org.springframework.boot</groupId>
- 
                <artifactId>spring-boot-maven-plugin</artifactId>
- 
            </plugin>
- 
        </plugins>
- 
    </build>
- 
 
- 
</project>
(3)application.yml配置
- 
# 在微服务网关zuul中演示时需要该工程的端口号为8090
- 
server:
- 
  port: 8080
- 
 
- 
spring:
- 
  application:  # 指定微服务对外暴露的名称
- 
    name: abcmsc-consumer-depart01
- 
 
- 
eureka:
- 
  client:
- 
    service-url:
- 
      defaultZone: http://localhost:8000/eureka
- 
    #  instance:
- 
      #   metadata-map:
- 
    #   cluster: ribbon
- 
# 开启Feign对Hystrix的支持
- 
feign:
- 
  hystrix:
- 
    enabled: true
- 
 
- 
  client:
- 
    config:
- 
      default:
- 
        connectTimeout: 5000  # 指定Feign连接提供者的超时时限
- 
        readTimeout: 5000    # 指定Feign从请求到获取提供者响应的超时时限
- 
 
- 
# 开启actuator的所有web终端
- 
management:
- 
  endpoints:
- 
    web:
- 
      exposure:
- 
        include: "*"
- 
 
- 
# 设置服务熔断时限
- 
hystrix:
- 
  command:
- 
    default:
- 
      execution:
- 
        isolation:
- 
          thread:
- 
            timeoutInMilliseconds: 3000
(4)实体类Depart
- 
package com.abc.consumer.bean;
- 
 
- 
import lombok.Data;
- 
 
- 
@Data
- 
public class Depart {
- 
    private Integer id;
- 
    private String name;
- 
}
(5)DepartCodeConfig类
- 
package com.abc.consumer.codeconfig;
- 
 
- 
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
- 
import org.springframework.context.annotation.Bean;
- 
import org.springframework.context.annotation.Configuration;
- 
import org.springframework.web.client.RestTemplate;
- 
 
- 
@Configuration
- 
public class DepartCodeConfig {
- 
 
- 
    @LoadBalanced    // 开启消息者端的负载均衡功能,默认是轮询策略
- 
    @Bean
- 
    public RestTemplate restTemplate() {
- 
        return new RestTemplate();
- 
    }
- 
 
- 
}
(6)DepartController类
- 
package com.abc.consumer.controller;
- 
 
- 
import com.abc.consumer.bean.Depart;
- 
import com.abc.consumer.service.DepartService;
- 
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
- 
import org.springframework.beans.factory.annotation.Autowired;
- 
import org.springframework.web.bind.annotation.*;
- 
 
- 
import java.util.List;
- 
 
- 
@RestController
- 
@RequestMapping("/consumer/depart")
- 
public class DepartController {
- 
 
- 
    @Autowired
- 
    DepartService service;
- 
 
- 
    // 服务降级:若当前处理器方法发生异常,则执行fallbackMethod属性指定的方法
- 
    @HystrixCommand(fallbackMethod = "getHystrixHandle")
- 
    @GetMapping("/get/{id}")
- 
    public Depart getHandle(@PathVariable("id") int id) {
- 
        return service.getDepartById(id);
- 
    }
- 
 
- 
    public Depart getHystrixHandle(@PathVariable("id") int id) {
- 
        Depart depart = new Depart();
- 
        depart.setId(id);
- 
        depart.setName("no this depart  -- 方法级别");
- 
        return depart;
- 
    }
- 
 
- 
 
- 
}
(7)DepartService类
- 
package com.abc.consumer.service;
- 
 
- 
 
- 
import com.abc.consumer.bean.Depart;
- 
import org.springframework.cloud.openfeign.FeignClient;
- 
import org.springframework.stereotype.Service;
- 
import org.springframework.web.bind.annotation.*;
- 
 
- 
import java.util.List;
- 
 
- 
@Service
- 
// 指定当前Service所绑定的提供者微服务名称
- 
// fallback指定该接口所绑定的服务降级类
- 
@FeignClient(value = "abcmsc-provider-depart")
- 
@RequestMapping("/provider/depart")
- 
public interface DepartService {
- 
    @GetMapping("/get/{id}")
- 
    Depart getDepartById(@PathVariable("id") int id);
- 
 
- 
}
(8)启动类
- 
package com.abc.consumer;
- 
 
- 
import org.springframework.boot.SpringApplication;
- 
import org.springframework.cloud.client.SpringCloudApplication;
- 
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
- 
import org.springframework.cloud.openfeign.EnableFeignClients;
- 
 
- 
// 指定Service接口所在的包,开启OpenFeign客户端
- 
@EnableFeignClients(basePackages = "com.abc.consumer.service")
- 
@SpringCloudApplication
- 
@EnableHystrixDashboard   // 开启Hystrix仪表盘功能
- 
public class Consumer01Application {
- 
 
- 
    public static void main(String[] args) {
- 
        SpringApplication.run(Consumer01Application.class, args);
- 
    }
- 
 
- 
}
五、创建消费者09-consumer-turbine-8081
(1)复制项目09-consumer-turbine-8080

(2)修改依赖

(3)修改application.yml配置

(4)修改09-consumer-turbine-8081.iml

六、创建消费者turbine监控
(1)创建项目
创建一个spring boot项目

(2)依赖
- 
<?xml version="1.0" encoding="UTF-8"?>
- 
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- 
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- 
    <modelVersion>4.0.0</modelVersion>
- 
    <parent>
- 
        <groupId>org.springframework.boot</groupId>
- 
        <artifactId>spring-boot-starter-parent</artifactId>
- 
        <version>2.1.7.RELEASE</version>
- 
        <relativePath/> <!-- lookup parent from repository -->
- 
    </parent>
- 
    <groupId>com.abc</groupId>
- 
    <artifactId>09-consumer-turbine-monitor-9000</artifactId>
- 
    <version>0.0.1-SNAPSHOT</version>
- 
    <name>09-consumer-turbine-monitor-9000</name>
- 
    <description>Demo project for Spring Boot</description>
- 
 
- 
    <properties>
- 
        <java.version>1.8</java.version>
- 
        <spring-cloud.version>Greenwich.SR2</spring-cloud.version>
- 
    </properties>
- 
 
- 
    <dependencies>
- 
 
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-turbine</artifactId>
- 
        </dependency>
- 
 
- 
        <!--hystrix依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
- 
        </dependency>
- 
 
- 
        <!--feign依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-openfeign</artifactId>
- 
        </dependency>
- 
 
- 
        <!-- hystrix-dashboard依赖 -->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
- 
        </dependency>
- 
 
- 
        <!--actuator依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-starter-actuator</artifactId>
- 
        </dependency>
- 
 
- 
        <!--eureka客户端依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.cloud</groupId>
- 
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
- 
        </dependency>
- 
 
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-starter-web</artifactId>
- 
        </dependency>
- 
 
- 
        <!-- https://mvnrepository.com/artifact/org.webjars.bower/jquery -->
- 
        <dependency>
- 
            <groupId>org.webjars.bower</groupId>
- 
            <artifactId>jquery</artifactId>
- 
            <version>2.1.1</version>
- 
        </dependency>
- 
 
- 
        <dependency>
- 
            <groupId>org.projectlombok</groupId>
- 
            <artifactId>lombok</artifactId>
- 
            <optional>true</optional>
- 
        </dependency>
- 
        <!--热部署依赖-->
- 
        <dependency>
- 
            <groupId>org.springframework.boot</groupId>
- 
            <artifactId>spring-boot-devtools</artifactId>
- 
            <optional>true</optional>
- 
        </dependency>
- 
 
- 
    </dependencies>
- 
    <dependencyManagement>
- 
        <dependencies>
- 
            <dependency>
- 
                <groupId>org.springframework.cloud</groupId>
- 
                <artifactId>spring-cloud-dependencies</artifactId>
- 
                <version>${spring-cloud.version}</version>
- 
                <type>pom</type>
- 
                <scope>import</scope>
- 
            </dependency>
- 
        </dependencies>
- 
    </dependencyManagement>
- 
 
- 
    <build>
- 
        <plugins>
- 
            <plugin>
- 
                <groupId>org.springframework.boot</groupId>
- 
                <artifactId>spring-boot-maven-plugin</artifactId>
- 
            </plugin>
- 
        </plugins>
- 
    </build>
- 
 
- 
</project>
(3)application.yml配置
- 
 
- 
server:
- 
  port: 9000
- 
 
- 
spring:
- 
  application:  # 指定微服务对外暴露的名称
- 
    name: 09-consumer-turbine-monitor-9000
- 
 
- 
eureka:
- 
  client:
- 
    service-url: # 指定Eureka服务注册中心
- 
      defaultZone: http://localhost:8000/eureka
- 
 
- 
# 开启Feign对Hystrix的支持
- 
feign:
- 
  hystrix:
- 
    enabled: true
- 
 
- 
  client:
- 
    config:
- 
      default:
- 
        connectTimeout: 5000  # 指定Feign连接提供者的超时时限
- 
        readTimeout: 5000    # 指定Feign从请求到获取提供者响应的超时时限
- 
 
- 
# 开启actuator的所有web终端
- 
management:
- 
  endpoints:
- 
    web:
- 
      exposure:
- 
        include: "*"
- 
 
- 
# 设置服务熔断时限
- 
hystrix:
- 
  command:
- 
    default:
- 
      execution:
- 
        isolation:
- 
          thread:
- 
            timeoutInMilliseconds: 3000
- 
turbine:
- 
  app-config: abcmsc-consumer-depart01,abcmsc-consumer-depart02
- 
  cluster-name-expression: new String("default")
- 
  combine-host-port: true
- 
  instanceUrlSuffix: /actuator/hystrix.stream #turbine默认监控actuator/路径下的端点,修改直接监控hystrix.stream
- 
    #cluster-name-expression: metadata['cluster']
- 
    #aggregator:
- 
  # cluster-config: ribbon
- 
  #instanceUrlSuffix:  /hystrix.stream #turbine默认监控actuator/路径下的端点,修改直接监控hystrix.stream
(4)启动类
- 
package com.abc.consumer;
- 
 
- 
import org.springframework.boot.SpringApplication;
- 
import org.springframework.boot.autoconfigure.SpringBootApplication;
- 
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
- 
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
- 
import org.springframework.cloud.netflix.turbine.EnableTurbine;
- 
 
- 
 
- 
@SpringBootApplication
- 
@EnableTurbine
- 
@EnableHystrixDashboard
- 
@EnableEurekaClient
- 
public class MonitorApplication {
- 
 
- 
    public static void main(String[] args) {
- 
        SpringApplication.run(MonitorApplication.class, args);
- 
    }
- 
 
- 
   /*@Bean
- 
    public ServletRegistrationBean getServlet() {
- 
        HystrixMetricsStreamServlet streamServlet = new HystrixMetricsStreamServlet();
- 
        ServletRegistrationBean registrationBean = new ServletRegistrationBean(streamServlet);
- 
        registrationBean.setLoadOnStartup(1);
- 
        registrationBean.addUrlMappings("/actuator/hystrix.stream);
- 
        registrationBean.setName("HystrixMetricsStreamServlet");
- 
        return registrationBean;
- 
    }*/
- 
 
- 
}
七、启动
(1)启动eureka模块
(2)启动两个消费者模块
(3)启动turbine监控模块
八、效果
(1)请求http://localhost:8080/consumer/depart/get/1

(1)请求http://localhost:8081/consumer/depart/get/1

浏览器访问http://localhost:9000/hystrix
输入http://localhost:9000/turbine.stream


其他说明
图片说明借鉴 https://www.jianshu.com/p/590bad4c8947
Turbine使用的更多相关文章
- 第二十六章 hystrix-dashboard + turbine
		一.使用turbine的意义 引入多个hystrix stream: 1.使用hystrix-dashboard的可以添加多个stream的功能 图中添加的两个stream会在真正monitor的时候 ... 
- 附7 turbine
		一.作用 聚集同一个微服务的相同的commandKey.Threadpool.commandGroupKey数据进行聚合 二.配置 1.集群(cluster)(turbine聚集数据的粒度) turb ... 
- apache开源项目-- Turbine
		1.缘起 Jetspeed是Apache Jakarta小组的开放源码门户系统.它使得最终用户可以通过WAP手机.浏览器.PDA等各种设备来使用各种各样的网络资源(比如应用程序.数据以及这之外的任何网 ... 
- springcloud(五):熔断监控Hystrix Dashboard和Turbine
		Hystrix-dashboard是一款针对Hystrix进行实时监控的工具,通过Hystrix Dashboard我们可以在直观地看到各Hystrix Command的请求响应时间, 请求成功率等数 ... 
- spring cloud熔断监控Hystrix Dashboard和Turbine
		参考: http://blog.csdn.net/ityouknow/article/details/72625646 完整pom <?xml version="1.0" e ... 
- 改造断路器集群监控Hystrix Turbine实现自动注册消费者、实时监控多个服务
		在上一篇文章中,我们搭建了Hystrix Dashoard,对指定接口进行监控.但是只能对一个接口进行监听,功能比较局限: Turbine:汇总系统内多个服务的数据并显示到 Hystrix Dashb ... 
- spring cloud(五)熔断监控Hystrix Dashboard和Turbine
		Hystrix-dashboard是一款针对Hystrix进行实时监控的工具,通过Hystrix Dashboard我们可以在直观地看到各Hystrix Command的请求响应时间, 请求成功率等数 ... 
- Spring Cloud Turbine微服务集群实时监控
		本文代码下载地址: https://gitlab.com/mySpringCloud/turbine SpringBoot版本:1.5.9.RELEASE (稳定版) SpringCloud版本:Ed ... 
- SpringCloud系列七:Hystrix 熔断机制(Hystrix基本配置、服务降级、HystrixDashboard服务监控、Turbine聚合监控)
		1.概念:Hystrix 熔断机制 2.具体内容 所谓的熔断机制和日常生活中见到电路保险丝是非常相似的,当出现了问题之后,保险丝会自动烧断,以保护我们的电器, 那么如果换到了程序之中呢? 当现在服务的 ... 
- Spring Cloud 入门教程(八): 断路器指标数据监控Hystrix Dashboard 和 Turbine
		1. Hystrix Dashboard (断路器:hystrix 仪表盘) Hystrix一个很重要的功能是,可以通过HystrixCommand收集相关数据指标. Hystrix Dashboa ... 
随机推荐
- feign微服务调用携带浏览器信息(header、cookie)
			import feign.RequestInterceptor; import feign.RequestTemplate; import org.apache.commons.collections ... 
- django前后端分离403 csrf token missing or incorrect
			根据这个链接https://stackoverflow.com/a/26639895 这是一个django的跨域访问问题. django,会对合法的跨域访问做这样的检验,cookies里面存储的'cs ... 
- 菜鸡的Java笔记 第三十一 扩展结构
			.新特性 可变参数的意义以及实现 那么下面通过一个简单的思考来分析可变参数的存在意义 范例:如果说现在要定义一个方法,这个方法可以实现任意多个 ... 
- [hdu6987]Cycle Binary
			定义$x$为$s$的周期,当且仅当$\forall 1\le i\le |s|-x,s_{i}=s_{i+x}$(字符串下标从1开始) 令$per(s)$为$s$的正周期构成的集合,$\min p ... 
- [bzoj5338]xor
			维护两颗可持久化字典树(当然可以放在一起),第一棵维护每一个点到根的每一位的二进制数量,在其父亲的基础上建立:第二棵维护dfs序上每一个点到第1个点的二进制数量,在其上一个点的基础上建立. 对于询问1 ... 
- ThinkPad笔记本外放没声音解决办法(不是驱动的原因)
			本人的本子是T480,自从装完Ubuntu系统之后W10系统就没有外放声音了,卸载Ubuntu之后还是没有声音,重装声卡驱动.重装系统之后依然无效. 我的解决办法是升级主板Bois,具体如下: 进入官 ... 
- 低代码开发Paas平台时代来了
			概述 **本人博客网站 **IT小神 www.itxiaoshen.com 低代码理论 概念 低代码开发基于可视化和模型驱动的概念,结合了云原生和多终端体验技术,它可以在大多数业务场景中,帮助企业显著 ... 
- x86汇编反编译到c语言之——(1)表达式求值及赋值语句
			一. 反编译一种可能的实现方式 我们的目的是将多种平台的汇编如x86,ARM,6502反编译为c语言,所以实现时先将多种汇编转化为 特定虚拟机汇编语言,然后只需要将虚拟机汇编语言反编译为c语言.其中多 ... 
- vue3 学习笔记(九)——script setup 语法糖用了才知道有多爽
			刚开始使用 script setup 语法糖的时候,编辑器会提示这是一个实验属性,要使用的话,需要固定 vue 版本. 在 6 月底,该提案被正式定稿,在 v3.1.3 的版本上,继续使用但仍会有实验 ... 
- 网络管理之命令行工具nmcli
			参考Ubuntu官方文档和Red Hat,本文采用Google翻译. NETWORKMANAGER 简介 介绍 NetworkManager 提供的默认联网服务是一个动态网络控制和配置守护进程,它尝试 ... 
