Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[fix][proxy] Fix connection read timeout handling in Pulsar Proxy #20014

Conversation

lhotari
Copy link
Member

@lhotari lhotari commented Apr 5, 2023

Motivation

  • The behavior of the custom ProxyReadTimeoutHandler is not defined in any way and based on the code will result in bad behavior and proxy connections being closed

Modifications

Documentation

  • doc
  • doc-required
  • doc-not-needed
  • doc-complete

- The behavior of the custom ProxyReadTimeoutHandler is not defined in any way
  and based on the code will result in bad behavior and proxy connections being closed
- Remove ProxyReadTimeoutHandler that was added as part of Zero copy support (apache#15678)
  - replace with a solution where readTimeoutHandler is remove from the pipeline
@lhotari lhotari added type/bug The PR fixed a bug or issue reported a bug area/proxy labels Apr 5, 2023
@lhotari lhotari self-assigned this Apr 5, 2023
@github-actions github-actions bot added the doc-not-needed Your PR changes do not impact docs label Apr 5, 2023
@lhotari lhotari added release/2.11.2 ready-to-test and removed doc-not-needed Your PR changes do not impact docs labels Apr 5, 2023
@lhotari
Copy link
Member Author

lhotari commented Apr 5, 2023

/pulsarbot rerun-failure-checks

@github-actions github-actions bot added the doc-not-needed Your PR changes do not impact docs label Apr 5, 2023
Copy link
Member

@michaeljmarshall michaeljmarshall left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

Copy link
Contributor

@eolivelli eolivelli left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree

+1

@michaeljmarshall
Copy link
Member

Test failure looks potentially related to the PR:

  Error:  Tests run: 17, Failures: 1, Errors: 0, Skipped: 5, Time elapsed: 124.408 s <<< FAILURE! - in org.apache.pulsar.broker.service.TopicTerminationTest
  Error:  testTerminateWhilePublishing(org.apache.pulsar.broker.service.TopicTerminationTest)  Time elapsed: 20.039 s  <<< FAILURE!
  org.testng.internal.thread.ThreadTimeoutException: Method org.apache.pulsar.broker.service.TopicTerminationTest.testTerminateWhilePublishing() didn't finish within the time-out 20000
  	at java.base@17.0.6/jdk.internal.misc.Unsafe.park(Native Method)
  	at java.base@17.0.6/java.util.concurrent.locks.LockSupport.park(LockSupport.java:211)
  	at java.base@17.0.6/java.util.concurrent.CompletableFuture$Signaller.block(CompletableFuture.java:1864)
  	at java.base@17.0.6/java.util.concurrent.ForkJoinPool.unmanagedBlock(ForkJoinPool.java:3463)
  	at java.base@17.0.6/java.util.concurrent.ForkJoinPool.managedBlock(ForkJoinPool.java:3434)
  	at java.base@17.0.6/java.util.concurrent.CompletableFuture.waitingGet(CompletableFuture.java:1898)
  	at java.base@17.0.6/java.util.concurrent.CompletableFuture.get(CompletableFuture.java:2072)
  	at app//org.apache.pulsar.broker.service.TopicTerminationTest.testTerminateWhilePublishing(TopicTerminationTest.java:172)
  	at java.base@17.0.6/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  	at java.base@17.0.6/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
  	at java.base@17.0.6/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  	at java.base@17.0.6/java.lang.reflect.Method.invoke(Method.java:568)
  	at app//org.testng.internal.invokers.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:139)
  	at app//org.testng.internal.invokers.InvokeMethodRunnable.runOne(InvokeMethodRunnable.java:47)
  	at app//org.testng.internal.invokers.InvokeMethodRunnable.call(InvokeMethodRunnable.java:76)
  	at app//org.testng.internal.invokers.InvokeMethodRunnable.call(InvokeMethodRunnable.java:11)
  	at java.base@17.0.6/java.util.concurrent.FutureTask.run(FutureTask.java:264)
  	at java.base@17.0.6/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
  	at java.base@17.0.6/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
  	at java.base@17.0.6/java.lang.Thread.run(Thread.java:833)

@lhotari
Copy link
Member Author

lhotari commented Apr 6, 2023

Test failure looks potentially related to the PR:

  Error:  Tests run: 17, Failures: 1, Errors: 0, Skipped: 5, Time elapsed: 124.408 s <<< FAILURE! - in org.apache.pulsar.broker.service.TopicTerminationTest

@michaeljmarshall It's most likely yet another flaky one since this PR contains only proxy changes. Broker tests don't use the proxy.

@nodece nodece merged commit dd05408 into apache:master Apr 6, 2023
lhotari added a commit that referenced this pull request Apr 6, 2023
@Technoboy- Technoboy- added this to the 3.0.0 milestone Apr 6, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/proxy cherry-picked/branch-2.11 doc-not-needed Your PR changes do not impact docs ready-to-test release/2.11.1 type/bug The PR fixed a bug or issue reported a bug
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants