acl/app/master/tools/service_guard/udp_service.cpp

84 lines
1.8 KiB
C++

#include "stdafx.h"
#include "action/guard_action.h"
#include "configure.h"
#include "udp_service.h"
udp_service::udp_service(void)
{
}
udp_service::~udp_service(void)
{
}
void udp_service::on_read(acl::socket_stream* stream)
{
int n;
char buf[1500];
if ((n = stream->read(buf, sizeof(buf) - 1, false)) == -1)
return;
buf[n] = 0;
logger_debug(DBG_NET, 1, "read from %s, %d bytes, buf=|%s|",
stream->get_peer(), n, buf);
const char* peer_ip = stream->get_peer();
if (peer_ip == NULL || *peer_ip == 0) {
logger_error("can't get peer ip");
return;
}
guard_action* job = new guard_action(peer_ip, buf);
threads_->execute(job);
}
void udp_service::thread_on_init(void)
{
logger(">>thread_on_init<<<");
}
void udp_service::proc_on_bind(acl::socket_stream&)
{
logger(">>>proc_on_bind<<<");
}
void udp_service::proc_on_init(void)
{
threads_ = new acl::thread_pool;
threads_->set_limit(var_cfg_threads_max);
threads_->set_idle(var_cfg_threads_idle);
threads_->start();
var_redis.init(NULL, var_cfg_redis_addrs, var_cfg_threads_max,
var_cfg_redis_conn_timeout, var_cfg_redis_rw_timeout);
var_redis.set_password("default", var_cfg_redis_passwd);
if (var_cfg_main_service_list && *var_cfg_main_service_list)
{
ACL_ARGV *tokens = acl_argv_split(
var_cfg_main_service_list, ",; \t\r\n");
ACL_ITER iter;
acl_foreach(iter, tokens)
{
const char* ptr = (const char*) iter.data;
var_main_service_list[ptr] = true;
}
acl_argv_free(tokens);
}
logger(">>>proc_on_init<<<");
}
void udp_service::proc_on_exit(void)
{
delete threads_;
logger(">>>proc_on_exit<<<");
}
bool udp_service::proc_on_sighup(acl::string&)
{
logger(">>>proc_on_sighup<<<");
return true;
}