All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Reenable TCP nodelay on the server connection, impacted performance
- 0.8.3 was tagged 2023-02-15 but a proper release was never created (release workflow failed)
- 0.8.4 was tagged (and released) 2023-03-01 but it was built without bumping the version, so it reports 0.8.3
- 0.8.5 was tagged 2023-03-01 but a proper release was never created (release workflow did not run)
- Build RPM packages for Fedora 37
- Build DEB packages for Ubuntu 22.04
- Locks around socket writes
- Default systemd service file uses /etc/amqproxy.ini
- Set a connection name on upstream connections
- New amq-protocol.cr without a StringPool, which in many cases caused a memory leak
- Prevent race conditions by using more locks
- Don't disable nagles algorithm (TCP no delay), connections are faster with the algorithm enabled
- idle_connection_timeout can be specificed as an environment variable
- Container image uses libssl1.1 (from libssl3 which isn't fully supported)
- Inform clients of product and version via Start frame
- Check upstream connection before lending it out
- Graceful shutdown, waiting for connections to close
- Don't try to reuse channels closed by server for new connections
- Notify upstream that consumer cancellation is supported
- Reuse a single TLS context for all upstream TLS connections, saves memory
- Fixed broken OpenSSL in the Docker image
- Build package for Debian 11 (bullseye) (#73)
- Bump dependencies
- Fix bug with connection pool shrinking (#70)
- Support for config files (#64)
This version never got built.
- Same as 0.5.10, only to test release automation
- Include error cause in upstream error log (#67)
- TLS cert verification works for container images again
- Don't parse timestamp value, it can be anyting
- Docker image for arm64
- dockerfile syntax error
- --idle-connection-timeout option, for how long an idle connection the pool will stay open
- Wait at least 5s before closing an upstream connection
- Close client socket on write error
- Close Upstreadm socket if client disconnects while deliverying body as state is then unknown
- Skip body io if no client to deliver to
- Better client disconnect handling
- Name all fibers for better debugging
- Not stripping binaries in Dockerfile
- Crystal 1.0.0
- Heartbeat support for upstreams, uses the server suggest heartbeat interval
- Improved connection closed handling