从App Engine Java flexible启动Dataflow模板时管道损坏

时间:2017-09-26 16:04:53

标签: java google-app-engine google-cloud-dataflow

我为我的一个项目编写了一个服务来创建和启动数据流 - 工作模板"来自" Google App Engine",结合"任务队列"。

只有事先成功创建模板才能启动模板。我刚才意识到,有时会抛出以下错误。这是gae中的一个问题,还是我可以采取任何措施来防止这种情况发生?在一些尝试之前和之后我都没有看到这个,模板似乎运行。

stacktrace:

java.net.SocketException: Broken pipe (Write failed) at 
java.net.SocketOutputStream.socketWrite0(Native Method) at 
java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:111) at 
java.net.SocketOutputStream.write(SocketOutputStream.java:155) at 
sun.security.ssl.OutputRecord.writeBuffer(OutputRecord.java:431) at 
sun.security.ssl.OutputRecord.write(OutputRecord.java:417) at 
sun.security.ssl.SSLSocketImpl.writeRecordInternal(SSLSocketImpl.java:876) at 
sun.security.ssl.SSLSocketImpl.writeRecord(SSLSocketImpl.java:847) at 
sun.security.ssl.SSLSocketImpl.writeRecord(SSLSocketImpl.java:717) at 
sun.security.ssl.Handshaker.sendChangeCipherSpec(Handshaker.java:1124) at 
sun.security.ssl.ClientHandshaker.sendChangeCipherAndFinish(ClientHandshaker.java:1216) at 
sun.security.ssl.ClientHandshaker.serverHelloDone(ClientHandshaker.java:1128) at 
sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:348) at 
sun.security.ssl.Handshaker.processLoop(Handshaker.java:1026) at 
sun.security.ssl.Handshaker.process_record(Handshaker.java:961) at 
sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1062) at 
sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1375) at 
sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1403) at 
sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1387) at 
sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:559) at 
sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185) at 
sun.net.www.protocol.http.HttpURLConnection.getOutputStream0(HttpURLConnection.java:1316) at 
sun.net.www.protocol.http.HttpURLConnection.getOutputStream(HttpURLConnection.java:1291) at 
sun.net.www.protocol.https.HttpsURLConnectionImpl.getOutputStream(HttpsURLConnectionImpl.java:250) at 
com.google.api.client.http.javanet.NetHttpRequest.execute(NetHttpRequest.java:77) at 
com.google.api.client.http.HttpRequest.execute(HttpRequest.java:972) at 
com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:419) at 
com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:352) at 
com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:469) at 

--> Google doesn't like me

xy.myname.myproject.importhelp.dataflow.DataflowUtil.startTemplate(DataflowUtil.java:113) at 

--> start the template, which usually works (also most templates started while this error was thrown)

xy.myname.myproject.importhelp.webservices.Jobs.startStandardTemplate(Jobs.java:227) at 

---> No depending Jobs need to be checked

xy.myname.myproject.importhelp.webservices.Jobs.doPost(Jobs.java:123) at 

---> Here starts my code to receive template information

javax.servlet.http.HttpServlet.service(HttpServlet.java:707) at 
javax.servlet.http.HttpServlet.service(HttpServlet.java:790) at 
org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:833) at 
org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:535) at 
org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143) at 
org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:548) at 
org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:132) at 
org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java:190) at 
org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:1595) at 
org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java:188) at 
org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1253) at 
org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java:168) at 
org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:473) at 
org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:1564) at 
org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java:166) at 
org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1155) at 
org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141) at 
org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:219) at 
org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:126) at 
org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:132) at 
org.eclipse.jetty.server.Server.handle(Server.java:564) at 
org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:317) at 
org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:251) at 
org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:279) at 
org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:110) at 
org.eclipse.jetty.io.ChannelEndPoint$2.run(ChannelEndPoint.java:124) at 
org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:672) at 
org.eclipse.jetty.util.thread.QueuedThreadPool$2.run(QueuedThreadPool.java:590) at 
java.lang.Thread.run(Thread.java:748)

0 个答案:

没有答案