当前位置: 首页>>代码示例>>C++>>正文


C++ Director::name方法代码示例

本文整理汇总了C++中Director::name方法的典型用法代码示例。如果您正苦于以下问题:C++ Director::name方法的具体用法?C++ Director::name怎么用?C++ Director::name使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Director的用法示例。


在下文中一共展示了Director::name方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: index

// GET /
bool ApiRequest::index()
{
	// FIXME: thread safety.
	// In order to make this method thread-safe, we must ensure that each director's 
	// json-write is done from within the director's worker thread and finally
	// the reply be sent to the client from within the request's worker thread.

	Buffer result;
	JsonWriter json(result);

	json.beginObject();
	for (auto di: *directors_) {
		Director* director = di.second;
		json.name(director->name()).value(*director);
	}
	json.endObject();
	result << "\n";

	char slen[32];
	snprintf(slen, sizeof(slen), "%zu", result.size());

	request_->responseHeaders.push_back("Cache-Control", "no-cache");
	request_->responseHeaders.push_back("Content-Type", "application/json");
	request_->responseHeaders.push_back("Access-Control-Allow-Origin", "*");
	request_->responseHeaders.push_back("Content-Length", slen);
	request_->write<BufferSource>(result);
	request_->finish();

	return true;
}
开发者ID:hiwang123,项目名称:x0,代码行数:31,代码来源:ApiRequest.cpp

示例2: update

void HealthMonitor::update() {
  Director* director = static_cast<Director*>(backend_->manager());

  setRequest(
      "GET %s HTTP/1.1\r\n"
      "Host: %s\r\n"
      "x0-Health-Check: yes\r\n"
      "x0-Director: %s\r\n"
      "x0-Backend: %s\r\n"
      "\r\n",
      director->healthCheckRequestPath().c_str(),
      director->healthCheckHostHeader().c_str(), director->name().c_str(),
      backend_->name().c_str());
}
开发者ID:tempbottle,项目名称:x0,代码行数:14,代码来源:HealthMonitor.cpp

示例3: pass

void DirectorPlugin::pass(HttpRequest* r, const std::string& directorName,
                          const std::string& backendName) {
    auto i = directors_.find(directorName);
    if (i == directors_.end()) {
        r->log(Severity::error,
               "director.pass(): No director with name '%s' configured.",
               directorName.c_str());
        internalServerError(r);
        return;
    }
    Director* director = i->second.get();

    // custom backend route
    Backend* backend = nullptr;
    if (!backendName.empty()) {
        backend = director->findBackend(backendName);

        if (!backend) {
            // explicit backend specified, but not found -> do not serve.
            r->log(Severity::error, "director: Requested backend '%s' not found.",
                   backendName.c_str());
            internalServerError(r);
            return;
        }
    }

#if !defined(NDEBUG)
    server().log(Severity::trace, "director: passing request to %s [backend %s].",
                 director->name().c_str(), backend->name().c_str());
#endif

    auto rn = requestNotes(r);
    rn->manager = director;

    r->onPostProcess.connect(std::bind(&DirectorPlugin::addVia, this, r));

    director->schedule(rn, backend);

    return;
}
开发者ID:tempbottle,项目名称:x0,代码行数:40,代码来源:DirectorPlugin.cpp

示例4: balance

void DirectorPlugin::balance(HttpRequest* r, const std::string& directorName,
                             const std::string& bucketName) {
    auto i = directors_.find(directorName);
    if (i == directors_.end()) {
        r->log(Severity::error,
               "director.balance(): No director with name '%s' configured.",
               directorName.c_str());
        internalServerError(r);
        return;
    }
    Director* director = i->second.get();

    RequestShaper::Node* bucket = nullptr;
    if (!bucketName.empty()) {
        bucket = director->findBucket(bucketName);
        if (!bucket) {
            // explicit bucket specified, but not found -> ignore.
            bucket = director->rootBucket();
            r->log(Severity::error,
                   "director: Requested bucket '%s' not found in director '%s'. "
                   "Assigning root bucket.",
                   bucketName.c_str(), directorName.c_str());
        }
    } else {
        bucket = director->rootBucket();
    }

    auto rn = requestNotes(r);
    rn->manager = director;

    r->onPostProcess.connect(std::bind(&DirectorPlugin::addVia, this, r));

#if !defined(NDEBUG)
    server().log(Severity::trace, "director: passing request to %s [%s].",
                 director->name().c_str(), bucket->name().c_str());
#endif

    director->schedule(rn, bucket);
}  // }}}
开发者ID:tempbottle,项目名称:x0,代码行数:39,代码来源:DirectorPlugin.cpp

