通过 AtomicIntegerArray 或 AtomicInteger做简单的洪流控制【转】

15 篇文章 0 订阅

在设计系统的时候,为了防止雪崩效应我们都需要加入一些洪流控制,比如你有多个分库的时候,你肯定不会希望见到某一个分库挂掉的时候把整个应用都拖垮,通过一个简单的计数器我们就可以实现简单的洪流控制。

JDK 最新提供的java.util.concurrent.*下的类简化了多线程的编程,atomic类采用经典的compareAndSet模式,在不同步锁的情况下保证了多线程的数据安全,进而极大地提升性能。

 

	//并发控制器
	static AtomicIntegerArray floodCounter = new AtomicIntegerArray(16);
	//最大并发量
	public static int maxFloodCount = 10;
	//权重
	public static int QueryItemByIDFloodCount = 1;
 
	public static void queryItemById(long id) {
		int db = (int) (id % 16);
		if (floodCounter.getAndAdd(db, QueryItemByIDFloodCount) > maxFloodCount) {
			System.out.println("I'am busy!");
			floodCounter.addAndGet(db, -QueryItemByIDFloodCount);
			return;
		}
		System.out.println("do somthing!");
		floodCounter.addAndGet(db, -QueryItemByIDFloodCount);
	}

这个包下面还有ConcurrentHashMap等系列的map,list,set,极大地简化了在并发情况下使用这些常用类的难度,让开发人员不在为并发而头疼。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值