errno

在unix系统中对大部分系统调用非正常返回时,通常返回值为-1。并设置全局变量errno(errno.h),如socket(), bind(), accept(), listen()。

erron存放一个正整数来保存上次出错的错误值。

对线程而言。每一个线程都有专用的errno变量。不必考虑同步问题。

strerror converts to English (Note: use strerror_r for thread safety)

perror is simplified strerror/fprintf

慢系统调用

指可能永远堵塞而无法返回的系统调用,一般是一些读写的样例,如pipe。终端设备。网络连接,典型的accept(), read(), write(), open(),select(),epoll()等。

适用于慢系统调用的基本规则是:当堵塞于某个慢系统调用的进程捕获到某个信号且对应的信号处理函数返回时,系统调用可能会返回一个EINTR错误,即将errno的值置为该值。

尽管有些内核会对该系统调用重新启动,但从可移植性的角度说,对EINTR处理是必须的。

注意对connect()不能如此处理。(UNP 5.9)

一个信号被信号处理函数响应,在处理过程中,该信号被屏蔽。标准的信号实现没有排队的功能,所以信号可能会被丢失。多个连续的信号来不及处理。

用waidpid()枚举检查不失为一种好的解决方法,见UNP 5.10

关于TOE(TCP offload engine)

本地抓包时一个小细节:

出现checksum incorrect。是由网卡上的TOE引擎造成的。

TOE wiki

用TCP/IP协议处理网络流量,要占用大量server资源。为了减轻server的压力,一种称为TCP减负引擎(TCP Offload Engine :TOE)的技术应运而生。

TCP减负引擎一般由软硬两部分组件构成,将传统的TIP/IP协议栈的功能进行延伸,把网络数据流量的处理工作所有转到网卡 上的集成硬件中进行,server仅仅承担TCP/IP控制信息的处理任务。

一般由操作系统的TCP/IP协议栈完毕TCP/UDP/IP校验和的计算工作,在网卡集成TOE的功能会包含计算checksum。

设置Rx Checksum Offload/Tx Checksum Offload为Enable之后,协议栈不再进行校验和的计算,而是由网卡自己完毕。

把网卡的属性改动一下就能够避免checksum incorrect,禁用 Checksum Offload。可修正checksum incorrect。代价是网络性能减少。

这个校验和的问题似乎相应用层的程序没有什么影响。。。(个人感觉)

Socket上的I/O处理

前文(标准I/O小结)提到的标准I/O库是ANSI C定义的一组高级输入输出函数,比起直接使用UNIX的系统I/O更加方便。

然而,标准I/O库没有提供读取文件元数据的方式,也不适合处理socket一类的特殊文件。





不足值(short count)

    定义,简而言之,我想处理10个字节,仅仅处理了6个。则不足值是6 。注意不是4

    因为内核中套接口的缓冲区大小有限和网络时延的原因,造成read和write实际处理的字节比预期的要少。其它如遇到EOF或从终端读取,也可能遇到不足值

读写磁盘文件时不会出现不足值





处理方式:

 UNP 3.9和CSAPP 10.9(RIO) 均给出了解决方法,借鉴之。例如以下代码:

int simon_send(int fd, char* buf, unsigned int n)
{
int left = n;
char *bufptr = buf;
int send_bytes; while (left >= 0)
{
if ((send_bytes = send(fd, bufptr, MAX_BUF_SIZE, 0)) < 0)
{
if (errno == EINTR) //iterrupted by signal , send again
send_bytes = 0;
else
break;
}
else if (!send_bytes) // EOF or socket shutdown by peer
break; left -= send_bytes;
bufptr += send_bytes;
} return n - left;
} int simon_recv(int fd, char* buf, unsigned int n)
{
int left = n;
char *bufptr = buf;
int recv_bytes; while (left >= 0)
{
if ((recv_bytes = recv(fd, bufptr, MAX_BUF_SIZE, 0)) < 0)
{
if (errno == EINTR)
recv_bytes = 0;
else
return -1;
}
else if (!recv_bytes)
break; left -= recv_bytes;
bufptr += recv_bytes;
} return n - left;
}

另,使用带标志MSG_WAITALL的recv也能一定程度上处理。

关于I/O的选择和比較。可见下图(摘自某ppt):

