Skip to content
This repository has been archived by the owner on Sep 11, 2019. It is now read-only.

Latest commit

 

History

History
41 lines (24 loc) · 1.54 KB

README.md

File metadata and controls

41 lines (24 loc) · 1.54 KB

Akka PostgreSQL

TODO / REF:

  • Better Connection Handling
  • Restart Flow (Akka 2.5.4)
  • correct Backpressure, currently it will fail with an overflow, however the correct implementation would backpressure/drop upstream (and or throttle)
  • Java API
  • Tests
  • More complete API, i.e. Prepared Statements (and their return), Statements with Return, Transactions
  • Query DSL

IO Monad: https://github.com/getquill/quill/commit/cee378c19f981fce9e74b079cb700d92dcd6c786

Description

Everything here is likely to change and won't be MiMa compatible in any way!!!

Actually this is a PostgreSQL client built with akka-stream and is fully non-blocking, i.e. everything will return a Future.

The basic implementation is as follow:

Broadcast Hub ~> dynamic Connection ~> Merge Hub

Which means that any client could attach itself to the "output stream" i.e. can log any message that the server will send or can actually create multiple sources to the client.

Motivation

The basic idea is to use PostgreSQL as a PubSub implementation. Currently we don't want to add another server like redis to do it, just for PubSub or recreate or HA solution based on redis, that's why we implemented this.

Reference Implementation of Parsers:

Reference: https://github.com/mauricio/postgresql-async

Command Complections

if we issue any command we will always get a ReadyForQuery which will indicate that we are now ready to process the next query.