一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - JAVA流控及超流控后的延遲處理實例

JAVA流控及超流控后的延遲處理實例

2019-12-07 15:54shichen2014 JAVA教程

這篇文章主要介紹了JAVA流控及超流控后的延遲處理,以實例形式較為詳細的分析了Java進行流量控制的技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了JAVA流控及超流控后的延遲處理方法。分享給大家供大家參考。具體實現方法如下:

流控檢查(每半秒累計,因此最小留空閥值只能做到每秒2條):

 

復制代碼代碼如下:
import java.text.SimpleDateFormat;
import java.util.Date;
import java.lang.Thread;
 
/**
 * 流量控制
 *
 * @author chenx
 */
public class OverflowController {
 
    private int maxSendCountPerSecend; // 該條鏈路上流控閥值
    private Date sendTime = new Date();
    private int sendCount = 0; // 該條鏈路上發送的數量
 
    public OverflowController(int maxSendCountPerSecend) {
        if (maxSendCountPerSecend < 2) {
            maxSendCountPerSecend = 2;
        }
 
        this.maxSendCountPerSecend = maxSendCountPerSecend;
    }
 
    public int getMaxSendCountPerSecend() {
        if (getMilliseconds(new Date()) >= 500) {
            return maxSendCountPerSecend / 2;
        }
 
        return maxSendCountPerSecend - (maxSendCountPerSecend / 2);
    }
 
    /**
     * 是否超流控
     */
    public boolean isOverflow(int sendNum) {
        synchronized (this) {
            Date now = new Date();
            if (now.getTime() - sendTime.getTime() >= 500) {
                sendTime = now;
                sendCount = sendNum;
            } else {
                if (sendCount + sendNum > getMaxSendCountPerSecend()) {
                    return true;
                } else {
                    sendCount += sendNum;
                }
            }
 
            return false;
        }
    }
 
    /**
     * 獲取指定時間的毫秒數
     */
    private int getMilliseconds(Date date) {
        SimpleDateFormat df = new SimpleDateFormat("SSS");
        return Integer.valueOf(df.format(date));
    }
 
    public static void main(String[] args) throws InterruptedException {
        OverflowController oc = new OverflowController(50);
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
        for (int i = 0; i <= 100; i++) {
            if (oc.isOverflow(1)) {
                System.out.println(i + "-isOverflow-" + df.format(new Date()));
            } else {
                System.out.println(i + "-sendOk-" + df.format(new Date()));
            }
 
            Thread.sleep(10);
        }
    }
}


超流控后的延遲處理,由于java中沒有.net的“延遲委托”一說:

復制代碼代碼如下:
ThreadPool.RegisterWaitForSingleObject(
 WaitHandle waitObject,
      WaitOrTimerCallback callBack,
      Object state,
     int millisecondsTimeOutInterval,
     bool executeOnlyOnce
)

 

Java下需實現一個簡單的延遲隊列:

 

復制代碼代碼如下:
import java.util.concurrent.Delayed;
import java.util.concurrent.TimeUnit;
 
public class DelayEntry implements Delayed {
 
    private int count;
    private long dequeuedTimeMillis; // 出隊列時間
 
    public int getCount() {
        return count;
    }
 
    public void setCount(int count) {
        this.count = count;
    }
 
    public long getDequeuedTimeMillis() {
        return dequeuedTimeMillis;
    }
 
    public DelayEntry(long delayMillis) {
        dequeuedTimeMillis = System.currentTimeMillis() + delayMillis;
    }
 
    @Override
    public int compareTo(Delayed o) {
        DelayEntry de = (DelayEntry) o;
        long timeout = dequeuedTimeMillis - de.dequeuedTimeMillis;
        return timeout > 0 ? 1 : timeout < 0 ? -1 : 0;
    }
 
    @Override
    public long getDelay(TimeUnit unit) {
        return dequeuedTimeMillis - System.currentTimeMillis();
    }
}


 

復制代碼代碼如下:
import java.util.concurrent.DelayQueue;
 
public class DelayService {
 
    public void run() {
        DelayQueue<DelayEntry> queue = new DelayQueue<DelayEntry>();
        DelayConsumer delayConsumer = new DelayConsumer(queue);
        delayConsumer.start();
 
        for (int i = 0; i < 100; i++) {
            DelayEntry de = new DelayEntry(5000);
            de.setCount(i);
            System.out.println(System.currentTimeMillis() + "--------" + de.getCount());
            queue.add(de);
        }
    }
 
    class DelayConsumer extends Thread {
        DelayQueue<DelayEntry> queue;
        public DelayConsumer(DelayQueue<DelayEntry> queue) {
            this.queue = queue;
        }
 
        public void run() {
            while (true) {
                try {
                    DelayEntry de = queue.take();
                    System.out.println("queue size=" + queue.size());
                    System.out.println(de.getCount());
                    System.out.println(System.currentTimeMillis());
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }
 
    public static void main(String[] args) {
        DelayService ds = new DelayService();
        ds.run();
    }
}

 

希望本文所述對大家的Java程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品国产中文字幕在线视频 | 久久国产乱子伦精品免费不卡 | 精品福利视频一区二区三区 | 国产日韩片 | 成人伊人青草久久综合网破解版 | 国产精品一区二区不卡的视频 | 闺蜜的样子小说安沁在线阅读 | 日韩视频在线观看中字 | 成年美女黄网站色视频大全免费 | 国产福利不卡视频 | 国产精品免费精品自在线观看 | 国产精品综合在线 | 欧美三级小视频 | 欧美一区二区三区成人看不卡 | 涩涩屋视频在线观看 | 成人免费视频一区二区三区 | 大jjjj免费看视频 | 9丨精品国产高清自在线看 9久热这里只有精品免费 | 美女秘密网站 | 丁香六月色婷婷综合网 | 亚洲成人影院在线 | 国产成人精品在线观看 | 欧美日韩一区二区三区在线播放 | 亚洲精品短视频 | 美女脱了内裤打开腿让你桶爽 | 鸥美毛片 | 99r在线观看| 双性肉文h | 亚洲视频免费在线看 | 国产成人一区二区三区 | 2021年国内自拍 | 亚洲精品午夜久久aaa级久久久 | 男人天堂a | www四虎影视 | 欧美日韩国产一区二区三区在线观看 | 紧身裙女教师波多野结衣 | 亚洲福利区 | 日韩无砖专区2020在线 | 91影视在线看免费观看 | 无遮掩60分钟从头啪到尾 | 日本免费全黄一级裸片视频 |