linux网络编程学习笔记之二 -----错误异常处理和各种碎碎(更新中)的更多相关文章

  1. 网络编程学习笔记(二)基于TCP的Socket编程

    1.Socket:英文意思插座.两个Java应用程序可以通过一个双向的网络通信连接实现数据交换,这个双向链路的一端称为一个Socket. 2.Socket通常用来实现client-server(客户端 ...

  2. linux网络编程学习笔记之五 -----并发机制与线程�

    进程线程分配方式 简述下常见的进程和线程分配方式:(好吧,我仅仅是举几个样例作为笔记...并发的水太深了,不敢妄谈...) 1.进程线程预分配 简言之,当I/O开销大于计算开销且并发量较大时,为了节省 ...

  3. linux网络编程学习笔记之四 -----多-threaded服务器

    对于使用过程中并发.通过实现更轻量级线程. 每个线程都是一个独立的逻辑流. 主题是CPU在执行调度的最小独立单位,这个过程是资源分配单元.当然,这是在微内核操作系统说.总之,这是唯一的一个操作系统内核 ...

  4. linux网络编程学习笔记之三 -----多进程并发服务端

    首先是fork()函数.移步APUE 8.3.  比較清晰的解释能够參考http://blog.csdn.net/lingdxuyan/article/details/4993883和http://w ...

  5. java网络编程学习笔记(二):socket详解

    1.Socket有多种构造方法,大多数构造方法在构造的时候就指定了连接的主机和端口号.当客户端的构造方法与服务器连接的时候,可能需要等待一段时间,因为需要建立连接.默认情况下,Socket的构造方法会 ...

  6. 转 网络编程学习笔记一:Socket编程

    题外话 前几天和朋友聊天,朋友问我怎么最近不写博客了,一个是因为最近在忙着公司使用的一些控件的开发,浏览器兼容性搞死人:但主要是因为这段时间一直在看html5的东西,看到web socket时觉得很有 ...

  7. linux基础命令学习笔记(二)

    linux基础命令学习笔记(二) 1.kill :终止进程  kill pid (唯一标示一个进程) kill -9  强制终止  kill -15 命令未结束不能终止 # ps aux 查看所有进程 ...

  8. Linux网络编程学习计划

    由于网络编程是很重要的一块,自己这一块也比较欠缺,只知道一些皮毛,从今天开始系统学习<Linux网络编程>一书,全书分为十四个章节: 第一章   概论   P1-16 第二章   UNIX ...

  9. Linux Shell编程学习笔记——目录(附笔记资源下载)

    LinuxShell编程学习笔记目录附笔记资源下载 目录(?)[-] 写在前面 第一部分 Shell基础编程 第二部分 Linux Shell高级编程技巧 资源下载 写在前面 最近花了些时间学习She ...

随机推荐

  1. 大数据- Hive

    构建在Hadoop之上的数据仓库,数据计算使用MR,数据存储使用HDFS         由于数据计算使用mapreduce.因此通经常使用于进行离线数据处理 Hive 定义了一种类 SQL 查询语言 ...

  2. Android JNI用于驱动測试

    硬件平台:S3C6410 操作系统:Ubuntu.windows 板子系统:Android 开发工具:jdk.ndk,eclipse 本次測试从linux内核模块编译開始.以S3C6410的pwm驱动 ...

  3. 怎样将OpenStack部署到Hadoop

    随着信息时代的快速发展,大数据技术和私有云环境都非常实用;只是,假设将两者结合在一起.企业会获得巨大的利润.虽然结合两者会让环境变得更复杂.企业仍然能够看到将 OpenStack 私有云和 Apach ...

  4. 从头认识java-17.4 具体解释同步(3)-对象锁

    这一章节我们接着上一章节的问题,给出一个解决方式:对象锁. 1.什么是对象锁? 对象锁是指Java为临界区synchronized(Object)语句指定的对象进行加锁,对象锁是独占排他锁. 2.什么 ...

  5. transform属性实现翻转效果

    transform:perspective(800px) rotateY(180deg);//翻转180度,透视800px; transition-delay: 0.3s;//过程时间 opacity ...

  6. Binary Search Algorithm

    二分查找代码: //============================================================================ // Name : Bin ...

  7. arguments对象----不定参数的实现方式

    function format(string) { var args = arguments; var pattern = new RegExp("%([1-" + argumen ...

  8. 本文介绍C# BitmapData

    本文介绍C# BitmapData,对于C# BitmapData,虽然BitmapData.Width还是等于Bitmap.Width,但大概是出于显示性能的考虑.   最近要转开发平台,正研究C# ...

  9. iOS_02_第一个C语言程序(理解编译、连接、运行)

    一.开发工具的选择 1. 可以用来写代码的工具:记事本.ULtraEdit.Vim.Xcode等. 2. 选择XCode的原因:苹果公司官方提供的开发利器.简化开发的工程.有高亮显示功能. 3. 使用 ...

  10. DC中为什么要用Uniquify?

    转自:http://blog.sina.com.cn/s/blog_68c493870101exl7.html 为了在layout中进行时钟树的综合,网表在DC中必须被uniquified.所谓uni ...