-
Notifications
You must be signed in to change notification settings - Fork 31
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
For a long-running connections (for example ones coming from a load-balancer), we used to wait for body text stream to complete and therefore hanged the request infinitely. This caused performance issues. Now, we detect if there was no activity for a given body text for the period of time and short-circuit the processing early.
- Loading branch information
Showing
14 changed files
with
89 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
29 changes: 29 additions & 0 deletions
29
core/src/main/scala/com.snowplowanalytics.snowplow.collector.core/Pipes.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
/** | ||
* Copyright (c) 2013-present Snowplow Analytics Ltd. | ||
* All rights reserved. | ||
* | ||
* This software is made available by Snowplow Analytics, Ltd., | ||
* under the terms of the Snowplow Limited Use License Agreement, Version 1.0 | ||
* located at https://docs.snowplow.io/limited-use-license-1.0 | ||
* BY INSTALLING, DOWNLOADING, ACCESSING, USING OR DISTRIBUTING ANY PORTION | ||
* OF THE SOFTWARE, YOU AGREE TO THE TERMS OF SUCH LICENSE AGREEMENT. | ||
*/ | ||
package com.snowplowanalytics.snowplow.collector.core | ||
|
||
import scala.concurrent.duration.FiniteDuration | ||
import cats.effect.Async | ||
import fs2.{Pipe, Pull} | ||
|
||
object Pipes { | ||
def timeoutOnIdle[F[_]: Async, A](duration: FiniteDuration): Pipe[F, A, A] = | ||
_.pull.timed { timedPull => | ||
def go(timedPull: Pull.Timed[F, A]): Pull[F, A, Unit] = | ||
timedPull.timeout(duration) >> | ||
timedPull.uncons.flatMap { | ||
case Some((Right(elems), next)) => Pull.output(elems) >> go(next) | ||
case _ => Pull.done | ||
} | ||
|
||
go(timedPull) | ||
}.stream | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
22 changes: 22 additions & 0 deletions
22
core/src/test/scala/com.snowplowanalytics.snowplow.collector.core/PipesSpec.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
package com.snowplowanalytics.snowplow.collector.core | ||
|
||
import scala.concurrent.duration._ | ||
import org.specs2.mutable.Specification | ||
import cats.effect.IO | ||
import cats.effect.unsafe.implicits.global | ||
import fs2.Stream | ||
|
||
class PipesSpec extends Specification { | ||
|
||
"Pipes#timeoutOnIdle" should { | ||
"allow terminating a stream early when idle" in { | ||
Stream | ||
.emits[IO, Int](Vector(1, 2, 3)) | ||
.onComplete(Stream.empty[IO].delayBy(20.seconds)) | ||
.through(Pipes.timeoutOnIdle(100.millis)) | ||
.compile | ||
.count | ||
.unsafeRunSync() must beEqualTo(3) | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters