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

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

?? kelips.h

?? 比較權威的p2p仿真軟件
?? H
字號:
#ifndef __KELIPS_H#define __KELIPS_H// To Do:// OOPS short gossip intervals don't work right since gossip() blocks// there is something wrong with proximity routing, not fast enuf// log timeouts' contribution to rtt// need to parameterize number of nodes to ping per gossip round// Differences from Kelips as described in IPTPS 2003 paper:// I look up IDs, not files.// When/how do you learn RTT to a new node? So you know whether to//   keep it in your contacts list.// How often does a node generate a new heartbeat value?// When does a node send Info for itself? random? every gossip?// For how many rounds do they gossip a new item? (1 seems to work best)// Do existing items with new heartbeats count as new for gossip?// How big are the rations mentions in 2.1? In the eval.//   For group vs contact, and also new vs old.// Pull at join and then all push often leaves isolated nodes,//   since maybe nobody pushes to me. So what happens at join?// ***// What heartbeat timeout values?// The contacts tend to time out a lot...// Replacing contacts with newer heartbeat helps convergence a lot.//   As well as reducing contact timeout dramatically.// Are lookups iterative or recursive? Who controls various retries?// To do:// why does one-hop (k=1) w/ n=1024 suck so much?//   should be fabulous if you gossip enough!// gossip to nearby nodes preferentially?// hmm, we get a LOT of lookup failures in kx.pl runs, like 1/2 of lookups//   any way to make it more persistent?// why doesn't 1024 get down to 1 RTT?//   not moving info fast enough?// examine effect of each paramter individually// maybe try parameters that move more info?// is there an explicit "dead" flag on gossip entries?// Does it stabilize after the expected number of rounds?// Gossip w/o favoring new nodes (nnodes: avg median)://   100: 10 10//   400: 27 27// With gossiping new nodes first for 1 round://   100: 10 11//   400: 25 29// Replacing contacts with newer heartbeat, _item_rounds = 1://   100:  6  5//   400: 13 14// Oy, _item_rounds=0 beats this by a lot.#include "p2psim/p2protocol.h"#include "consistenthash.h"#include "p2psim/p2psim.h"#include "p2psim/condvar.h"#include "p2psim/network.h"#include <map>#include <vector>#include <set>#ifdef HAVE_LIBGBextern "C" {  #include "gb_graph.h"   #include <gb_dijk.h>}#endifclass Kelips : public P2Protocol {public:  typedef u_int ID;  struct lookup_args{    ID key;    Time start;    u_int retrytimes;    vector<IPAddress> history;    Time total_to;    u_int num_to;  };  struct lookup1_args{    ID key;    IPAddress dst_ip;  };  Kelips(IPAddress i, Args a);  virtual ~Kelips();  string proto_name() { return "Kelips"; }  // Functions callable from events file.  virtual void join(Args*);  virtual void leave(Args*);  virtual void crash(Args*);  virtual void lookup(Args*);  virtual void insert(Args*);  virtual void nodeevent (Args *) {};  void lookup_internal(lookup_args *a);  void add_edge(int *matrix, int sz); private:  // typedef ConsistentHash::CHID ID;  // Parameters, with defaults from Kelips paper.  int _round_interval;    // (2000) inter-gossip interval.  u_int _group_targets;   // (3) gossip to X targets in group.  u_int _contact_targets; // (3) gossip to X contacts.  u_int _group_ration;    // (4) group items per gossip packet.  u_int _contact_ration;  // (2) contact items per gossip packet.  int _n_contacts;        // (2) contacts to remember per foreign group.  int _item_rounds;       // (1???) how many times to gossip a new item.  Time _max_lookup_time;  u_int _purge_time;      // period the purge timer is run  u_int _track_conncomp_timer;   u_int _to_multiplier; //a retransmit timer  u_int _to_cheat;    int _timeout;           // (25000???) milliseconds to group item timeout.  // hearbeat timeouts. XXX not specified in paper.  /*  static const int _group_timeout = 25000;  static const int _contact_timeout = 50000;  */  int _k; // number of affinity groups, should be sqrt(n)  bool _started; // are our timers ticking?  bool _live;    // are we joined but not crashed?  // global statistics  static double _rpc_bytes; // total traffic  static double _good_latency; // successful lookups  static double _good_hops;  static int _good_lookups;  static int _ok_failures;  static int _bad_failures;  // Information about one other node.  class Info {  public:    IPAddress _ip;    Time _heartbeat; // when _ip last spoke to anyone.    int _rounds;     // how many rounds to send for.    int _rtt;        // measured by us, -1 if not valid    Info(IPAddress ip, Time hb) {       _ip = ip; _heartbeat = hb; _rounds = 0; _rtt = -1;    }    Info() { _ip = 0; _heartbeat = 0; _rounds = 0; _rtt = -1; }    int age() const { return now() - _heartbeat; }  };  // Set of nodes that this node knows about.  // This is the paper's Affinity Group View and Contacts.  map<IPAddress, Info *> _info;  void gotinfo(Info i, int rtt);  ID ip2id(IPAddress xip) {    return xip;    // return ConsistentHash::ip2chid(xip);  }  int id2group(ID id) { return(id % _k); }  int ip2group(IPAddress xip) { return(id2group(ip2id(xip))); }  ID id() { return ip2id(ip()); }  int group() { return ip2group(ip()); }  void gossip(void *);  void handle_gossip(vector<Info> *, void *);  void purge(void *);  vector<IPAddress> all();  vector<IPAddress> grouplist(int g);  vector<IPAddress> notgrouplist(int g);  void check(bool doprint);  void handle_join(IPAddress *caller, vector<Info> *ret);  vector<Info> gossip_msg(int g, u_int, u_int);  vector<IPAddress> randomize(vector<IPAddress> a);  vector<IPAddress> newold(vector<IPAddress> a, bool xnew);  void newold_msg(vector<Info> &msg, vector<IPAddress> l, u_int ration);  void handle_lookup_final(ID *kp, bool *done);  void handle_lookup1(lookup1_args *kp, IPAddress *res);  bool lookup1(lookup_args *a);  bool lookupvia(lookup_args *a, IPAddress via);  bool lookup2(lookup_args *a);  bool lookup_loop(lookup_args *a);  void handle_lookup2(ID *kp, IPAddress *res);  IPAddress find_by_id(ID key);  void init_state(const set<Node*>*);  bool stabilized(vector<ID> lid);  void rpcstat(bool ok, IPAddress dst, int latency, int nitems, uint type);  IPAddress victim(int g);  void handle_ping(void *, void *);  inline int contact_score(const Info &i);  IPAddress closest_contact(int g);  bool node_key_alive(ID key);  // RPC that records RTT.  template<class AT, class RT>    bool xRPC(IPAddress dst, int nitems, void (Kelips::* fn)(AT *, RT *),              AT *args, RT *ret, uint type=1, Time *total_to=NULL, uint *num_to=NULL){    Time t1 = now();    Time timeout = 1000;    if (_to_cheat) {      timeout = _to_multiplier * 2 * (Network::Instance()->gettopology())->latency(ip(),dst);    }else if ((_info.find(dst) == _info.end())       || (_info[dst]->_rtt == 9999) || 	(_info[dst]->_rtt == -1)) {      timeout = 1000; //1 second timeout    } else {      timeout = _to_multiplier * _info[dst]->_rtt;    }    bool ok = doRPC(dst, fn, args, ret, timeout);    rpcstat(ok, dst, now() - t1, nitems,type);    if (!ok) {      if (total_to) *total_to += timeout; //record the timeout incurred      if (num_to) *num_to += 1;    }    return ok;  };  friend class KelipsObserver;};#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲图片你懂的| 欧美国产欧美综合| 欧日韩精品视频| 色呦呦网站一区| 欧美伊人精品成人久久综合97| 99久久久精品免费观看国产蜜| 9i在线看片成人免费| 99久久免费国产| 91官网在线免费观看| 欧美高清视频www夜色资源网| 欧美三级视频在线播放| 欧美精品日韩精品| 精品国产乱码久久久久久图片| 久久精品欧美一区二区三区麻豆 | 97se亚洲国产综合在线| av在线不卡观看免费观看| 色美美综合视频| 91麻豆精品91久久久久同性| 精品福利一区二区三区免费视频| 337p粉嫩大胆噜噜噜噜噜91av| 国产亚洲欧美日韩俺去了| 亚洲另类中文字| 日韩精品1区2区3区| 国产在线精品不卡| 91麻豆.com| 日韩一区二区三区在线视频| 91久久精品一区二区二区| 日韩欧美区一区二| 国产精品久久三区| 日韩国产欧美在线观看| 成人午夜av影视| 8v天堂国产在线一区二区| 久久久久99精品一区| 一区二区三区电影在线播| 另类成人小视频在线| 99精品国产热久久91蜜凸| 欧美精品777| 中文字幕亚洲综合久久菠萝蜜| 日韩精品五月天| 成人黄页在线观看| 91精品一区二区三区久久久久久| 国产欧美一区二区精品忘忧草| 亚洲午夜精品网| 丰满白嫩尤物一区二区| 欧美一区二区精品| 亚洲少妇屁股交4| 国内精品国产成人| 欧美久久一二区| **性色生活片久久毛片| 狠狠久久亚洲欧美| 777xxx欧美| 一区二区不卡在线播放| 暴力调教一区二区三区| 精品成人在线观看| 亚洲国产欧美一区二区三区丁香婷 | 精品av综合导航| 亚洲自拍偷拍网站| av一二三不卡影片| 国产午夜一区二区三区| 卡一卡二国产精品| 欧美区视频在线观看| 亚洲免费观看高清完整版在线观看熊| 国产一区二区在线视频| 日韩亚洲电影在线| 日韩av网站在线观看| 欧美色视频一区| 亚洲麻豆国产自偷在线| 91丨九色丨黑人外教| 亚洲欧美综合另类在线卡通| 国产成人av一区| 久久综合久久综合久久| 久久 天天综合| 欧美大片一区二区三区| 久久超碰97人人做人人爱| 日韩精品一区二区三区视频播放 | 欧美日韩午夜精品| 亚洲一区在线电影| 91国偷自产一区二区三区成为亚洲经典| 国产精品久久精品日日| 成人高清免费在线播放| 亚洲色图在线看| 在线精品视频免费播放| 亚洲电影视频在线| 欧美久久免费观看| 久久97超碰国产精品超碰| 久久久久9999亚洲精品| 成人午夜在线播放| 亚洲免费av高清| 欧美精品xxxxbbbb| 久久精品国产99国产| 久久九九国产精品| 91视频观看视频| 日韩国产精品久久久| 久久久不卡网国产精品一区| 成人激情文学综合网| 亚洲h动漫在线| 2014亚洲片线观看视频免费| av亚洲精华国产精华| 性做久久久久久| 久久综合久久综合亚洲| 91丝袜美女网| 蜜臀精品久久久久久蜜臀| 亚洲国产精品ⅴa在线观看| 欧美亚洲自拍偷拍| 精品一区二区三区欧美| 亚洲图片另类小说| 欧美一区二区视频在线观看2020| 国产一区二区精品在线观看| 亚洲日本电影在线| 精品久久久久久久人人人人传媒 | 欧美一区二区三区四区视频| 国产露脸91国语对白| 亚洲一区在线观看视频| 久久久欧美精品sm网站| 欧美在线免费视屏| 国产成人免费在线观看| 视频一区二区国产| ...av二区三区久久精品| 精品久久久三级丝袜| 欧美性做爰猛烈叫床潮| 高清国产一区二区| 蜜臀av一区二区在线观看| 一区二区成人在线| 国产精品毛片久久久久久久 | 国产成人日日夜夜| 日本亚洲免费观看| 亚洲综合清纯丝袜自拍| 国产午夜精品久久久久久免费视| 欧美精品色综合| 色婷婷av一区二区三区gif| 国产一区二三区好的| 免费人成在线不卡| 亚洲一区二区欧美日韩| 亚洲欧美视频在线观看| 亚洲国产精华液网站w| 久久午夜色播影院免费高清| 51精品国自产在线| 欧美日韩中文精品| 色视频一区二区| 91麻豆精品视频| 99re这里都是精品| 成人午夜精品在线| 成人黄色一级视频| av电影天堂一区二区在线观看| 国产精品白丝jk白祙喷水网站| 久久99精品久久久久久国产越南| 午夜久久电影网| 石原莉奈在线亚洲三区| 日韩国产成人精品| 欧美aaaaa成人免费观看视频| 视频一区二区三区入口| 天天色综合天天| 蜜臀av一级做a爰片久久| 麻豆精品国产91久久久久久| 蜜臀av在线播放一区二区三区| 奇米精品一区二区三区四区 | 午夜精品影院在线观看| 亚洲国产精品精华液网站| 亚洲一区在线免费观看| 亚洲va欧美va天堂v国产综合| 亚洲高清中文字幕| 日韩精品91亚洲二区在线观看 | 亚洲综合999| 午夜精品久久久久久| 麻豆成人综合网| 国产综合色视频| 国产成人亚洲精品青草天美| 成人免费福利片| 日本精品一级二级| 欧美精品vⅰdeose4hd| 26uuu亚洲综合色欧美| 国产精品伦理在线| 亚洲福利一区二区三区| 久久成人免费电影| 成人激情动漫在线观看| 91国产免费看| 欧美tk丨vk视频| 国产精品国产三级国产aⅴ原创| 一区二区三区久久| 激情小说亚洲一区| 色老汉一区二区三区| 日韩欧美专区在线| 国产精品久久久久影院亚瑟| 亚洲一区二区三区中文字幕 | 777奇米四色成人影色区| 久久亚洲一级片| 亚洲欧美成aⅴ人在线观看| 免费欧美高清视频| 一本久久精品一区二区| 精品盗摄一区二区三区| 一区二区三区在线观看国产 | 91丨九色丨蝌蚪富婆spa| 91精品国产高清一区二区三区 | 在线免费观看一区| 欧美成人乱码一区二区三区| 亚洲精品免费在线观看| 狠狠色伊人亚洲综合成人| 欧美日韩国产片| 一色桃子久久精品亚洲| 国产一区二三区|