[ 
https://issues.apache.org/jira/browse/THRIFT-2207?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13776815#comment-13776815
 ] 

Vaibhav Gumashta commented on THRIFT-2207:
------------------------------------------

Heap dump of the main thread that went OOM:
main" prio=5 tid=1 RUNNABLE
        at java.lang.OutOfMemoryError.<init>(OutOfMemoryError.java:25)
        at 
org.apache.thrift.transport.TSaslTransport.receiveSaslMessage(TSaslTransport.java:181)
        at 
org.apache.thrift.transport.TSaslTransport.open(TSaslTransport.java:288)
        at 
org.apache.thrift.transport.TSaslClientTransport.open(TSaslClientTransport.java:37)
           Local Variable: org.apache.thrift.transport.TSaslClientTransport#1
        at 
org.apache.hive.service.cli.thrift.TestThriftHttpCLIService.testIncompatibeClientServer(TestThriftHttpCLIService.java:121)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
           Local Variable: sun.reflect.NativeMethodAccessorImpl#16
        at 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
           Local Variable: sun.reflect.DelegatingMethodAccessorImpl#22
        at java.lang.reflect.Method.invoke(Method.java:597)
           Local Variable: java.lang.reflect.Method#49
        at 
org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45)
        at 
org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
           Local Variable: org.junit.runners.model.FrameworkMethod$1#1
        at 
org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42)
           Local Variable: java.lang.Object[]#2425
           Local Variable: 
org.apache.hive.service.cli.thrift.TestThriftHttpCLIService#1
        at 
org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
           Local Variable: org.junit.internal.runners.statements.InvokeMethod#1
        at 
org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
           Local Variable: java.util.AbstractList$Itr#2
           Local Variable: org.junit.internal.runners.statements.RunBefores#2
        at 
org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:30)
           Local Variable: java.util.ArrayList#885
        at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:263)
           Local Variable: org.junit.internal.runners.model.EachTestNotifier#2
           Local Variable: org.junit.internal.runners.statements.RunAfters#2
        at 
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:68)
           Local Variable: org.junit.runner.Description#5
        at 
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47)
        at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)
        at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)
           Local Variable: org.junit.runners.ParentRunner$3#1
           Local Variable: org.junit.runners.ParentRunner$1#1
        at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)
           Local Variable: java.util.AbstractList$Itr#3
           Local Variable: org.junit.runners.model.FrameworkMethod#3
        at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)
        at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)
           Local Variable: org.junit.runners.ParentRunner$2#1
        at 
org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
           Local Variable: org.junit.internal.runners.statements.RunBefores#1
           Local Variable: java.util.AbstractList$Itr#1
        at 
org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:30)
           Local Variable: java.util.ArrayList#1
        at org.junit.runners.ParentRunner.run(ParentRunner.java:300)
           Local Variable: org.junit.internal.runners.statements.RunAfters#1
           Local Variable: org.junit.internal.runners.model.EachTestNotifier#1
           Local Variable: org.junit.runner.notification.RunNotifier#1
           Local Variable: org.junit.runners.BlockJUnit4ClassRunner#1
        at junit.framework.JUnit4TestAdapter.run(JUnit4TestAdapter.java:39)
           Local Variable: junit.framework.TestResult#1
        at 
org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.run(JUnitTestRunner.java:518)
           Local Variable: java.io.ByteArrayOutputStream#2
           Local Variable: junit.framework.JUnit4TestAdapter#1
           Local Variable: java.io.ByteArrayOutputStream#1
        at 
org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.launch(JUnitTestRunner.java:1052)
           Local Variable: 
org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner#1
        at 
org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.main(JUnitTestRunner.java:906)
           Local Variable: java.lang.String[]#9
           Local Variable: java.util.Properties#3
           Local Variable: java.util.Properties#1
           Local Variable: 
org.apache.tools.ant.taskdefs.optional.junit.JUnitTest#1

                
> Thrift goes OOM when used in an HTTP over Thrift setting
> --------------------------------------------------------
>
>                 Key: THRIFT-2207
>                 URL: https://issues.apache.org/jira/browse/THRIFT-2207
>             Project: Thrift
>          Issue Type: Bug
>          Components: Java - Library
>    Affects Versions: 0.9
>            Reporter: Vaibhav Gumashta
>
> I am trying to use HTTP over thrift for HIVE. On the server side, I'm 
> creating a Jetty instance and creating an instance of ThriftHttpServlet to 
> handle the request. However, on client side, if I create a TSocket transport 
> (wrapped in a TSaslClientTransport due to this: 
> [THRIFT-1774|https://issues.apache.org/jira/browse/THRIFT-1774]), 
> transport.open goes out of memory. Although Jetty throws an exception on 
> trying to handle a non-HTTP message, it doesn't seem to be handles in 
> TSaslTransport#receiveSaslMessage.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

Reply via email to