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
严重: 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 异常。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。