开发者社区> 问答> 正文

odps数据同步时,发生以下错误

Exception in thread "taskGroup-0" com.alibaba.datax.common.exception.DataXException: Code:[OdpsWriter-09], Description:[写入数据到 ODPS 目的表失败.]. - ODPS 目的表写 block:1,048 失败, uploadId=[2017020314311962389a0a00a7ff40]. 请联系 ODPS 管理员处理. - java.io.IOException: Error writing request body to server

展开
收起
jason2011 2017-02-04 17:52:34 5388 0
1 条回答
写回答
取消 提交回答
  • 严重: servlet.service() for servlet jsp threw exception。出现此错误一般都是在jsp中使用了输出流,没有妥善处理好的原因。
    原因:
    在tomcat中jsp编译成servlet之后在函数_jspservice(httpservletrequest request, httpservletresponse response)的最后
    有一段这样的代码
    finally {
    if (_jspxfactory != null) _jspxfactory.releasepagecontext(_jspx_page_context);
    }
    这里是在释放在jsp中使用的对象,会调用response.getwriter(),因为这个方法是和
    response.getoutputstream()相冲突的!所以会出现以上这个异常。

    解决的办法
    在使用完输出流以后调用以下两行代码即可:
    out.clear();
    out = pagecontext.pushbody();
    java.io.ioexception: stream closed出现这个异常的原因:举个例子
    bufferedreader input1 = new bufferedreader(new inputstreamreader(system.in));
    bufferedreader input2 = new bufferedreader(new inputstreamreader(system.in));
    这两句话中的input1和input2都是由system.in封装而来。这是设计模式中的装饰模式的应用,顾名思义,装饰模式就是对最原始的东西进行装饰,只改变了外表,但实质并没有改变。system.in就是最原始的东西,input1和input2只是他被装饰后的外表,所以程序中的input1和input2的实质上都是system.in。调用input1.close(),会自动调用input1的实质system.in.close(),所以对于input2来说他的实质system.in已经关闭掉,所以...

    学习:http://blog.sina.com.cn/s/blog_59d6717c0100f9bz.html
    多个线程索引同一个input stream,当某一个thread在执行完之后,把这个inputstream关闭了;而此时正在从这个input stream流中读取信息的线程就会抛出 java.io.ioexception: stream closed 异常。

    终于找到这个异常的根源所在,原来是两个页面同时调用一个jsp,这个jsp中的内建对象

    out在执行out.close()时发生的异常,也就是当某一个thread(对应一个jsp)在执行完之
    后,把这个stream关闭了;而此时正在从这个stream中读取信息的另一个jsp就会抛出
    java.io.ioexception: stream closed 异常。

    2019-07-17 20:45:45
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
大数据AI一体化的解读 立即下载
极氪大数据 Serverless 应用实践 立即下载
大数据&AI实战派 第2期 立即下载