隔离
Hystrix有两种隔离方式:信号量和线程池。
线程池隔离:对每个command创建一个自己的线程池,执行调用。通过线程池隔离来保证不同调用不会相互干扰和每一个调用的并发限制。
信号量隔热:对每个command创建一个自己的计数器,当并发量超过计数器指定值时,直接拒绝。使用信号量和线程池的一个区别是,信号量没有timeout机制
线程池实现
HystrixThreadPool是hystrix中的线程池实现,每个线程池有一个threadkey作为key。在创建HystrixCommand时需要创建一个该命令使用的线程池的threadkey。
Hystrix线程池(HystrixThreadPool)底层使用JDK ThreadPoolExecutor实现线程管理,其实际就是封装了JDK ThreadPoolExecutor。