acl  3.5.3.0
acl_vstream_net.h
浏览该文件的文档.
1 #ifndef ACL_VSTREAM_NET_INCLUDE_H
2 #define ACL_VSTREAM_NET_INCLUDE_H
3 
4 #ifdef __cplusplus
5 extern "C" {
6 #endif
7 
8 #include "../stdlib/acl_define.h"
9 #include "../stdlib/acl_vstream.h"
10 
11 /**
12  * 监听某个地址(对于UNIX,还可以监听域套接字)
13  * @param addr {const char*} 监听地址,
14  * 如:127.0.0.1:80 或域套接字(UNIX平台) 如:/tmp/test.sock,在 Linux 平台下,
15  * 如果 addr 的首字母为 '@',则当作 astract unix domain path.
16  * @param qlen {int} 监听队列的长度
17  * @param flag {unsigned} 监听标志位,参见:ACL_INET_FLAG_XXX
18  * @param io_bufsize {int} 接收的新的客户端套接字的IO缓冲区大小
19  * @param rw_timeout {int} 接收的新的客户端套接字的IO读写超时时间,单位为秒
20  * @return {ACL_VSTREAM*} 监听流指针
21  */
22 ACL_API ACL_VSTREAM *acl_vstream_listen_ex(const char *addr, int qlen,
23  unsigned flag, int io_bufsize, int rw_timeout);
24 
25 /**
26  * 监听某个地址(对于UNIX,还可以监听域套接字)
27  * @param addr {const char*} 监听地址
28  * 如:127.0.0.1:80, 或域套接字, 如:/tmp/test.sock,当地址为 ip:0 时则监听
29  * 端口号由操作系统自动分配
30  * @param qlen {int} 监听队列的长度
31  * @return {ACL_VSTREAM*} 监听流指针
32  */
33 ACL_API ACL_VSTREAM *acl_vstream_listen(const char *addr, int qlen);
34 
35 /**
36  * 从监听流中接收一个客户端连接流
37  * @param listen_stream {ACL_VSTREAM*} 监听流
38  * @param client_stream {ACL_VSTREAM*} 可重复利用的 ACL_VSTREAM 结构,
39  * 如果为空则内部产生一个新的 ACL_VSTREAM 流,否则复用该结构空间
40  * @param ipbuf {char*} 如果不为空则用来存储客户端的IP地址
41  * @param bsize {int} 如果 ipbuf 不为空,则表示 ipbuf 的空间大小
42  * @return {ACL_VSTREAM*} 如果不为空则表示新接收的客户端流
43  */
44 ACL_API ACL_VSTREAM *acl_vstream_accept_ex(ACL_VSTREAM *listen_stream,
45  ACL_VSTREAM *client_stream, char *ipbuf, int bsize);
46 
47 /**
48  * 从监听流中接收一个客户端连接流
49  * @param listen_stream {ACL_VSTREAM*} 监听流
50  * @param ipbuf {char*} 如果不为空则用来存储客户端的IP地址
51  * @param bsize {int} 如果 ipbuf 不为空,则表示 ipbuf 的空间大小
52  * @return {ACL_VSTREAM*} 如果不为空则表示新接收的客户端流
53  */
54 ACL_API ACL_VSTREAM *acl_vstream_accept(ACL_VSTREAM *listen_stream,
55  char *ipbuf, int bsize);
56 
57 /**
58  * 远程连接服务器
59  * @param addr {const char*} 服务器地址, 如果连接一个域套接口服务器(仅UNIX平台),
60  * 域套接地址:/tmp/test.sock,对于 Linux 平台,如果首字母为 '@' 则表示连接本
61  * 地的抽象UNIX域套接口(Linux abstract unix domain socket);
62  * 如果连接一个TCP服务器,则地址格式为:
63  * remote_addr[@local_ip], 如: www.sina.com|80@60.28.250.199, 意思是绑定
64  * 本的网卡地址为: 60.28.250.199, 远程连接 www.sina.com 的 80 端口, 如果由OS
65  * 自动绑定本地 IP 地址,则可以写为:www.sina.com:80
66  * @param block_mode {int} 阻塞连接还是非阻塞连接,ACL_BLOCKING, ACL_NON_BLOCKING
67  * @param conn_timeout {int} 连接超时时间(秒)
68  * @param rw_timeout {int} 连接流成功后的读写超时时间,单位为秒
69  * @param bufsize {int} 连接流成功后的缓冲区大小
70  * @param error {int*} 如果不为空,则存储连接失败后的错误号
71  * @return {ACL_VSTREAM*} 如果不为空,则表示连接成功后的数据流
72  */
73 ACL_API ACL_VSTREAM *acl_vstream_connect_ex(const char *addr, int block_mode,
74  int conn_timeout, int rw_timeout, int bufsize, int *error);
75 
76 /**
77  * 远程连接服务器
78  * @param addr {const char*} 服务器地址,含义同上
79  * @param block_mode {int} 阻塞连接还是非阻塞连接,ACL_BLOCKING, ACL_NON_BLOCKING
80  * @param connect_timeout {int} 连接超时时间(秒)
81  * @param rw_timeout {int} 连接流成功后的读写超时时间,单位为秒
82  * @param rw_bufsize {int} 连接流成功后的缓冲区大小
83  * @return {ACL_VSTREAM*} 如果不为空,则表示连接成功后的数据流
84  */
85 ACL_API ACL_VSTREAM *acl_vstream_connect(const char *addr, int block_mode,
86  int connect_timeout, int rw_timeout, int rw_bufsize);
87 
88 /**
89  * 远程连接服务器
90  * @param addr {const char*} 服务器地址,含义同上
91  * @param block_mode {int} 阻塞连接还是非阻塞连接,ACL_BLOCKING, ACL_NON_BLOCKING
92  * @param connect_timeout {int} 连接超时时间(毫秒)
93  * @param rw_timeout {int} 连接流成功后的读写超时时间,单位为毫秒
94  * @param rw_bufsize {int} 连接流成功后的缓冲区大小
95  * @param error {int*} 如果不为空,则存储连接失败后的错误号
96  * @return {ACL_VSTREAM*} 如果不为空,则表示连接成功后的数据流
97  */
98 ACL_API ACL_VSTREAM *acl_vstream_timed_connect(const char *addr, int block_mode,
99  int connect_timeout, int rw_timeout, int rw_bufsize, int *error);
100 
101 /**
102  * 针对 UDP 通信,该函数用来绑定本地 UDP 地址,如果绑定成功,则创建
103  * ACL_VSTREAM 对象, 用户可以象调用 ACL_VSTREAM 对象的读写接口
104  * @param addr {const char*} 本地 UDP 地址,格式:ip:port,可以输入地址 ip:0
105  * 来让操作系统自动分配本地端口号,此外还支持在 UNIX 平台下绑定 UNIX 域套接口,
106  * UNIX 域套接口的地址格式为:{path}@udp,其中 {path} 为域套接口路径,@udp 为
107  * UDP 后缀
108  * @param rw_timeout {int} 读写超时时间(秒)
109  * @param flag {unsigned} 标志位
110  * @return {ACL_VSTREAM*} 返回 NULL 表示绑定失败
111  */
112 ACL_API ACL_VSTREAM *acl_vstream_bind(const char *addr, int rw_timeout, unsigned flag);
113 
114 /**
115  * 将网络流对象设置为 UDP IO 模式
116  * @param stream {ACL_VSTREAM*}
117  */
118 ACL_API void acl_vstream_set_udp_io(ACL_VSTREAM *stream);
119 
120 #ifdef __cplusplus
121 }
122 #endif
123 
124 #endif
125 
ACL_API ACL_VSTREAM * acl_vstream_accept_ex(ACL_VSTREAM *listen_stream, ACL_VSTREAM *client_stream, char *ipbuf, int bsize)
ACL_API ACL_VSTREAM * acl_vstream_connect_ex(const char *addr, int block_mode, int conn_timeout, int rw_timeout, int bufsize, int *error)
ACL_API ACL_VSTREAM * acl_vstream_connect(const char *addr, int block_mode, int connect_timeout, int rw_timeout, int rw_bufsize)
ACL_API ACL_VSTREAM * acl_vstream_accept(ACL_VSTREAM *listen_stream, char *ipbuf, int bsize)
ACL_API ACL_VSTREAM * acl_vstream_bind(const char *addr, int rw_timeout, unsigned flag)
ACL_API ACL_VSTREAM * acl_vstream_timed_connect(const char *addr, int block_mode, int connect_timeout, int rw_timeout, int rw_bufsize, int *error)
ACL_API ACL_VSTREAM * acl_vstream_listen_ex(const char *addr, int qlen, unsigned flag, int io_bufsize, int rw_timeout)
ACL_API ACL_VSTREAM * acl_vstream_listen(const char *addr, int qlen)
ACL_API void acl_vstream_set_udp_io(ACL_VSTREAM *stream)