Table of Contents
Thread safe TCP Connection Pooling package in golang. For a server, a pool of connections can be maintained so requests to that server can use an available connection in the pool rather than waiting on initiating a connection. Using existing connections delivers requests to that server faster, and decreases connection setup and tear-down overhead. Connection Pooling also reduces the server load, which frees resources to handle other important tasks.
- golang
- Install Go
- Download the Go installer and run it.
- Verify your installation by running
$ go version
$ go get -t github.com/arjunmann73/TCPconnPool
func main() {
...
// Creating a pool with 5 initial connections and maximum connects possible = 30.
if pool, err := TCPconnPool.CreateConnectionPool(5, 30); err != nil {
log.Fatal("error in creation of connection pool")
}
...
...
// Retrieving a connection from the pool
if conn, err := pool.GetOneConnection(); err != nil {
log.Fatal("error in retriving a connection")
}
...
...
// Putting a connection back into the pool, does not close the underlying connection.
if err := pool.PutOneConnection(conn); err != nil {
log.Fatal("error in putting a connection back into the pool")
}
}
See the open issues for a list of proposed features (and known issues).
Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are greatly appreciated.
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
) - Commit your Changes (
git commit -m 'Add some AmazingFeature'
) - Push to the Branch (
git push origin feature/AmazingFeature
) - Open a Pull Request
Distributed under the MIT License. See LICENSE
for more information.