acl/lib_acl_cpp/samples/beanstalk2/beanstalk.cpp
2015-01-15 09:12:41 -08:00

85 lines
1.6 KiB
C++

// beanstalk.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include "util.h"
static char __addr[64];
static const char* __tube = "zsxxsz";
static int __max = 100;
// 接收队列消息的消费者线程
static void consumer(void)
{
acl::beanstalk conn(__addr, 10);
// 从指定消息队列中接收消息
if (conn.watch(__tube) == false)
{
printf("watch %s faile\r\n", __tube);
return;
}
acl::string buf;
unsigned long long id;
// 超时接收一条消息
if ((id = conn.reserve(buf)) == 0)
printf("reserve failed, error: %s\r\n", conn.get_error());
else
{
printf("id: %llu, buf: %s\r\n", id, buf.c_str());
conn.delete_id(id);
}
// 阻塞接收一条消息
if ((id = conn.reserve(buf, 1)) == 0)
printf("reserve failed, error: %s\r\n", conn.get_error());
else
printf("id: %llu, buf: %s\r\n", id, buf.c_str());
}
static void usage(const char* procname)
{
printf("usage: %s -h [help] -s beanstalk_addr [127.0.0.1:11300] -n max_count\r\n", procname);
}
int main(int argc, char* argv[])
{
#if WIN32
acl::acl_cpp_init();
#endif
acl::log::stdout_open(true);
snprintf(__addr, sizeof(__addr), "127.0.0.1:11300");
int ch;
while ((ch = getopt(argc, argv, "hs:n:")) > 0)
{
switch (ch)
{
case 'h':
usage(argv[0]);
return 0;
case 's':
snprintf(__addr, sizeof(__addr), "%s", optarg);
break;
case 'n':
__max = atoi(optarg);
if (__max <= 0)
__max = 1;
break;
default:
break;
}
}
consumer();
#ifdef WIN32
printf("enter any key to exit\r\n");
getchar();
#endif
return 0;
}