使用curl_easy_perfotm造成阻塞,主要有以下几种情况
1.设置选项
该选项的含义为:整个下载必须在60s内完成,否则,操作会超时。但是超时之后,仅仅是下载或者上传停止,线程并不会结束
而是会阻塞于此。
2.设置选项
该选项含义为,下载速度不能低于50000字节/秒,如果低于该值,会停止下载,并试图断开连接。但是,同样的,线程将会阻塞于此
3.下载过程中,网络断开,例如,拔掉网线,下载会停止,但同样会造成阻塞。
解决方法:
1.使用muli_perform非阻塞式方式。该方法在多线程上传中也友好许多,只是比curl_easy_perfotm的使用略微复杂。
2.利用回调函数
回调函数返回一个非0的值,将会中断传输,返回错误码CURLE_ABORTED_BT_CALLBACK
例如:我们可以在回调函数中判断下载数据,在一定时间内数据量没有任何变化,可以认为网络连接已经断开
从而终止而避免线程阻塞。当然了,如果在该时间内,网络恢复(例如,网线重新插回),仍然可以继续传输数据。
但这些的 前提 是,不要设置前面提到的两个选项,因为在超时或者速度不满足的时候,就停止调用回调函数,也就没有机会
去判断网络是否断开之类。
3.编译curl库时,将ares(异步dns解析)编译进去。这个未验证。
注意:在设置timeout选项并且使用多线程上传时,很有可能会出现crash问题。即便设置了下面的选项
仍然有小概率出现该问题。
1.设置选项
该选项的含义为:整个下载必须在60s内完成,否则,操作会超时。但是超时之后,仅仅是下载或者上传停止,线程并不会结束
而是会阻塞于此。
2.设置选项
该选项含义为,下载速度不能低于50000字节/秒,如果低于该值,会停止下载,并试图断开连接。但是,同样的,线程将会阻塞于此
3.下载过程中,网络断开,例如,拔掉网线,下载会停止,但同样会造成阻塞。
解决方法:
1.使用muli_perform非阻塞式方式。该方法在多线程上传中也友好许多,只是比curl_easy_perfotm的使用略微复杂。
2.利用回调函数
回调函数返回一个非0的值,将会中断传输,返回错误码CURLE_ABORTED_BT_CALLBACK
例如:我们可以在回调函数中判断下载数据,在一定时间内数据量没有任何变化,可以认为网络连接已经断开
从而终止而避免线程阻塞。当然了,如果在该时间内,网络恢复(例如,网线重新插回),仍然可以继续传输数据。
但这些的 前提 是,不要设置前面提到的两个选项,因为在超时或者速度不满足的时候,就停止调用回调函数,也就没有机会
去判断网络是否断开之类。
3.编译curl库时,将ares(异步dns解析)编译进去。这个未验证。
注意:在设置timeout选项并且使用多线程上传时,很有可能会出现crash问题。即便设置了下面的选项
仍然有小概率出现该问题。