【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>
在以前有关使用 acl 的技术文章(如:使用 acl::master_threads 类编写多进程多线程服务器程序 ,用 acl::master_aio 类编写高并发非阻塞服务器程序,使用 acl::master_proc 类编写多进程服务器程序)中,对如何使用 acl 服务器框架类编写服务器应用程序做了较为详细的描述,但手工输入这些代码毕竟是比较烦人的,在 acl 的 app/ 目录下有一个向导程序:wizard,可以帮助开发者快速生成服务器框架模板,开发者只需在相关位置添加业务逻辑代码即可。下面是使用 wizard 向导程序的简要过程:
首先在 acl 的根目录下编译所有的 acl 的基础库:make all,然后进入 app/wizard 目录生成 wizard 程序:make,运行 ./wizard,出现如下界面:
[zsx@localhost wizard]$ ./wizard
select one below:
m: master_service; d: db; h: http; q: exit
# 上面过程提示用户生成哪种应用的程序,我们此处是编写服务器,所以选择:m
>m
# 接着 wizard 提示我们输入应用程序名称,此处可以写:echo_server
please input your program name: echo_server
# 然后 wizard 提示选择何种服务器框架模板,此处选择 t 表示使用多进程多线程服务器模板
# 各个参数类型说明如下:
# t:多进程多线程服务器模板
# p:多进程服务器模板
# a:多进程非阻塞服务器模板
# g:触发器服务器模板
choose master_service type:
t: for master_threads; p: for master_proc; a: for master_aio; g: for master_trigger; s: skip choose
>t
create echo_server/Makefile ok.
create echo_server/echo_server.sln ok.
create echo_server/echo_server.vcproj ok.
create echo_server/Makefile.in ok
create echo_server/stdafx.h ok
create echo_server/stdafx.cpp ok
create common_files ok!
create echo_server/echo_server.cf ok.
create echo_server/Makefile.in ok
create echo_server/main.cpp ok
create echo_server/master_service.h ok
create echo_server/master_service.cpp ok
create master_threads ok!
------------------------------------------------------------------------------
select one below:
m: master_service; d: db; h: http; q: exit
>q
Bye!
OK,输入几个字母,按几下回车,一个相对完整的服务器程序便生成了。从上面的生成过程不难看出 wizard 向导程序不仅生成了源文件,而且生成了工程文件以及服务器配置文件。
进入 echo_server 目录,打开自动生成的 master_service.cpp 文件,修改 master_service::thread_on_read 函数内容如下:
bool master_service::thread_on_read(acl::socket_stream* conn)
{
acl::string buf;
// 从客户端连接流中读取一行数据,读操作参见:acl_cpp/stream/istream.hpp
if (client->gets(buf, false) == false)
{
printf("gets from client error, closed it!\r\n");
// 返回 false 通知服务器框架将该客户端连接关闭
return false;
}
// 将从客户端连接流中读到数据回写,写操作参见:acl_cpp/stream/ostream.hpp
if (client->write(buf) == -1)
{
// 返回 false 通知服务器框架将该客户端连接关闭
printf("write to client error, closed it!\r\n");
return false;
}
// 返回 true 通知服务器框架继续监听该客户端连接的下一个请求过程
return true;
}
同时修改 master_service::thread_on_accept 函数,内容如下:
bool master_service::thread_on_accept(acl::socket_stream* conn)
{
// 设置客户端连接读写超时时间(秒)
conn->set_rw_timeout(10);
// 向客户端发送欢迎信息
if (conn->format("+OK Welcome!\r\n") == -1)
{
printf("write to client error, close it!\r\n");
// 返回 false 通知服务器框架关闭客户端连接
return false;
}
// 返回 true 通知框架监控该客户端流的可读状态
return true;
}
一个非常简单的 echo 服务器程序完成,编译之(make),然后先以命令行方式进行测试:./echo_server alone 该服务器程序提示如下信息:listen on: 127.0.0.1:8888,意思是它现在开始监听本机回路地址的 8888 端口。可以手工通过 telnet 命令测试它:
[zsx@localhost ~]$ telnet 127.0.0.1 8888
Trying 127.0.0.1...
Connected to localhost.localdomain (127.0.0.1).
Escape character is '^]'.
+OK Welcome!
hello world!
hello world!
当然,正式的生产环境下需要将 echo_server 程序放在 acl_master 服务器框架下运行,部署方式参见:acl服务器模块的部署--示例 ,acl 服务器模块的部署 。
参考:
acl 库下载:https://sourceforge.net/projects/acl/
svn: svn://svn.code.sf.net/p/acl/code/
QQ 群:242722074
来源:oschina
链接:https://my.oschina.net/u/568966/blog/309592