示例5: csv

void HaproxyApi::csv(HttpRequest* r)
{
	Buffer buf;

	buf.push_back("# pxname,svname,qcur,qmax,scur,smax,slim,stot,bin,bout,dreq,dresp,ereq,econ,eresp,wretr,wredis,status,weight,act,bck,chkfail,chkdown,lastchg,downtime,qlimit,pid,iid,sid,throttle,lbtot,tracked,type,rate,rate_lim,rate_max,check_status,check_code,check_duration,hrsp_1xx,hrsp_2xx,hrsp_3xx,hrsp_4xx,hrsp_5xx,hrsp_other,hanafail,req_rate,req_rate_max,req_tot,cli_abrt,srv_abrt,\n");

	for (auto di: *directors_) {
		Director* director = di.second;

		buildFrontendCSV(buf, director);

		director->eachBackend([&](Backend* backend) {
			// 01 pxname: proxy name
			buf.push_back(director->name());
			buf.push_back(',');

			// 02 svname: service name (FRONTEND for frontend, BACKEND for backend, any name for server)
			buf.push_back(backend->name()); // svname

			// 03 qcur: current queued requests
			// 04 qmax: max queued requests
			buf.push_back(",0,0,"); // qcur, qmax

			// 05 scur: current sessions
			buf.push_back(backend->load().current());
			buf.push_back(',');

			// 06 smax: max sessions
			buf.push_back(backend->load().max());
			buf.push_back(",");

			// 07 slim: sessions limit
			buf.push_back(",");

			// 08 stot: total sessions
			buf.push_back(backend->load().total());

			// 09 bin: bytes in
			// 10 bout: bytes out
			buf.push_back(",0,0,"); // bin, bout

			// 11 dreq: denied requests
			// 12 dresp: denied responses
			buf.push_back("0,0,"); // dreq, dresp

			// 13 ereq: request errors
			// 14 econ: connection errors
			// 15 eresp: response errors (among which srv_abrt)
			buf.push_back("0,0,0,"); // ereq, econ, resp

			// 16 wretr: retries (warning)
			// 17 wredis: redispatches (warning)
			buf.push_back("0,0,"); // wretr, wredis

			// 18 status
			if (!backend->isEnabled()) { // status
				buf.push_back("MAINT");
			} else if (backend->healthMonitor()) {
				switch (backend->healthMonitor()->state()) {
				case HealthState::Online:
					buf.push_back("UP");
					break;
				case HealthState::Offline:
					buf.push_back("DOWN");
					break;
				case HealthState::Undefined:
					buf.push_back("UNKNOWN");
					break;
				}
			} else {
				buf.push_back("UP");
			}

			// weight: server weight (server), total weight (backend)
			buf.push_back(",0,"); // weight

			// 20 act: server is active (server), number of active servers (backend)
			// 21 bck: server is backup (server), number of backup servers (backend)
			switch (director->backendRole(backend)) { // act, bck
				case BackendRole::Active:
					buf.push_back("1,0,");
					break;
				case BackendRole::Backup:
					buf.push_back("0,1,");
					break;
				case BackendRole::Terminate:
					buf.push_back("0,0,");
					break;
			}
			// 22 chkfail: number of failed checks
			buf.push_back(','); // TODO

			// 23 chkdown: number of UP->DOWN transitions
			buf.push_back(','); // TODO

			// 24 lastchg: last status change (in seconds)
			buf.push_back(','); // TODO

			// 25 downtime: total downtime (in seconds)
			buf.push_back(','); // TODO
//.........这里部分代码省略.........
开发者ID:saeschdivara,项目名称:x0,代码行数:101,代码来源:HaproxyApi.cpp


注:本文中的Director::name方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。