FiberedMysql2
FiberedMysql2 adds Fiber support to ActiveRecord::ConnectionAdapters::Mysql2Adapter for Rails versions < 7.1.
This is a stop-gap until Rails 7.1, which adds isolation_level: :fiber to ActiveRecord connection pooling.
We have split the fibered_mysql2 gem into two separate branches.
- The
masterbranch supports fibers via Async before Rails 7.1. - The
v0.x-masterbranch supports fibers via EventMachine+Synchrony for all Rails versions.
Use the v0.x-master branch at https://github.com/Invoca/fibered_mysql2/tree/v0.x-master if working on supporting EventMachine.
Installation
Add this line to your application's Gemfile:
gem 'fibered_mysql2'And then execute:
$ bundle
Or install it yourself as:
$ gem install fibered_mysql2
Support
Tested with Rails 6.0, Ruby 3, and Async.
Usage
Behaves the same as ActiveRecord::ConnectionAdapters::Mysql2Adapter but with using Fibers rather than Threads for tracking ownership when leasing/expiring connections.
connection = FiberedMysql2::FiberedMysql2Adapter.new(client, logger, options, config)
connection.lease
connection.expireDevelopment
After checking out the repo, run bin/setup to install dependencies. Then, run rake spec to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/invoca/fibered_mysql2.