Redis源码学习之【Tcp Socket封装】

介绍

Redis对linux socket的封装,虽然在该封装中也含有对unix socket的封装,但是普遍来说使用的tcp socket。和上一篇的epoll的封装类似,都是通过调用底层的socket的函数完成一些列的方便的函数调用封装。

源码

anet.h anet.c

分析

主要包含以下几个封装函数(这里仅介绍关于Tcp socket的封装函数)

anetTcpconnect:创建socket并调用底层的connect进行连接。

anetTcpNonBlockConnect:和anetTcpConnect功能类似,但是设置连接的socket为非阻塞的。

anetRead:调用底层的read对socket中的内容进行读取。

anetWrite:调用底层的write向socket写入内容。

anetTcpServer:创建监听socket,并调用bind和listen启动服务器开始监听端口。

anetTcpAccept:调用accept,接收客户端的连接。

当然还有其他的辅助的函数,像是anetResolve解析地址,以及设置socket属性的一些函数如anetNonBlock anetTcpNoDelay anetTcpKeepAlive anetPeerToString等。

说明

这里的对socket的封装的主要目的是为了方便Redis的网络调用这里的函数主要被下一篇将要介绍的Redis网络通信实现所调用。


你可能感兴趣的:(redis)