Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Invoca/fibered_mysql2

Repository files navigation

Coverage Status

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.

  1. The master branch supports fibers via Async before Rails 7.1.
  2. The v0.x-master branch 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.expire

Development

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.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 7