GithubHelp home page GithubHelp logo

evolution-gaming / resource-pool Goto Github PK

View Code? Open in Web Editor NEW
1.0 3.0 3.0 81 KB

Pool of cats-effect resources

Home Page: https://github.com/evolution-gaming/resource-pool

License: MIT License

Scala 100.00%
connection-pool pool resource resource-pool scala

resource-pool's Introduction

resource-pool

Build Status Coverage Status Codacy Badge Version

Pool of cats-effect resources

Features:

  • allocates resources on demand up to configured limit
  • deallocates resources if not active for a configured time
  • tries to minimize number of resources in the pool
  • uses first-in-first-out queue for tasks
  • shuts down gracefully after completing accumulated tasks
  • tolerates resource failures
  • supports cancellation

Example

import com.evolution.resourcepool.ResourcePool.implicits._

trait Connection {
  def query(): IO[Any]
}

def connection: Resource[IO, Connection] = ???

connection
  .toResourcePool( // you can convert any resource into the pool of resources
    maxSize = 10, // it will create up to `maxSize` connections 
    expireAfter = 1.minute) // pool will release connection if it is not used for 1 minute
  .use { connectionPool =>
    connectionPool
      .resource // this will get first available connection or allocate one
      .use { connection =>
        connection.query() // here you have access to the connection
      }
  }

Setup

addSbtPlugin("com.evolution" % "sbt-artifactory-plugin" % "0.0.2")

libraryDependencies += "com.evolution" %% "resource-pool" % "1.0.2"

resource-pool's People

Contributors

rtar avatar t3hnar avatar

Watchers

 avatar  avatar  avatar  avatar

Forkers

akilegaspi

resource-pool's Issues

Questions and code improvement suggestions

I have some questions and suggestions for improving the code. Feel free to ignore stylistic suggestions because they're subjective.

  1. I don't think we should expose IntHelper as a part of public API, I'd mark it as private[resourcepool].

  2. Do we really need implicits in our public API (IntHelper, ResourcePoolOps)? IMO introducing an implicit is justified only if it's going to be used a lot of times. How many times a user is going to construct a pool in his code? Probably once or twice. So I think it's much easier for the user to have an explicit method and not think about what they need to import.

  3. If I understand correctly, cancellation works differently for ResourcePoolOps.resource than for ResourcePool.get. cats.effect.Resource.apply makes acquire and release uncancelable. I think this change in cancellation semantics can be a surprise for the users, so I'd mention it in the scaladoc for ResourcePoolOps.resource.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.