The AWS SDK for Ruby's release of modularization as a feature means we are major version bumping the SDK. While the SDK interface you're using for V2 remains unchanged, for packaging reasons (shifting of which code is in which package, and preventing V2 and V3 from running in the same process and creating unpredictable runtime behavior) you'll need to make some changes to your Gemfile
and possibly to require
statements in code. This guide will walk you through some common upgrade scenarios.
Most users of the SDK have a setup similar to this:
# Gemfile
gem 'aws-sdk', '~> 2'
# Code Files
require 'aws-sdk'
s3 = Aws::S3::Client.new
ddb = Aws::DynamoDB::Client.new
# etc.
If that's you, the quickest migration path is to simply change your Gemfile
like so:
# Gemfile
gem 'aws-sdk', '~> 3'
However, this will pull in a large number of new dependencies, as each service client has its own individual gem. As a direct user, you can also change to using only the service gems actually required by your project, which is the recommended path. This would involve a change to both your Gemfile
, and to the code files where your require
statements live, like so:
# Gemfile
gem 'aws-sdk-s3', '~> 1'
gem 'aws-sdk-dynamodb', '~> 1'
# Code Files
require 'aws-sdk-s3'
require 'aws-sdk-dynamodb'
s3 = Aws::S3::Client.new
ddb = Aws::DynamoDB::Client.new
# etc.
As you can see, only gems and require statements need to be changed - the modules, classes, and methods are backwards compatible.
This is VERY similar to if you're a user of aws-sdk
. The V3 release provides an update to aws-sdk-resources
as well, so your initial gemfile change is just the major version, as above. Of course, we still recommend moving over to service-level gems when you can.
The aws-sdk-core
gem has been a popular choice for V2 users, providing the basic SDK client experience without the addition of resource abstractions. However, in V2 of the SDK, this gem no longer contains any service clients. Therefore, you'll need to make changes to both your Gemfile
and to require
statements to upgrade. Consider this usage pattern:
# Gemfile
gem 'aws-sdk-core', '~> 2'
# Code Files
require 'aws-sdk-core'
s3 = Aws::S3::Client.new
ddb = Aws::DynamoDB::Client.new
# etc.
The minimum change needed would be to change your Gemfile
to use aws-sdk
or aws-sdk-resources
version 3, and change your require
statements to match. For example:
# Gemfile
gem 'aws-sdk', '~> 3'
# Code Files
require 'aws-sdk'
s3 = Aws::S3::Client.new
ddb = Aws::DynamoDB::Client.new
# etc.
Of course, we still recommend moving over to using service-specific gems as specified above. The end state is the same.
If you are the author of a library which has the AWS SDK for Ruby V2 as a dependency, you should also upgrade, and provide a reference to this guide to help your users smoothly transition over. You have two options for providing an upgrade path.
The preferred upgrade path is to switch to only the service gems your library actually uses. For example, a library like our aws-record
gem will only depend on the aws-sdk-dynamodb
gem, adding other gems only when actually used by the library.
# Gemspec File
Gem::Specification.new do |spec|
# ...
spec.add_dependency('aws-sdk-dynamodb', '~> 1')
# ...
end
Your users will need to follow the upgrade paths above if they are current users of V2 of the AWS SDK for Ruby.
The simplest upgrade path is to open up your dependency on aws-sdk
or aws-sdk-resources
like so:
# Gemspec File
Gem::Specification.new do |spec|
# ...
spec.add_dependency('aws-sdk', '>= 2.0', '< 4')
# ...
end
This means users who don't have an AWS SDK dependency will end up using V3, while users who are using V2 won't have to make any changes. This is workable since the public API is backwards compatible, but it's not ideal in that you'll be adding about 100 gems to the dependency chain of your users, most of which they do not need or use.