87

I get the following error when attempting to run cap production deploy.

DEBUG [dc362284]    Bundler::GemNotFound: Could not find json-1.8.1.gem for installation
DEBUG [dc362284]    An error occurred while installing json (1.8.1), and Bundler cannot continue.
DEBUG [dc362284]    Make sure that `gem install json -v '1.8.1'` succeeds before bundling.

It may be important to note that this deployment was working, than I upgraded to Ruby 2.1.0 to remove an encoding error. I upgraded locally which worked fine. I ran rvm install 2.1.0 and rvm use 2.1.0 then changed my .ruby-version file to reflect this Ruby upgrade.

The bundle install command works locally, but produces the same above error when I ssh onto the destination server and run this command.

If I run gem list I can see this in the list of gems.

...
jquery-rails (3.0.4)
json (1.8.1)
less (2.3.2)
...

If I try the recommended solution gem install json -v '1.8.1' Locally and on the destination server I get the following output:

Building native extensions.  This could take a while...
Successfully installed json-1.8.1
Parsing documentation for json-1.8.1
Done installing documentation for json after 0 seconds
1 gem installed

So it appears the gem is installed, right? Why is this happening? How can I solve this? Any help would be greatly appreciated.

d-cubed
  • 1,034
  • 5
  • 30
  • 58
Thomas
  • 2,426
  • 3
  • 23
  • 38

19 Answers19

75
$ bundle update json
$ bundle install
danvitoriano
  • 1,181
  • 10
  • 12
68

So after a half day on this and almost immediately after posting my question I found the answer. Bundler 1.5.0 has a bug where it doesn't recognize default gems as referenced here

The solution was to update to bundler 1.5.1 using gem install bundler -v '= 1.5.1'

Thomas
  • 2,426
  • 3
  • 23
  • 38
49

Run this command then everything will be ok

sudo apt-get install libgmp-dev
Jameel Grand
  • 2,294
  • 16
  • 32
41

if you are in MacOS Sierra and your ruby version is 2.4.0.The ruby version is not compatible with json 1.8.3.

You can try add this line in your Gemfile:

gem 'json', github: 'flori/json', branch: 'v1.8'

This works for me!

Iulian Onofrei
  • 9,188
  • 10
  • 67
  • 113
Juice007
  • 1,054
  • 1
  • 9
  • 14
35

To solve this problem, simply run:

bundle update

It will update the version of your bundler. Then run:

bundle install

Your problem will get solve. Solution is well explained here.

Rohini Choudhary
  • 2,423
  • 2
  • 21
  • 31
  • 1
    +1 Really helpful and got me unstuck. After `bundle update`, the install worked great. Thank you for the clean solution. – twknab Oct 29 '17 at 21:54
  • 3
    `bundle update` will update all your gems. `gem update bundler` will update bundler. – eebbesen Feb 16 '18 at 02:51
20

I found the solution here. There is a problem with json version 1.8.1 and ruby 2.2.3, so install json 1.8.3 version.

gem install json -v1.8.3
Ajeet Khan
  • 8,582
  • 8
  • 42
  • 65
  • 1
    This worked fantastically for me on OSX, Ubuntu across multiple bad versions of the json gem. In one case I had to delete the lock file and rebuild from scratch: git rm Gemfile.lock bundle install – fuzzygroup Oct 11 '16 at 20:16
  • 2
    Worked fine, first of all I delete the `Gemfile.lock` and then just run `bundle install` and that's it. – alexventuraio Oct 17 '16 at 00:04
12

You should try

$ sudo gem install json -v '1.8.2'

in my case (Ubuntu 14.04) that didn't work directly and I had to do this:

$ sudo apt-get install ruby-dev

and then I could install the gem and continue. Had one more problem that was fixed by:

$ sudo apt-get install libsqlite3-dev

Hoping helps.

Lucas
  • 121
  • 1
  • 2
9

If the recommended answer didn't help because you are already using a newer version of bundler. Try the solution that worked for me.

Delete everything inside your vendor folder. Add a line to your gemfile

gem 'json', '1.8.0'

Then run - bundle update json.

