Skip to main content

RubyGems Repositories

RubyGems (rubygems.org) is the leading gem hosting service supporting the Ruby community. The Ruby programming language uses the Gem tool as its package management solution. Packages are called gems allowing for ease of use when distributing programs or libraries.

The following features are included as part of gem repository support:

  • Proxy repository for connecting to remote gem repositories and caching gems on the repository manager to avoid duplicate downloads and wasted bandwidth and time

  • Hosted repository for hosting gem packages and providing them to users

  • Repository groups for merging multiple hosted and proxy gem repositories and easily exposing them as one URL to all users

Requirements

Gem repositories are supported as of version NXRM 3.1 and higher however major changes to the Gem tooling API forced an update to how Nexus Repository communicates with RubyGem repositories and clients.

We recommend the following minimum versions:

  • Nexus Repository: release 3.53.0 or later

  • RubyGem client: version 3.4.12 or later

Proxying RubyGem Repositories

Proxy a gem repository by creating a new repository using the recipe rubygems (proxy)

Minimal configuration steps are:

  • Define Name

  • Define URL for Remote storage e.g. https://rubygems.org

  • Pick a Blob store for Storage

Private Hosted RubyGem Repositories

A private gem repository can be used as a target to push your gems as well as third-party gems and subsequently provide them to your users. It is a good practice to create two separate hosted gem repositories for internal and third-party gems.

To create a hosted gem repository, create a new repository using the recipe rubygems (hosted).

Minimal configuration steps are:

  • Define Name

  • Select a Blob store for Storage

The gem repository information is immediately updated as gems are pushed to the repository or deleted from it.

Grouping RubyGem Repositories

A repository group is the recommended way to expose all your gem repositories to your users, without needing any further client-side configuration after initial setup. A repository group allows you to expose the aggregated content of multiple proxies and hosted gem repositories with one URL to gem and other tools.

To create a gem group repository, create a new repository using the recipe rubygems (group).

Minimal configuration steps are:

  • Define Name

  • Select Blob store for Storage

  • Add Gems repositories to the Members list in the desired order

A typical, useful example would be to group the proxy repository that proxies the RubyGems repository, a hosted gem repository with internal software gems, and another hosted gem repository with third-party gems.

Using the repository URL of the repository group as your gem repository URL in your client tool gives you access to the gems in all member repositories with one URL.

Any gem added to a hosted or proxy repository becomes immediately available to all users of the gem repository group. Adding a new proxy gem repository to the group makes all gems in that proxy immediately available to the users as well.

Using RubyGem Repositories

Once you have configured the repository manager with the gem repository group, you can add it to your configuration for the gem command line tool.

You can add the URL of a gem repository or group using the URL from the repository list with a command like:

$ gem sources --add http://localhost:8081/repository/rubygems-group/

In order to take full advantage of the repository manager and the proxying of gems, you should remove any other sources. By default, https://rubygems.org/ is configured in gem and this can be removed with:

$ gem sources --remove https://rubygems.org/

Clear the local cache with:

$ gem sources -c 

To check a successful configuration you can run:

$ gem sources
*** CURRENT SOURCES ***


http://localhost:8081/repository/rubygems-group/ 

With this setup completed, any installation of new gems with gem install <gem_name> (e.g. gem install rake) will be downloaded from the repository manager.

If your repository manager requires authentication, you have to add the Basic Auth authentication details to the configuration of the source:

$ gem sources --add http://myuser:mypassword@localhost:8081/repository/rubygems-group/

If you are using the popular Bundler tool for tracking and installing gems, you need to install it with the gem:

$ gem install bundle
Fetching: bundler-1.7.7.gem (100%)
Successfully installed bundler-1.7.7
Fetching: bundle-0.0.1.gem (100%)
Successfully installed bundle-0.0.1
Parsing documentation for bundle-0.0.1
Installing ri documentation for bundle-0.0.1
Parsing documentation for bundler-1.7.7
Installing ri documentation for bundler-1.7.7
Done installing documentation for bundle, bundler after 4 seconds
2 gems installed 

To use the repository manager with Bundler, you have to configure the gem repository group as a mirror:

$ bundle config mirror.http://rubygems.org
http://localhost:8081/repository/rubygems-group/

You can confirm the configuration succeeded by checking the configuration:

$ bundle config
Settings are listed in order of priority. The top value will be used.
mirror.http://rubygems.org
Set for the current user (/Users/manfred/.bundle/config): "http://localhost:8081/repository/rubygems-group" 

With this configuration completed, you can create a Gemfile and run bundle install as usual and any downloads of gem files will be using the gem repository group configured as a mirror.

Pushing Gems

At this point, you have set up the various gem repositories on the Nexus Repository (proxy, hosted, and group), and are successfully using them for installing new gems on your systems. The next step can be to push gems to hosted gem repositories to provide them to other users. All this can be achieved on the command line with the features of the nexus gem.

The nexus gem is available at RubyGems and provides features to interact with Nexus Repository including pushing gems to a hosted gem repository including the necessary authentication.

You can install the Nexus gem with:

$ gem install nexus
Fetching: nexus-1.2.1.gem (100%)
...
Successfully installed nexus-1.2.1
Parsing documentation for nexus-1.2.1
Installing ri documentation for nexus-1.2.1
Done installing

After successful installation, you can push your gem to a desired repository. The initial invocation will request the URL for the gem repository and the credentials needed for deployment. Subsequent pushes will use the cached information.

$ gem nexus example-1.0.0.gem
Enter the URL of the rubygems repository on a Nexus server
URL: http://localhost:8081/repository/rubygems-hosted
The Nexus URL has been stored in ~/.gem/nexus
Enter your Nexus credentials
Username: admin
Password:
Your Nexus credentials has been stored in /Users/manfred/.gem/nexus
Uploading gem to Nexus...
Created

By default, pushing an identical version to the repository, known as redeployment, is not allowed in a hosted gem repository. If desired this configuration can be changed, although we suggest changing the version for each new deployment instead.

The nexus gem provides several additional features and parameters. You can access the documentation with:

$ gem help nexus 

E.g. you can access a list of all configured repositories with:

$ gem nexus --all-repos
DEFAULT: http://localhost:8081/repository/rubygems-hosted