亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? stable.java

?? JGRoups源碼
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
// $Id: STABLE.java,v 1.46 2006/05/17 10:54:38 belaban Exp $package org.jgroups.protocols.pbcast;import org.jgroups.*;import org.jgroups.stack.Protocol;import org.jgroups.util.Streamable;import org.jgroups.util.TimeScheduler;import org.jgroups.util.Util;import java.io.*;import java.util.Iterator;import java.util.Map;import java.util.Properties;import java.util.Vector;/** * Computes the broadcast messages that are stable; i.e., have been received by all members. Sends * STABLE events up the stack when this is the case. This allows NAKACK to garbage collect messages that * have been seen by all members.<p> * Works as follows: periodically we mcast our highest seqnos (seen for each member) to the group. * A stability vector, which maintains the highest seqno for each member and initially contains no data, * is updated when such a message is received. The entry for a member P is computed set to * min(entry[P], digest[P]). When messages from all members have been received, a stability * message is mcast, which causes all members to send a STABLE event up the stack (triggering garbage collection * in the NAKACK layer).<p> * The stable task now terminates after max_num_gossips if no messages or view changes have been sent or received * in the meantime. It will resume when messages are received. This effectively suspends sending superfluous * STABLE messages in the face of no activity.<br/> * New: when <code>max_bytes</code> is exceeded (unless disabled by setting it to 0), * a STABLE task will be started (unless it is already running). * @author Bela Ban */public class STABLE extends Protocol {    Address             local_addr=null;    final Vector        mbrs=new Vector();    final Digest        digest=new Digest(10);        // keeps track of the highest seqnos from all members    final Digest        latest_local_digest=new Digest(10); // keeps track of the latest digests received from NAKACK    final Vector        heard_from=new Vector();      // keeps track of who we already heard from (STABLE_GOSSIP msgs)    /** Sends a STABLE gossip every 20 seconds on average. 0 disables gossipping of STABLE messages */    long                desired_avg_gossip=20000;    /** delay before we send STABILITY msg (give others a change to send first). This should be set to a very     * small number (> 0 !) if <code>max_bytes</code> is used */    long                stability_delay=6000;    private StabilitySendTask   stability_task=null;    final Object        stability_mutex=new Object();   // to synchronize on stability_task    private volatile StableTask  stable_task=null;               // bcasts periodic STABLE message (added to timer below)    final Object        stable_task_mutex=new Object(); // to sync on stable_task    TimeScheduler       timer=null;                     // to send periodic STABLE msgs (and STABILITY messages)    static final String name="STABLE";    /** Total amount of bytes from incoming messages (default = 0 = disabled). When exceeded, a STABLE     * message will be broadcast and <code>num_bytes_received</code> reset to 0 . If this is > 0, then ideally     * <code>stability_delay</code> should be set to a low number as well */    long                max_bytes=0;    /** The total number of bytes received from unicast and multicast messages */    long                num_bytes_received=0;    /** When true, don't take part in garbage collection protocol: neither send STABLE messages nor     * handle STABILITY messages */    boolean             suspended=false;    boolean             initialized=false;    private ResumeTask  resume_task=null;    final Object        resume_task_mutex=new Object();    /** Number of gossip messages */    int                 num_gossips=0;        private static final long MAX_SUSPEND_TIME=200000;    public String getName() {        return name;    }    public long getDesiredAverageGossip() {        return desired_avg_gossip;    }    public void setDesiredAverageGossip(long gossip_interval) {        desired_avg_gossip=gossip_interval;    }    public long getMaxBytes() {        return max_bytes;    }    public void setMaxBytes(long max_bytes) {        this.max_bytes=max_bytes;    }    public int getNumberOfGossipMessages() {return num_gossips;}    public void resetStats() {        super.resetStats();        num_gossips=0;    }    public Vector requiredDownServices() {        Vector retval=new Vector();        retval.addElement(new Integer(Event.GET_DIGEST_STABLE));  // NAKACK layer        return retval;    }    public boolean setProperties(Properties props) {        String str;        super.setProperties(props);        str=props.getProperty("digest_timeout");        if(str != null) {            props.remove("digest_timeout");            log.error("digest_timeout has been deprecated; it will be ignored");        }        str=props.getProperty("desired_avg_gossip");        if(str != null) {            desired_avg_gossip=Long.parseLong(str);            props.remove("desired_avg_gossip");        }        str=props.getProperty("stability_delay");        if(str != null) {            stability_delay=Long.parseLong(str);            props.remove("stability_delay");        }        str=props.getProperty("max_gossip_runs");        if(str != null) {            props.remove("max_gossip_runs");            log.error("max_gossip_runs has been deprecated and will be ignored");        }        str=props.getProperty("max_bytes");        if(str != null) {            max_bytes=Long.parseLong(str);            props.remove("max_bytes");        }        str=props.getProperty("max_suspend_time");        if(str != null) {            log.error("max_suspend_time is not supported any longer; please remove it (ignoring it)");            props.remove("max_suspend_time");        }        if(props.size() > 0) {            log.error("these properties are not recognized: " + props);                        return false;        }        return true;    }    private void suspend(long timeout) {        if(!suspended) {            suspended=true;            if(log.isDebugEnabled())                log.debug("suspending message garbage collection");        }        startResumeTask(timeout); // will not start task if already running    }    private void resume() {        resetDigest(mbrs); // start from scratch        suspended=false;        if(log.isDebugEnabled())            log.debug("resuming message garbage collection");        stopResumeTask();    }    public void start() throws Exception {        if(stack != null && stack.timer != null)            timer=stack.timer;        else            throw new Exception("timer cannot be retrieved from protocol stack");        if(desired_avg_gossip > 0)            startStableTask();    }    public void stop() {        stopStableTask();        clearDigest();    }    public void up(Event evt) {        Message msg;        StableHeader hdr;        int type=evt.getType();        switch(type) {        case Event.MSG:            msg=(Message)evt.getArg();            // only if message counting is enabled, and only for multicast messages            // fixes http://jira.jboss.com/jira/browse/JGRP-233            if(max_bytes > 0) {                Address dest=msg.getDest();                if(dest == null || dest.isMulticastAddress()) {                    num_bytes_received+=(long)Math.max(msg.getLength(), 24);                    if(num_bytes_received >= max_bytes) {                        if(trace) {                            log.trace(new StringBuffer("max_bytes has been reached (").append(max_bytes).                                    append(", bytes received=").append(num_bytes_received).append("): triggers stable msg"));                        }                        num_bytes_received=0;                        // asks the NAKACK protocol for the current digest, reply event is GET_DIGEST_STABLE_OK (arg=digest)                        passDown(new Event(Event.GET_DIGEST_STABLE));                    }                }            }            hdr=(StableHeader)msg.removeHeader(name);            if(hdr == null)                break;            switch(hdr.type) {            case StableHeader.STABLE_GOSSIP:                handleStableMessage(msg.getSrc(), hdr.stableDigest);                break;            case StableHeader.STABILITY:                handleStabilityMessage(hdr.stableDigest, msg.getSrc());                break;            default:                if(log.isErrorEnabled()) log.error("StableHeader type " + hdr.type + " not known");            }            return;  // don't pass STABLE or STABILITY messages up the stack        case Event.GET_DIGEST_STABLE_OK:            Digest d=(Digest)evt.getArg();            synchronized(latest_local_digest) {                latest_local_digest.replace(d);            }            if(trace)                log.trace("setting latest_local_digest from NAKACK: " + d.printHighSeqnos());            sendStableMessage(d);            break;        case Event.VIEW_CHANGE:            View view=(View)evt.getArg();            handleViewChange(view);            break;        case Event.SET_LOCAL_ADDRESS:            local_addr=(Address)evt.getArg();            break;        }        passUp(evt);    }    public void down(Event evt) {        switch(evt.getType()) {        case Event.VIEW_CHANGE:            View v=(View)evt.getArg();            handleViewChange(v);            break;        case Event.SUSPEND_STABLE:            long timeout=0;            Object t=evt.getArg();            if(t != null && t instanceof Long)                timeout=((Long)t).longValue();            suspend(timeout);            break;        case Event.RESUME_STABLE:            resume();            break;        }        passDown(evt);    }    public void runMessageGarbageCollection() {        Digest copy;        synchronized(digest) {            copy=digest.copy();        }        sendStableMessage(copy);    }    /* --------------------------------------- Private Methods ---------------------------------------- */    private void handleViewChange(View v) {        Vector tmp=v.getMembers();        mbrs.clear();        mbrs.addAll(tmp);        adjustSenders(digest, tmp);        adjustSenders(latest_local_digest, tmp);        resetDigest(tmp);        if(!initialized)            initialized=true;    }    /** Digest and members are guaranteed to be non-null */    private static void adjustSenders(Digest d, Vector members) {        synchronized(d) {            // 1. remove all members from digest who are not in the view            Iterator it=d.senders.keySet().iterator();            Address mbr;            while(it.hasNext()) {                mbr=(Address)it.next();                if(!members.contains(mbr))                    it.remove();            }            // 2. add members to digest which are in the new view but not in the digest            for(int i=0; i < members.size(); i++) {                mbr=(Address)members.get(i);                if(!d.contains(mbr))                    d.add(mbr, -1, -1);            }        }    }    private void clearDigest() {        synchronized(digest) {            digest.clear();        }    }    /** Update my own digest from a digest received by somebody else. Returns whether the update was successful.     *  Needs to be called with a lock on digest */    private boolean updateLocalDigest(Digest d, Address sender) {        if(d == null || d.size() == 0)            return false;        if(!initialized) {            if(trace)                log.trace("STABLE message will not be handled as I'm not yet initialized");            return false;        }        if(!digest.sameSenders(d)) {            if(trace)                log.trace(new StringBuffer("received a digest ").append(d.printHighSeqnos()).append(" from ").                          append(sender).append(" which has different members than mine (").                          append(digest.printHighSeqnos()).append("), discarding it and resetting heard_from list"));            // to avoid sending incorrect stability/stable msgs, we simply reset our heard_from list, see DESIGN            resetDigest(mbrs);            return false;        }        StringBuffer sb=null;        if(trace)            sb=new StringBuffer("my [").append(local_addr).append("] digest before: ").append(digest).                    append("\ndigest from ").append(sender).append(": ").append(d);        Address mbr;        long highest_seqno, my_highest_seqno, new_highest_seqno;        long highest_seen_seqno, my_highest_seen_seqno, new_highest_seen_seqno;        Map.Entry entry;        org.jgroups.protocols.pbcast.Digest.Entry val;        for(Iterator it=d.senders.entrySet().iterator(); it.hasNext();) {            entry=(Map.Entry)it.next();            mbr=(Address)entry.getKey();            val=(org.jgroups.protocols.pbcast.Digest.Entry)entry.getValue();            highest_seqno=val.high_seqno;            highest_seen_seqno=val.high_seqno_seen;            // compute the minimum of the highest seqnos deliverable (for garbage collection)            my_highest_seqno=digest.highSeqnoAt(mbr);            // compute the maximum of the highest seqnos seen (for retransmission of last missing message)            my_highest_seen_seqno=digest.highSeqnoSeenAt(mbr);            new_highest_seqno=Math.min(my_highest_seqno, highest_seqno);            new_highest_seen_seqno=Math.max(my_highest_seen_seqno, highest_seen_seqno);            digest.setHighestDeliveredAndSeenSeqnos(mbr, new_highest_seqno, new_highest_seen_seqno);        }        if(trace) {            sb.append("\nmy [").append(local_addr).append("] digest after: ").append(digest).append("\n");            log.trace(sb);        }        return true;    }    private void resetDigest(Vector new_members) {        if(new_members == null || new_members.size() == 0)            return;        synchronized(heard_from) {            heard_from.clear();            heard_from.addAll(new_members);        }        Digest copy_of_latest;        synchronized(latest_local_digest) {            copy_of_latest=latest_local_digest.copy();        }        synchronized(digest) {            digest.replace(copy_of_latest);            if(trace)                log.trace("resetting digest from NAKACK: " + copy_of_latest.printHighSeqnos());        }    }    /**     * Removes mbr from heard_from and returns true if this was the last member, otherwise false.     * Resets the heard_from list (populates with membership)     * @param mbr     */    private boolean removeFromHeardFromList(Address mbr) {        synchronized(heard_from) {            heard_from.remove(mbr);            if(heard_from.size() == 0) {                resetDigest(this.mbrs);                return true;            }        }        return false;    }    void startStableTask() {        // Here, double-checked locking works: we don't want to synchronize if the task already runs (which is the case        // 99% of the time). If stable_task gets nulled after the condition check, we return anyways, but just miss        // 1 cycle: on the next message or view, we will start the task        if(stable_task != null)            return;        synchronized(stable_task_mutex) {            if(stable_task != null && stable_task.running()) {                return;  // already running            }            stable_task=new StableTask();            timer.add(stable_task, true); // fixed-rate scheduling        }        if(trace)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久久三级丝袜| 韩国一区二区三区| 色一区在线观看| 亚洲日本欧美天堂| 欧洲日韩一区二区三区| 亚洲成人第一页| 91精品蜜臀在线一区尤物| 久久99蜜桃精品| 国产日韩欧美综合一区| 99久久精品国产观看| 亚洲午夜电影在线观看| 欧美va在线播放| 国产精品一区二区三区99| 日韩伦理电影网| 欧美日韩成人综合| 国产九色sp调教91| 一区二区三区欧美视频| 日韩一区二区在线免费观看| 国产成人在线观看| 一区二区三国产精华液| 精品欧美黑人一区二区三区| 国产suv精品一区二区883| 亚洲综合男人的天堂| 欧美成人综合网站| 99re这里都是精品| 久久综合综合久久综合| 国产精品欧美综合在线| 欧美精品欧美精品系列| 国产精品综合网| 性久久久久久久久| 久久精品人人做人人综合| 在线视频你懂得一区二区三区| 免费成人在线观看| 亚洲精品国产精华液| 久久九九99视频| 欧美日韩性生活| 成人福利在线看| 日韩av电影一区| 亚洲欧美另类久久久精品| 欧美变态凌虐bdsm| 欧美吻胸吃奶大尺度电影 | 日本福利一区二区| 国模大尺度一区二区三区| 亚洲国产日产av| 国产精品久久久久桃色tv| 日韩欧美国产小视频| 欧美伊人精品成人久久综合97| 国产99久久久国产精品潘金| 青青青爽久久午夜综合久久午夜| 亚洲精品日韩一| 国产精品色一区二区三区| 26uuu精品一区二区在线观看| 欧美日韩午夜精品| 91免费国产在线观看| 成人美女视频在线观看| 精品一区二区免费在线观看| 亚洲宅男天堂在线观看无病毒| 日本一区二区三区dvd视频在线| 欧美一区二区视频在线观看2020| 91日韩一区二区三区| 高清国产午夜精品久久久久久| 日本va欧美va精品| 首页综合国产亚洲丝袜| 亚洲高清不卡在线| 亚洲一区在线视频观看| 亚洲综合清纯丝袜自拍| 亚洲卡通动漫在线| 亚洲美女偷拍久久| 亚洲精品国产精品乱码不99 | 欧美主播一区二区三区| 91网站最新地址| 不卡av在线免费观看| 成人精品电影在线观看| 国产不卡免费视频| 成人一区在线观看| av综合在线播放| 91小视频免费看| 91麻豆国产香蕉久久精品| 99国产精品久久久久久久久久| 成人网页在线观看| eeuss影院一区二区三区| kk眼镜猥琐国模调教系列一区二区| 成人av电影在线| 97se亚洲国产综合在线| 色哟哟一区二区三区| 在线精品视频免费观看| 欧美三级中文字幕| 欧美精品久久99久久在免费线| 精品婷婷伊人一区三区三| 欧美情侣在线播放| 精品日韩成人av| 亚洲国产精品国自产拍av| 国产精品不卡一区| 一区二区三区四区乱视频| 亚洲第一福利一区| 久久精工是国产品牌吗| 国产成人午夜精品影院观看视频| 成人黄色电影在线| 欧美日韩一区 二区 三区 久久精品| 欧美日韩一区二区三区在线看| 538在线一区二区精品国产| 欧美精品一区二区三| 国产精品久久久久久久久果冻传媒 | 美女诱惑一区二区| 国产成人av电影免费在线观看| 一本久久a久久精品亚洲| 欧美妇女性影城| 国产婷婷精品av在线| 一区二区三区四区不卡在线 | 欧美日韩专区在线| 日韩欧美成人一区二区| 国产精品网站在线观看| 亚洲一二三区视频在线观看| 经典三级一区二区| 91丨porny丨户外露出| 欧美电影一区二区三区| 国产欧美中文在线| 亚洲成人激情综合网| 成人午夜私人影院| 欧美精品九九99久久| 欧美国产一区二区在线观看| 亚洲电影视频在线| www.亚洲在线| 欧美电视剧在线看免费| 怡红院av一区二区三区| 国产一区二区精品久久91| 欧美午夜精品免费| 国产精品久久久久久久第一福利| 蜜臀av一级做a爰片久久| 色综合咪咪久久| 国产欧美日韩视频一区二区| 三级亚洲高清视频| 91丨九色丨尤物| 久久久久久久久久美女| 日韩精品三区四区| 91麻豆产精品久久久久久| 久久欧美一区二区| 奇米影视在线99精品| 欧美少妇一区二区| 亚洲精品乱码久久久久久| 成人免费视频一区| 久久亚洲一级片| 麻豆成人av在线| 欧美日韩卡一卡二| 一区二区三区在线视频观看58| 国产风韵犹存在线视精品| 日韩免费视频一区| 日韩国产精品久久久久久亚洲| 91久久奴性调教| 综合分类小说区另类春色亚洲小说欧美| 久久精品国产精品青草| 91精品在线一区二区| 五月激情丁香一区二区三区| 日本黄色一区二区| 中文字幕一区二区三区四区| 国产凹凸在线观看一区二区| 精品国产成人在线影院| 免费一级欧美片在线观看| 欧美精品在线一区二区三区| 亚洲韩国一区二区三区| 在线观看亚洲成人| 亚洲一区二区三区四区五区中文| 色婷婷国产精品| 亚洲自拍偷拍网站| 欧美日韩国产免费一区二区 | 日韩理论在线观看| 91免费观看在线| 亚洲一区在线观看视频| 欧美日韩一区二区三区高清| 一区二区三区精品| 欧美精品tushy高清| 亚洲h精品动漫在线观看| 欧美日韩另类一区| 男男gaygay亚洲| 精品粉嫩超白一线天av| 狠狠色丁香久久婷婷综合丁香| 亚洲精品在线免费播放| 国产一区二区三区四| 国产日韩欧美a| 成人黄色在线网站| 亚洲精品视频免费观看| 精品1区2区3区| 精品一区二区三区的国产在线播放 | 91在线porny国产在线看| 亚洲欧美日韩国产综合在线| 欧美伊人久久久久久午夜久久久久| 亚洲小说春色综合另类电影| 欧美一区二区视频免费观看| 国产一区二区成人久久免费影院| 国产精品久久久久久久久免费桃花| 色综合中文字幕国产 | 在线观看日韩国产| 日本欧美韩国一区三区| 久久蜜桃一区二区| 色综合天天综合色综合av| 亚洲国产精品久久久久秋霞影院 | 亚洲精品亚洲人成人网在线播放| 欧美日韩高清在线播放| 精品影院一区二区久久久| 国产精品久久久久一区二区三区 |