It seems to be an issue with 1.8.1 so going back to 1.8.0 did the trick for me.

Philip Kirkbride
  • 21,381
  • 38
  • 125
  • 225
Adam
  • 464
  • 1
  • 4
  • 13
7

I ran into this error while trying to get a project to run on my local dev box (OSX 10.6), using Sinatra and Postgresql (through activerecord), running on an rvm'd ruby 2.1. I found my answer here: https://github.com/wayneeseguin/rvm/issues/2511

My exact problem (after the first block of log entries):

I also get an error when trying to build native extensions for gems

The answer:

rvm reinstall 2.1.0 --disable-binary

The explanation:

OSX does not have a package manager so all libraries have to be installed manually by user, this makes it virtually impossible to link the binary dynamically, and as you can see there are problems with the (pseudo)statically linked binary.

For the sake of completeness, I had first forgotten to update rvm (rvm get head), which yielded some other errors, but still needed the --disable-binary flag once I had done so.

Matthias
  • 150
  • 1
  • 8
  • Get the following error with your solution: "Version '2.1.0' is ambiguous. Cannot select Ruby implementation/version, please be more specific. Cannot reinstall unknown package ''" – holyredbeard Apr 23 '14 at 18:45
  • You might not have ruby 2.1.0, or more than one version installed through rvm. Run `rvm list`, and you'll see what is your current version. Use the full string (e.g. ruby-2.0.0-p451) instead of the `2.1.0` mentioned above. – Matthias Apr 25 '14 at 11:08
7

bundle update json. Helped to get through.

Peter DeWeese
  • 18,141
  • 8
  • 79
  • 101
anti-k
  • 317
  • 2
  • 13
5

When I tried to install the json gem using gem install json separate from just using bundle install I got ERROR: Failed to build gem native extension., looking that up I found using

    apt-get install ruby-dev

did the trick

PetrolHead
  • 390
  • 4
  • 7
3

For OS X make sure you have coreutils

$ brew install coreutils
$ bundle
Tim Kozak
  • 4,026
  • 39
  • 44
2

This appears to be a bug in Bundler not recognizing the default gems installed along with ruby 2.x. I still experienced the problem even with the latest version of bundler (1.5.3).

One solution is to simply delete json-1.8.1.gemspec from the default gemspec directory.

rm ~/.rubies/ruby-2.1.0/lib/ruby/gems/2.1.0/specifications/default/json-1.8.1.gemspec

After doing this, bundler should have no problem locating the gem. Note that I am using chruby. If you're using some other ruby manager, you'll have to update your path accordingly.

jearlu
  • 550
  • 4
  • 10
2

I was missing C headers solution was to download it for Xcode, this is the best way.

xcode-select --install

Hope it helps.

Haris Krajina
  • 14,824
  • 12
  • 64
  • 81
2

Bundle was failing to install json -v '1.8.1' and deleting my Gemfile.lock and running bundle again solved this issue for me.

davidmccoy
  • 61
  • 5
1

I installed the latest version of json:

gem install json

Then deleted the line json(1.8.1) from the Gemfile.lock and did a

bundle install

And then the Gemfile.lock file uses json(1.8.3) without erros

PerseP
  • 1,177
  • 2
  • 14
  • 22
0

Switch ruby version from 1.9 to 2.2 with rvm did the job for me

Koala7
  • 1,340
  • 7
  • 41
  • 83
0

For me, some of the answers mentioned earlier were helpful from understanding point of view, but those didn't solve my problem.

So this is what I did to solve issue.

  • Modified gemfile.lock to update json (2.0.2) (Earlier, it was 1.8.3)
  • Check the Bundler version installed (Bundler -v command). I had version 1.12.5 installed
  • Install bundler version 1.11.2 (using gem install bundler -v '1.11.2')
  • Then run bundle install
iHS
  • 5,372
  • 4
  • 31
  • 49
0

For macOS Sierra:

I ran into this error When i used bundler(v1.15.3) in Rails(v4.2) project. The solution for me is gem uninstall bundler -v '1.15.3' and gem install bundler -v '1.14.6'.

Devin
  • 139
  • 1
  • 7