Example #1
0
FeedContentPtr FeedMemcContentI::GetFeed(Ice::Long id, const Ice::Current&) {
  // for UserProfileClient test only
  vector<Ice::Long> feedids;
  feedids.push_back(8373921129);
  FeedContentDict dict = FeedMemcClient::instance().GetFeedDict(feedids);
  FeedContentPtr content;
  content = dict[8373921129];
  content->data->xml = "<f v=\"1.0\" type=\"blogPublish\"><time>1300185966866</time><type>601</type><from><id>257876975</id><name>远非</name><tinyimg>0/0/men_tiny.gif</tinyimg></from><blog><id>716684593</id><title>ooxxxwwoo</title><digest>&amp;#23002;&amp;#23452;&amp;#19996;&amp;#20998;&amp;#20139;&amp;#26446;&amp;#22025;&amp;#27427;&amp;#30340;&amp;#26085;&amp;#24535;&amp;#36716;&amp;#65306;&amp;#20854;&amp;#23454;&amp;#22823;&amp;#23478;&amp;#37117;&amp;#34987;&amp;#26085;&amp;#26412;&amp;#22320;&amp;#38663;&amp;#21560;&amp;#24341;&amp;#20102;&amp;#30524;&amp;#29699; &amp;#30495;&amp;#27491;&amp;#26368;&amp;#21361;&amp;#38505;&amp;#30340;&amp;#26159;&amp;#21152;&amp;#24030; &amp;#65288;&amp;#20197;&amp;#19979;&amp;#20026;&amp;#36716;&amp;#36733;&amp;#65289;&amp;#26085;&amp;#26412;&amp;#36825;&amp;#27425;&amp;#29378;&amp;#26292;&amp;#30340;&amp;#22320;&amp;#38663;&amp;#30495;&amp;#30340;&amp;#21560;&amp;#24341;&amp;#20102;&amp;#22823;&amp;#23478;&amp;#30340;&amp;#30524;&amp;#29699;&amp;#65292;&amp;#25105;&amp;#22269;&amp;#30005;&amp;#35270;&amp;#21488;&amp;#26356;&amp;#26159;&amp;#36830;&amp;#31687;&amp;#32047;&amp;#29261;&amp;#30340;&amp;#25253;&amp;#36947;&amp;#20197;&amp;#26399;&amp;#36716;&amp;#31227;&amp;#22823;&amp;#23478;&amp;#23545;&amp;#22269;&amp;#20869;&amp;#29616;&amp;#29366;&amp;#30340;&amp;#19981;&amp;#28385;&amp;#12290;&amp;#20854;&amp;#23454;&amp;#65292;&amp;#22823;&amp;#23478;&amp;#38590;&amp;#36947;&amp;#24536;&amp;#35760;&amp;#20102;&amp;#32654;&amp;#22269;&amp;#21152;&amp;#24030;&amp;#37027;&amp;#22855;&amp;#24618;&amp;#27515;&amp;#20129;&amp;#30340;500&amp;#19975;&amp;#26465;&amp;#40060;&amp;#20102;&amp;#21527;&amp;#65311;&amp;#25105;&amp;#35748;&amp;#20026;&amp;#19981;&amp;#36229;&amp;#36807;&amp;#19968;&amp;#20010;&amp;#26376;&amp;#65292;&amp;#21152;&amp;#24030;&amp;#23558;&amp;#21457;&amp;#29983;&amp;#24046;&amp;#19981;&amp;#22810;9&amp;#32423;&amp;#30340;&amp;#22320;&amp;#38663;&amp;#12290;&amp;#20026;&amp;#37027;&amp;#20123;&amp;#21363;&amp;#23558;&amp;#32633;&amp;#38590;&amp;#30340;&amp;#20154;&amp;#31048;&amp;#31095;&amp;#21543;&amp;#65281;&amp;#65281;&amp;#65281;&amp;#65281; &amp;#27425;&amp;#22768;&amp;#27874;&amp;#12290;&amp;#12290;&amp;#12290;&amp;#36807;&amp;#24378;&amp;#30340;&amp;#27425;&amp;#22768;&amp;#27874;...</digest><url>http://blog.renren.com/GetEntry.do?id=716684593&amp;owner=257876975</url></blog></f>"; 
  content->reply->oldReply = "<f><reply><id>1692426042</id><type>0</type><time>2011-03-15 18:51</time><body>&quot;test1&quot;</body><im><body>test1</body></im><from><id>238489851</id><name>袁飞</name><tinyimg>http://hdn.xnimg.cn/photos/hdn221/20110220/1735/tiny_2kcu_195010p019116.jpg</tinyimg><icon></icon></from></reply></f>";
  content->reply->newReply = "<f><reply><id>1692426042</id><type>0</type><time>2011-03-15 18:51</time><body>&quot;test2&quot;</body><im><body>test2</body></im><from><id>238489851</id><name>袁飞</name><tinyimg>http://hdn.xnimg.cn/photos/hdn221/20110220/1735/tiny_2kcu_195010p019116.jpg</tinyimg><icon></icon></from></reply></f>";
  FeedMemcClient::instance().SetFeed(content);
  return NULL; 
  UserProfile profile;
  MCE_INFO("get profile : " << id );
  bool b = UserProfileClient::instance().Get(id, &profile);
  if (b) {
  MCE_INFO("profile fields : " 
      << " id " << profile.id()
      << " stage " << profile.stage()
      << " gender " << profile.gender()
      << " age " << profile.age()
      << " school " << profile.school()
      << " major " << profile.major()
      << " grade " << profile.grade()
      << " home_area " << profile.home_area() << "@" << profile.home_area().size()
      << " current_area " << profile.current_area() << "@" << profile.current_area().size()
      << " ip " << profile.ip()
      << " ip_area " << profile.ip_area() << "@" << profile.ip_area().size() );
  } else {
    MCE_INFO("profile not found. id=" << id); 
  }

  return FeedMemcClient::instance().GetFeed(id);
};
Example #2
0
void LogHelper::CookieEmptyCheck(UserProfile& upf){
  int userid = upf.id();
  if(!upf.id()){
    upf.set_id(888);
  }
  if(upf.age() > 100 || upf.age() < 15){
    upf.set_age(20 + AdMatchManagerI::instance().ServerIndex());
  }
  if(upf.ip_area().empty() || "0000000000000000" == upf.ip_area()){
    upf.set_ip_area("0086110000000000");
  }
  if(!upf.stage()){
    upf.set_stage(4);
  }
  if(!upf.ip()){
    upf.set_ip(975044608);
  }
  if(upf.current_area().empty()){
    upf.set_current_area("0086110000000000");
  }


  ///////////////////////////
  //if(!upf.home_area().empty()) {
  //  upf.set_ip_area(upf.home_area()); //for test only
  //}
  ///////////////////////////
}
Example #3
0
void CookieEmptyCheck(UserProfile& upf) {
  if (!upf.id()) {
    upf.set_id(8);
  }
  if (upf.ip_area().empty() || "0000000000000000" == upf.ip_area()) {
    upf.set_ip_area("0086110000000000"); // 北京
  }
  if (!upf.stage()) {
    upf.set_stage(4);
  }
  if (!upf.ip()) {
    upf.set_ip(975044608); // 北京的一个随机IP
  }
  if (upf.current_area().empty()) {
    upf.set_current_area("0086110000000000"); // 北京
  }
}
Example #4
0
FeedContentPtr MemcFeedTestI::GetFeed(Ice::Long id, const Ice::Current&) {
  // for UserProfileClient test only
  UserProfile profile;
  MCE_INFO("get profile : " << id );
  bool b = UserProfileClient::instance().Get(id, &profile);
  if (b) {
  MCE_INFO("profile fields : " 
      << " id " << profile.id()
      << " stage " << profile.stage()
      << " gender " << profile.gender()
      << " age " << profile.age()
      << " school " << profile.school()
      << " major " << profile.major()
      << " grade " << profile.grade()
      << " home_area " << profile.home_area() << "@" << profile.home_area().size()
      << " current_area " << profile.current_area() << "@" << profile.current_area().size()
      << " ip " << profile.ip()
      << " ip_area " << profile.ip_area() << "@" << profile.ip_area().size() );
  } else {
    MCE_INFO("profile not found. id=" << id); 
  }

  return FeedMemcClient::instance().GetFeed(id);
};
Example #5
0
void CookieEmptyCheck(UserProfile& upf) {
  MCE_DEBUG("id=" << upf.id() << ",iparea=" << upf.ip_area() << ",stage=" << upf.stage() << ",current_area=" << upf.current_area());
  if (!upf.id()) {
    upf.set_id(0);
  }
  if (upf.ip_area().empty() || "0000000000000000" == upf.ip_area()) {
    upf.set_ip_area("0086110000000000"); // 北京
  }
  if (!upf.stage()) {
    upf.set_stage(4);
  }
  if (!upf.ip()) {
    upf.set_ip(975044608); // 北京的一个随机IP
  }
  if (upf.current_area().empty()) {
    upf.set_current_area("0086110000000000"); // 北京
  }
  //测试代码,设置ip 10.2.17.35 (彭贺庭)和10.2.19.216(邢永涛)为国外
  /*if (upf.ip() == (10*256*256*256+2*256*256+17*256+35) || upf.ip() == (10*256*256*256+2*256*256+19*256+216)) {
    MCE_DEBUG("10.2.17.35 set to 0087110000000000, uid = " << upf.id());
    upf.set_current_area("0087110000000000");
    upf.set_ip_area("0087110000000000"); // 北京
  }*/
}
Example #6
0
bool AdNewGetRequest::response() {
  timeval start;
  gettimeofday(&start, NULL);
  if (!_fcgi_out) {
    MCE_WARN("remove notify fcgi_out null");
    return false;
  }

  _login_uid = 2;
  string uid = getProperty("uid");
  if (_cookies.find("id") != _cookies.end()) {
    uid = _cookies["id"];
  }
  if (!uid.empty()) {
    try {
      _login_uid = boost::lexical_cast<int>(uid);
    } catch (...) {
      MCE_WARN("lexical_cast cookie id error : " << uid);
    }
  }

  string serialized;
  if (_login_uid > 0) {
    bool b = false;
    try {
      StatFunc stat("memc GetSerialized");
      b = UserProfileClient::instance().GetSerialized(_login_uid, &serialized);
    } catch (std::exception& e) {
      MCE_WARN("UserProfileClient error : " << e.what() << " uid="
          << _login_uid);
    }

    if (!b) {
      MCE_INFO("profile not found in memcache. id=" << _login_uid);
      try {
        StatFunc stat("memc AdUserCacheLoader");
        serialized = AdUserCacheLoaderAdapter::instance().GetById(_login_uid);
      } catch (Ice::Exception& e) {
        MCE_WARN("AdUserCacheLoaderAdapter GetById error : " << e << " uid="
            << _login_uid);
      } catch (std::exception& e) {
        MCE_WARN("AdUserCacheLoaderAdapter GetById error : " << e.what()
            << " uid=" << _login_uid);
      }
    }
  }
  // FCGX_PutS("Content-type: application/x-javascript; charset=utf-8\r\n\r\n{}", _fcgi_out);
  // return true;

  UserProfile profile;
  if (serialized.empty()) {
    profile.set_stage(4);
    profile.set_gender(0);
    profile.set_age(25);
    profile.set_school(0);
    profile.set_major(0);
    profile.set_grade(0);
    profile.set_home_area("");
    profile.set_current_area("");
  } else {
    profile.ParseFromString(serialized);
  }

  unsigned int ip = ntohl(inet_addr(GetRemoteAddr().c_str()));

  profile.set_id(_login_uid);
  profile.set_ip(ip);
  profile.set_ip_area(IpAreaCache::instance().GetIpArea(ip));
  profile.SerializeToString(&serialized);

  int rotate_slot = GetCookieInt("an_slot", rand());
  rotate_slot %= 10000;

  AdResultMap ads;
  AdZone2Creatives final_ads;
  string referer = getProperty("ref");
  //MCE_DEBUG("[UrlMaping] ref = " << referer);
  if (referer.empty() || referer.find("http://") == string::npos) {
    referer = getProperty("r");
    if (referer.empty() || referer.find("http://") == string::npos) {
    referer = GetParamFix("HTTP_REFERER");
      //MCE_DEBUG("[UrlMaping] HTTP_REFERER = " << referer);
    }
  }

  bool err_flag = false;

  bool hide = false;
  string isvip = getProperty("isvip");
  string hideads = getProperty("hideads");
  if(isvip.compare("true")==0 && hideads.compare("true")==0) {
    hide = true;
  }

  stringstream log_url;
  try {
    char sep = '&';
    if (referer.find_first_of('?') == string::npos) {
      sep = '?';
    }
    int refresh_source = getPropertyInt("refresh_source", 0);
    int refresh_idx = getPropertyInt("refresh_idx", 0);
    log_url << referer << sep << "refresh_source=" << refresh_source
        << "&refresh_idx=" << refresh_idx;
    
    stringstream stat_desc;
    stat_desc << _login_uid << " GetAds";
    StatFunc stat(stat_desc.str());
  } catch (Ice::Exception& e) {
    MCE_WARN("AdGetRequest::response error : " << e << " uid=" << _login_uid);
    err_flag = true;
  } catch (std::exception& e) {
    MCE_WARN("AdGetRequest::response : " << e.what() << " uid=" << _login_uid);
    err_flag = true;
  }

//  string emtag = "M";

      MCE_DEBUG("debug 001");
  try {
    ads = AdEngineBAdapter::instance().GetAds(serialized, log_url.str(),
        rotate_slot, hide);
    MCE_DEBUG("EngineB size=" << ads.size());
    AdGateI::instance().translate(ads,final_ads);
    MCE_DEBUG("EngineB size=" << final_ads.size());
//    emtag = "M";
  } catch (Ice::Exception& e) {
    MCE_WARN("AdEngineBAdapter::GetAds error : " << e << " uid=" << _login_uid);
    err_flag = true;
  } catch (std::exception& e) {
    MCE_WARN("AdEngineBAdapter::GetAds error : " << e.what() << " uid="
        << _login_uid);
    err_flag = true;
  }

      MCE_DEBUG("debug 002");
  bool tw_flag = false;
  string tag, photo;
  map<long, EngineTypes> self_zones; // 需要中小自助广告广告位id
  for(AdResultMap::iterator it =  ads.begin(); it != ads.end(); it++) {
    if(!it->second.empty() && (it->second.at(0).groupid == -1)) {
      //台湾分尾号流量切分
      //MCE_INFO("Get Ads from AdEngine/AdTw");
      MCE_DEBUG("debug 003");
      if(_login_uid%10 < 2 || _login_uid == 287341024) {
        self_zones[it->first] = TW;
        tw_flag = true;
      } else {
        self_zones[it->first] = ENGINE;
      }
    } else if(!it->second.empty() && (it->second.at(0).groupid == -2)) {
      //余量,不分给台湾
      self_zones[it->first] = ENGINE;
      tag = "rr_REMAIN_1";
    } else if(!it->second.empty() && (it->second.at(0).groupid == -3)) {
      //余量,不分给台湾
      self_zones[it->first] = ENGINE;
      tag = "rr_REMAIN_2";
      photo = "true";
      MCE_DEBUG("photo = true");
    }
  }

      MCE_DEBUG("debug 004");
  if (!self_zones.empty()) {
    try {
      AdResultMap e_ads_;
      AdZone2Creatives e_ads;
      MCE_DEBUG("debug 005");
      //台湾分尾号流量切分
      if((_login_uid%10 < 2 || _login_uid == 287341024) && tw_flag) {
      MCE_DEBUG("debug 006");
        MCE_DEBUG("[TW_DEBUG] AdGetRequest::response --> enter to request Tw");
        e_ads_ = AdTwAdapter::instance().GetAds(serialized, log_url.str(), rotate_slot);
        AdGateI::instance().translate(ads,final_ads);
      } else {
      MCE_DEBUG("debug 007");
        MCE_DEBUG("AdGetRequest::response --> from AdEngine rotate_slot = "
            << rotate_slot);
        UserAndAction ua;
        ua.id = profile.id();
        ua.stage = profile.stage();
        ua.gender = profile.gender();
        ua.age = profile.age();
        ua.school = profile.school();
        ua.userMajor = profile.major();
        ua.grade = profile.grade();
        ua.homeArea = profile.home_area();
        ua.currentArea = profile.current_area();
        ua.ip = profile.ip();
        ua.ipArea = profile.ip_area();
        ua.actionType = ActionType::PAGEVIEW;
        AdRequest ad_request;
        ad_request.userAndAction = ua;
        ad_request.referer = referer;
        //url_mapping
       // set<Ice::Long> zone_ids;
        for (map<long, EngineTypes>::iterator zit = self_zones.begin(); zit != self_zones.end(); zit++) {
          long z_key = (*zit).first;
           if( photo == "true" && z_key == 100000000072 ) {
              ad_request.zoneDict[z_key] = 2;
           }else{
              ad_request.zoneDict[z_key] = 0;
            }
              ad_request.attributes[boost::lexical_cast<string>(z_key)]=tag;
        }
 //       AdUrlMaping::instance().GetAdZone(referer, ua.stage, zone_ids);
        //AdCreativeCache::instance().GetZoneDict(zone_ids, ad_request.zoneDict);
        MCE_DEBUG("AdGetRequest::response --> enter to request JavaServer");
        e_ads_=AdEngineJAdapter::instance().Request(ad_request);
        AdGateI::instance().translate(e_ads_,e_ads);
        //e_ads = AdEngineUAdapter::instance().GetAdsByZone(serialized, log_url.str(), rotate_slot, _login_uid, tag);
        //e_ads_ = AdEngineUAdapter::instance().GetAds(serialized, log_url.str(), rotate_slot, _login_uid, tag, photo);
      }
      if (e_ads.empty()) {
        MCE_DEBUG("AdGetRequest::response --> from AdEngineJ empty ");
      } else {
        for(AdZone2Creatives::iterator xxit =  e_ads.begin(); xxit != e_ads.end(); xxit++) {
          MCE_DEBUG("AdGetRequest::response --> from AdEngineJ" << xxit->second.size());
        }
      }
      for (map<long, EngineTypes>::iterator zit = self_zones.begin(); zit != self_zones.end(); zit++) {
        AdZone2Creatives::iterator eit = e_ads.find(zit->first);
        if (eit != e_ads.end()) {
          //eads[zit->first] = eit->second;
          //在相册页面,如果广告位wb1成功展示自助,则去掉wb2位置的广告
          /*if(100000000072 == zit->first) {
            ads[100000000073] = AdInfoSeq();
          }*/
        } else {
          ads[zit->first] = AdInfoSeq();
        }
      }
      for(AdZone2Creatives::const_iterator ad_x_it = e_ads.begin() ; ad_x_it != e_ads.end() ; ad_x_it ++ ){
        final_ads[ad_x_it->first] = ad_x_it->second; 
        MCE_DEBUG("AdGetRequest::response --> from AdEngineJ "  << ad_x_it->first <<"  " <<ad_x_it->second.size());
         if( ad_x_it->second.size() > 0 ) {
          for( int vi =0 ; vi < ad_x_it->second.size() ;vi ++ ) {
            MCE_DEBUG("widgetis =   " << ad_x_it->second[vi].widgetid);
          } 
         }
      }
    } catch (Ice::Exception& e) {
      MCE_WARN("AdEngineUAdapter/AdTwAdapter::GetAds error : " << e << " uid=" << _login_uid);
      err_flag = true;
    } catch (std::exception& e) {
      MCE_WARN("AdEngineUAdapter/AdTwAdapter::GetAds error : " << e.what() << " uid="
          << _login_uid);
      err_flag = true;
    }
  }
  if (err_flag) {
    stringstream stat_desc;
    stat_desc << _login_uid << " PushDefault";
    StatFunc stat(stat_desc.str());
    AdCreativeCache::instance().PushDefault(_login_uid, profile.stage(), GetRemoteAddr(),
        referer, &ads);
    AdGateI::instance().translate(ads,final_ads);
  }

  stringstream ad_header;
  string ad_body;
  if (render_ == RT_HTML) {
    ad_header
        << "Content-type: text/html; charset=utf-8\r\nSet-Cookie: an_slot="
        << ++rotate_slot << "; path=/ebpn\r\n\r\n";
    AdCreativeCache::instance().Get(final_ads, &ad_body);
    MCE_INFO("final ad size : "<< final_ads.size());
  } else if (render_ == RT_JSON) {
    ad_header
        << "Content-type: application/x-javascript; charset=utf-8\r\nSet-Cookie: an_slot="
        << ++rotate_slot << "; path=/ebpn\r\n\r\n";
    stringstream stat_desc;
    stat_desc << _login_uid << " GetJson";
    StatFunc stat(stat_desc.str());
    AdCreativeCache::instance().GetJson(referer, getPropertyInt(
        "refresh_source", 0), getPropertyInt("refresh_idx", 0), self_zones, final_ads,
        &ad_body);
    MCE_INFO("final ad size(json) : "<< final_ads.size());
  }

  FCGX_PutS(ad_header.str().c_str(), _fcgi_out);
  FCGX_PutS(ad_body.c_str(), _fcgi_out);
  timeval end;
  gettimeofday(&end, NULL);
  AdGateI::instance().ping_sender_.Send("GetAds", 1000*(end.tv_sec-start.tv_sec)+(end.tv_usec-start.tv_usec)/1000);
  return true;
}
Example #7
0
void AdMatchManagerI::PvLog(const set<AdGroupPtr>& zone_selected, const UserProfile& profile, uint64_t user_key, AdInfoSeq& ad_info_seq, const string& referer, const AdZonePtr& zone_ptr, const map<Ice::Long, int>& group_costs, int rotate_index){
  TimeStat ts;
  ostringstream log;
  int abs_pos = 1;
	vector<string> logseq;
  string referer_tmp = referer;
  LogHelper::instance().Process(referer_tmp);
  for(set<AdGroupPtr>::iterator sit = zone_selected.begin(); sit != zone_selected.end(); ++sit, ++abs_pos){
    AdInfo ad_info;
    MyUtil::Date date(time(NULL));
    AdGroupPtr group_ptr = *sit;

    AdEffectStat::instance().IncPv(user_key, group_ptr->group_id());
    //MCE_INFO("AdMatchNManagerI::GetAds --> IncPv user_key = " << user_key << " group_id = " << group_ptr->group_id());

    if(!group_ptr->creative_ids().empty()){
      //ad_info.creativeid = *(group_ptr->creative_ids().begin());
      int next_creative_index = 0;
      if(zone_ptr->GetRotateSize()){
        next_creative_index = rotate_index / zone_ptr->GetRotateSize();
        //MCE_INFO("AdMatchManagerI::PvLog -->  userid = " << userid << " rotate_index = " << rotate_index << " RotateSize = " << zone_ptr->GetRotateSize() << " next_creative_index = " << next_creative_index);
      }
      ad_info.creativeid = group_ptr->GetNextCreative(next_creative_index);
    }
    else{
      ad_info.creativeid = 0;
    }
    ad_info.groupid = group_ptr->group_id();
    ad_info.updateTime = 0;
    LogParas log_para;
    log_para.server_index_ = server_index_;
    map<Ice::Long, int>::const_iterator cost_it = group_costs.find(ad_info.groupid);
    if(cost_it == group_costs.end()){
      log_para.cost_ = 0;
    }
    else{
      log_para.cost_ = cost_it->second;
    }
    log_para.user_profile_ = profile;
    log_para.pv_time_ = Date(time(NULL)).time();
    log_para.creative_id_ = ad_info.creativeid;
    log_para.user_key_ = user_key;
    log_para.bid_unit_key_ = group_ptr->bid_unit_key();
    log_para.max_price_ = group_ptr->max_price();
    log_para.zone_id_ = zone_ptr->id();
    log_para.ad_count_ = zone_ptr->ad_count();
    ad_info.text = LogHelper::instance().MakeText(log_para);
    ad_info_seq.push_back(ad_info);

    //call AdLogAdapter
    Ice::Long zone_id = log_para.zone_id_;
    Ice::Long creativeid = log_para.creative_id_;
    string http = LogHelper::instance().MakeHttp(log_para);
    string ip = LogHelper::instance().MakeIp(profile.ip());
    log << "[email protected]||" << ip << "||" << date.toDateTime() << "||\"GET " << http << " HTTP/1.0\"||" << "200||"
        << "undefined||" << "undefined||" << "undefined||" << "2||" << "1||" << "none||" << referer_tmp << "||" << zone_id <<
        "^B^B^B^B^B^B^B" <<"||" << creativeid << "^B" << group_ptr->member_id() << "^B" << group_ptr->bid_unit_id()
        << "^B0^B" << group_ptr->max_price() << "^B" << referer_tmp << "^B" << abs_pos << "" << "^B1" << "^B2||4";
		logseq.push_back(log.str());
    /*try{
      ts.reset();
			logseq.push_buck(log.str());
      //AdLogAdapter::instance().Pv(log.str());
      //MCE_INFO("AdMatchManagerI::PvLog --> TIME_TEST write pv_log : " << ts.getTime());
    }
    catch(Ice::Exception& e){
      MCE_WARN("AdMatchManagerI::PvLog --> call AdLogAdapter.Pv ERR  line:"<<__LINE__<<" err:"<<e);
    }
    catch(std::exception& e){
      MCE_WARN("AdMatchManagerI::PvLog --> call AdLogAdapter.Pv ERR  line:"<<__LINE__<<" err:"<<e.what());
    }*/
    log.str("");
  }
	try{
    AdLogAdapter::instance().PvBySeq(logseq);
    //MCE_INFO("AdMatchManagerI::PvLog --> TIME_TEST write pv_log : " << ts.getTime());
  }
  catch(Ice::Exception& e){
    MCE_WARN("AdMatchManagerI::PvLog --> call AdLogAdapter.Pv ERR  line:"<<__LINE__<<" err:"<<e);
  }
  catch(std::exception& e){
    MCE_WARN("AdMatchManagerI::PvLog --> call AdLogAdapter.Pv ERR  line:"<<__LINE__<<" err:"<<e.what());
  }

}