HttpURLConnection超时和IO异常处理

最近同步数据的时候发现了一个问题,我本身后台插入数据后给其他部门后台做同步。说简单一点其实就是调用对方提供的接口,进行HTTP请求调用。然后后面发现问题了。HTTP请求的话,有可能请求超时,中断失败,IO异常其实都有可能,如果是平时打开一个网页还好,打不开的时候,你会关掉,或者他页面给你显示信息。但是同步,不可以这样做,一旦请求失败,必须让数据正确的同步,今天才意识到这个问题的重要性。


[java]  view plain  copy
  1. String httpUrl = "https://www.baidu.com/s?ie=UTF-8&tn=90594569_hao_pg&wd=1";  
  2. URL url = null;  
  3. HttpURLConnection httpConn = null;  
  4. String result = "";  
  5. try {  
  6.     String address = httpUrl;  
  7.     url = new URL(address);  
  8.     httpConn =  (HttpURLConnection) url.openConnection();  
  9.       
  10.     //A URL connection can be used for input and/or output. Set the   
  11.     //DoInput flag to true if you intend to use the URL connection for input,  
  12.     //false if not. The default is true.   
  13.       
  14.     //URL连接可用于input或output。如果想用URL连接输入,设置DoInput标签为true。  
  15.     //输入和输出是针对计算机的,如果以程序员的角度考虑,经常弄混。  
  16.     //input输入,output输出,那么不是从output里read,input中write吗,其实相反  
  17.     //input输入进计算机,计算机才能读,所以是从input read,而output是计算机输出,通过output write。  
  18.     httpConn.setDoOutput(false);  
  19.     //所以如果setDoInput(false),想从URLConnection读取时不能读取  
  20.     //Cannot read from URLConnection if doInput=false (call setDoInput(true))   
  21.     httpConn.setDoInput(true);  
  22.       
  23.     //连接建立超时时间还有读取数据超时时间,  
  24.     httpConn.setConnectTimeout(600000);  
  25.     httpConn.setReadTimeout(600000);  
  26.     httpConn.setRequestMethod("GET");  
  27.     httpConn.connect();  
  28.     
  29.     //获取状态码  
  30.     int code = httpConn.getResponseCode();  
  31.     System.out.println(code);  
  32.     //读http请求响应  
  33.     BufferedReader reader = new BufferedReader(new InputStreamReader(httpConn.getInputStream()));  
  34.     String line;  
  35.     while ((line = reader.readLine()) != null)  
  36.     {  
  37.         result = result + line+"\n";  
  38.     }  
  39.     System.out.println(result);  
  40.     //关闭IO和连接  
  41.     reader.close();  
  42.     httpConn.disconnect();  
  43. }  
  44. catch(Exception e){  
  45.     log.error(e);  
  46. }  
  47. finally{  
  48.     if(httpConn!=null)  
  49.         httpConn.disconnect();  
  50. }  

代码看上去写的没什么,该释放资源的地方也释放了。该打日志输出的也打了。
其实问题就是异常的处理。之前以为一些东西没有同步过去是因为连接超时的问题。
所以特地捕获SocketTimeoutException异常,后面看了日志之后,发现是同步接口那边服务器的问题,
报了502错误。其实异常是IO异常。


无论是那种情况,我们都要在出现这种问题之后,再次地把请求发送过去,根据接口返回的结果,确认对方已经同步到。
如果服务器暂时性的出了问题,我们可以暂停一小段时间后,然后再次请求。


所以暂时想到的方法是,由于同步的实时性要求不高,那么可以间隔的时间可以长一点。
然后循环,另起线程,每次间隔5分钟,直至结果正常。


[java]  view plain  copy
  1. catch(Exception e){  
  2.     for (int i = 0; i < 6; i++) {  
  3.         Thread t = new Thread(){public void run(){get();}};  
  4.         t.start();  
  5.         if(result.equals("ok")){  
  6.             break;  
  7.         }  
  8.         try {  
  9.             Thread.sleep(300000);  
  10.         } catch (InterruptedException e2) {  
  11.             log.error(e2);  
  12.         }  
  13.     }  
  14.     log.error(e);  
  15. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值