增加HTTP业务层和缓存运行状态统计。业务层状态输出到tfe.fieldstat,缓存输出到cache.fieldstat。增加缓存开关。
This commit is contained in:
@@ -194,29 +194,35 @@ static void * __thread_ctx_entry(void * arg)
|
||||
return (void *)NULL;
|
||||
}
|
||||
|
||||
struct tfe_thread_ctx * __thread_ctx_create(struct tfe_proxy * proxy, unsigned int thread_id)
|
||||
|
||||
void tfe_proxy_work_thread_create_ctx(struct tfe_proxy * proxy)
|
||||
{
|
||||
struct tfe_thread_ctx * __thread_ctx = ALLOC(struct tfe_thread_ctx, 1);
|
||||
assert(__thread_ctx != NULL);
|
||||
|
||||
__thread_ctx->thread_id = thread_id;
|
||||
__thread_ctx->evbase = event_base_new();
|
||||
|
||||
int ret = pthread_create(&__thread_ctx->thr, NULL, __thread_ctx_entry, (void *)__thread_ctx);
|
||||
if (unlikely(ret < 0))
|
||||
unsigned int i=0;
|
||||
for(i=0; i<proxy->nr_work_threads;i++)
|
||||
{
|
||||
TFE_LOG_ERROR(proxy->logger, "Failed at pthread_create() for thread %d: %s",errno, strerror(errno));
|
||||
goto __errout;
|
||||
proxy->work_threads[i]=ALLOC(struct tfe_thread_ctx, 1);
|
||||
proxy->work_threads[i]->thread_id = i;
|
||||
proxy->work_threads[i]->evbase = event_base_new();
|
||||
}
|
||||
|
||||
return __thread_ctx;
|
||||
|
||||
__errout:
|
||||
if (__thread_ctx != NULL && __thread_ctx->evbase != NULL) event_base_free(__thread_ctx->evbase);
|
||||
if (__thread_ctx != NULL) free(__thread_ctx);
|
||||
return NULL;
|
||||
return;
|
||||
}
|
||||
int tfe_proxy_work_thread_run(struct tfe_proxy * proxy)
|
||||
{
|
||||
struct tfe_thread_ctx * __thread_ctx=NULL;
|
||||
unsigned int i=0;
|
||||
int ret=0;
|
||||
for(i=0; i<proxy->nr_work_threads;i++)
|
||||
{
|
||||
__thread_ctx=proxy->work_threads[i];
|
||||
ret = pthread_create(&__thread_ctx->thr, NULL, __thread_ctx_entry, (void *)__thread_ctx);
|
||||
if (unlikely(ret < 0))
|
||||
{
|
||||
TFE_LOG_ERROR(proxy->logger, "Failed at pthread_create() for thread %d, error %d: %s", i, errno, strerror(errno));
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int tfe_proxy_config(struct tfe_proxy * proxy, const char * profile)
|
||||
{
|
||||
/* Worker threads */
|
||||
@@ -304,7 +310,7 @@ int main(int argc, char *argv[])
|
||||
|
||||
/* SSL INIT */
|
||||
g_default_proxy->ssl_mgr_handler = ssl_manager_init(main_profile, "ssl",
|
||||
g_default_proxy->evbase, g_default_logger, g_default_proxy->fs_handle);
|
||||
g_default_proxy->evbase, g_default_logger);
|
||||
CHECK_OR_EXIT(g_default_proxy->ssl_mgr_handler, "Failed at init SSL manager. Exit.");
|
||||
|
||||
for (size_t i = 0; i < (sizeof(signals) / sizeof(int)); i++)
|
||||
@@ -317,15 +323,9 @@ int main(int argc, char *argv[])
|
||||
struct timeval gc_delay = {2, 0};
|
||||
evtimer_add(g_default_proxy->gcev , &gc_delay);
|
||||
|
||||
/* WORKER THREAD */
|
||||
//TODO: Split ctx_create functioin to create and Run.
|
||||
for(unsigned tid = 0; tid < g_default_proxy->nr_work_threads; tid++)
|
||||
{
|
||||
g_default_proxy->work_threads[tid] = __thread_ctx_create(g_default_proxy, tid);
|
||||
CHECK_OR_EXIT(g_default_proxy->work_threads[tid], "Failed at creating thread %u", tid);
|
||||
}
|
||||
|
||||
|
||||
/* WORKER THREAD CTX Create */
|
||||
tfe_proxy_work_thread_create_ctx(g_default_proxy);
|
||||
|
||||
/* ACCEPTOR INIT */
|
||||
g_default_proxy->kni_acceptor_handler = kni_acceptor_init(g_default_proxy, main_profile, g_default_logger);
|
||||
CHECK_OR_EXIT(g_default_proxy->kni_acceptor_handler, "Failed at init KNI acceptor. Exit. ");
|
||||
@@ -341,21 +341,31 @@ int main(int argc, char *argv[])
|
||||
TFE_LOG_INFO(g_default_logger, "Plugin %s initialized. ", plugin_iter->symbol);
|
||||
}
|
||||
|
||||
|
||||
|
||||
ret=tfe_proxy_work_thread_run(g_default_proxy);
|
||||
CHECK_OR_EXIT(ret==0, "Failed at creating thread. Exit.");
|
||||
|
||||
TFE_LOG_ERROR(g_default_logger, "Tango Frontend Engine initialized. ");
|
||||
event_base_dispatch(g_default_proxy->evbase);
|
||||
|
||||
return 0;
|
||||
}
|
||||
unsigned int tfe_proxy_get_thread_count(void)
|
||||
unsigned int tfe_proxy_get_work_thread_count(void)
|
||||
{
|
||||
return g_default_proxy->nr_work_threads;
|
||||
}
|
||||
struct event_base * tfe_proxy_get_evbase(unsigned int thread_id)
|
||||
struct event_base * tfe_proxy_get_work_thread_evbase(unsigned int thread_id)
|
||||
{
|
||||
assert(thread_id<g_default_proxy->nr_work_threads);
|
||||
return g_default_proxy->work_threads[thread_id]->evbase;
|
||||
}
|
||||
struct event_base * tfe_proxy_get_gc_evbase(void)
|
||||
{
|
||||
return g_default_proxy->evbase;
|
||||
}
|
||||
|
||||
screen_stat_handle_t tfe_proxy_get_fs_handle(void)
|
||||
{
|
||||
return g_default_proxy->fs_handle;
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user