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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 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)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产盗摄视频一区二区三区| 国产精品视频免费| 日韩高清欧美激情| 欧美日韩国产欧美日美国产精品| 亚洲国产精品麻豆| 欧美一区二区三区免费在线看| 日韩国产欧美一区二区三区| 精品人在线二区三区| 国产高清视频一区| 亚洲欧洲无码一区二区三区| 99在线精品视频| 五月天精品一区二区三区| 精品少妇一区二区三区视频免付费| 国产在线日韩欧美| 国产精品福利电影一区二区三区四区| 91丨porny丨中文| 亚洲gay无套男同| 精品美女一区二区三区| 成人av资源站| 天天亚洲美女在线视频| 久久久精品综合| 色94色欧美sute亚洲线路一久| 婷婷国产v国产偷v亚洲高清| 精品999在线播放| 91视频国产资源| 麻豆免费看一区二区三区| 国产精品色一区二区三区| 欧美三级视频在线观看| 国产精品91xxx| 亚洲成a人v欧美综合天堂下载| 久久精品视频在线看| 欧美色综合网站| 国产精品亚洲成人| 亚洲一区二区影院| 久久网站热最新地址| 91国偷自产一区二区三区成为亚洲经典 | 人人爽香蕉精品| 国产清纯白嫩初高生在线观看91 | 欧美在线制服丝袜| 国产一区二区三区| 午夜国产精品影院在线观看| 国产日韩欧美综合在线| 欧美久久久久久久久中文字幕| 成人激情小说乱人伦| 久久精品国产成人一区二区三区 | 欧美日韩高清影院| 波多野结衣亚洲一区| 久久99国产乱子伦精品免费| 亚洲乱码中文字幕综合| 久久久久久久精| 91精品国产色综合久久不卡电影| 99久久99久久精品国产片果冻 | 日本中文字幕一区| 亚洲日本丝袜连裤袜办公室| 久久精品免费在线观看| 欧美xxxxx牲另类人与| 欧美乱熟臀69xxxxxx| 一本色道亚洲精品aⅴ| 国产精品1区2区| 韩国女主播成人在线观看| 午夜激情综合网| 亚洲成人免费视| 亚洲永久精品国产| 亚洲乱码国产乱码精品精可以看| 国产精品情趣视频| 国产日产精品1区| 久久久久99精品国产片| 精品国产免费久久| 日韩欧美一区在线观看| 538在线一区二区精品国产| 在线观看av不卡| 欧美性大战xxxxx久久久| 在线免费视频一区二区| 99久久精品久久久久久清纯| jlzzjlzz亚洲日本少妇| 成人高清免费观看| 成人免费高清视频在线观看| 国产91精品免费| 国产91在线|亚洲| 成人蜜臀av电影| 波多野结衣中文字幕一区二区三区 | 91超碰这里只有精品国产| 欧美狂野另类xxxxoooo| 欧美精品丝袜中出| 正在播放亚洲一区| 日韩亚洲欧美成人一区| 久久亚洲一区二区三区四区| 久久婷婷成人综合色| 欧美精品一区二区三| 久久久久88色偷偷免费| 国产精品乱码人人做人人爱| 国产精品国产三级国产aⅴ无密码| 中文字幕第一页久久| 亚洲欧美一区二区三区极速播放 | 欧美精品一二三四| 日韩欧美一二区| 国产日本一区二区| 一区二区三区在线免费观看| 丝袜亚洲另类丝袜在线| 久久狠狠亚洲综合| 99精品一区二区三区| 欧美麻豆精品久久久久久| 精品精品国产高清一毛片一天堂| 国产欧美日韩麻豆91| 一区二区三区中文免费| 蜜桃av噜噜一区二区三区小说| 国产一区在线不卡| 一本到不卡免费一区二区| 欧美精三区欧美精三区| 久久一留热品黄| 一区二区三区av电影| 麻豆视频一区二区| 972aa.com艺术欧美| 日韩一级视频免费观看在线| 国产精品乱子久久久久| 亚洲成年人网站在线观看| 国产福利91精品一区二区三区| 色婷婷综合久久久| 精品电影一区二区| 亚洲小少妇裸体bbw| 国产一区二区导航在线播放| 在线亚洲欧美专区二区| 久久久久免费观看| 亚洲不卡一区二区三区| 国产98色在线|日韩| 91精品欧美一区二区三区综合在 | 色婷婷av一区二区三区大白胸| 日韩欧美区一区二| 一区二区三区国产| 大胆欧美人体老妇| 精品久久久三级丝袜| 亚洲资源中文字幕| 大陆成人av片| 精品国产乱码久久久久久牛牛 | 亚洲精品成人在线| 国产一区视频在线看| 欧美日韩精品欧美日韩精品 | 首页综合国产亚洲丝袜| 成人h动漫精品一区二区| 日韩精品综合一本久道在线视频| 亚洲日韩欧美一区二区在线| 国产福利一区在线观看| 6080日韩午夜伦伦午夜伦| 亚洲女性喷水在线观看一区| 国产精品一级在线| 精品精品国产高清a毛片牛牛 | 精品动漫一区二区三区在线观看| 亚洲第一搞黄网站| 色哟哟一区二区在线观看| 国产精品久久久久久久浪潮网站 | 理论片日本一区| 欧美日本视频在线| 夜夜操天天操亚洲| 91麻豆精东视频| 国产精品久久久久久久蜜臀| 成人综合在线观看| 日本一区二区三区国色天香 | 99天天综合性| 一区在线观看视频| 成人av影院在线| 欧美国产亚洲另类动漫| 国产成人综合自拍| 久久一夜天堂av一区二区三区| 极品销魂美女一区二区三区| 欧美大黄免费观看| 国内成人免费视频| 久久精品欧美日韩精品| 国产成人av一区二区三区在线| 2024国产精品视频| 国产盗摄女厕一区二区三区| 久久久99久久精品欧美| 国产成a人无v码亚洲福利| 久久久久久久精| 丁香亚洲综合激情啪啪综合| 国产精品女主播av| 色综合久久99| 丝袜美腿亚洲一区二区图片| 91精品国产综合久久香蕉麻豆| 天堂一区二区在线免费观看| 日韩一区二区三区视频在线观看| 老司机午夜精品99久久| 26uuu精品一区二区在线观看| 国产成人免费在线观看| 中文字幕视频一区| 欧美午夜不卡视频| 蜜臀久久99精品久久久画质超高清| 日韩精品专区在线影院观看| 国产大片一区二区| 一区二区三区四区精品在线视频| 欧美调教femdomvk| 奇米四色…亚洲| 国产欧美日韩三级| 在线观看视频91| 精品系列免费在线观看| 国产精品久久久久天堂| 欧美日韩亚洲综合在线 | 亚洲成av人片一区二区| 日韩精品一区在线| 91农村精品一区二区在线| 日韩中文字幕91|