nginx代码非常的优秀,之前已经介绍了sendfile的使用来实现“内存零拷贝”,今天我又理解了一下writev函数的使用,以nginx-1.6.0为例,在src/os/unix/ngx_writev_chain.c的113行,如下图:
可以man 2 writev看下函数的概念(与writev相对应的还有一个readv)writev是读取多个不连续的buffer然后集中写入。
#includessize_t readv(int fd, const struct iovec *vector, int count); ssize_t writev(int fd, const struct iovec *vector, int count);
如何实现
#include#include #include int main(int argc,char *argv[]){ int fd1,fd2,fd3; ssize_t size; char buf1[9],buf2[9]; struct iovec iov[2]; fd1=open(argv[1],O_RDONLY); fd2=open(argv[2],O_RDONLY); fd3=open(argv[3],O_RDWR); size=read(fd1,buf1,sizeof(buf1)); printf("%s size is : %d\n",argv[1],size); size=read(fd2,buf2,sizeof(buf2)); printf("%s size is : %d\n",argv[2],size); iov[0].iov_base=buf1; iov[0].iov_len=sizeof(buf1); iov[1].iov_base=buf2; iov[1].iov_len=sizeof(buf2); size=writev(fd3,iov,2); printf("%s size is :%d\n",argv[3],size); close(fd1); close(fd2); close(fd3);}
首先创建3个文件,file1(9个字节),file2(9个字节),file3(空文件),程序将file1和file1读入buffer然后将两段buffer集中写入新的fd中
编译测试吧
writev和write函数区别就是在于多个非连续buffer的读取后写入,当负载大的时候就可以很好的体现出性能效果了。