2015-07-10 83 views
1

我正在使用IDE Cloud9並希望升級Ruby版本(從2.1.5到2.2.1)。在安裝RVM後,我說rvm use 2.2.1並將Gemfile中的Ruby版本更改爲2.2.1。然後我跑bundle install,並得到以下結果:更新Ruby版本和gems,gem更新失敗

Fetching gem metadata from https://rubygems.org/.......... 
Fetching version metadata from https://rubygems.org/... 
Fetching dependency metadata from https://rubygems.org/.. 
Fetching https://github.com/leikind/wice_grid.git 
Using rake 10.4.2 
Installing CFPropertyList 2.3.1 
Installing i18n 0.7.0 
Installing json 1.8.3 
Installing minitest 5.7.0 
Installing thread_safe 0.3.5 
Installing tzinfo 1.2.2 
Installing activesupport 4.2.3 
Installing builder 3.2.2 
Installing erubis 2.7.0 
Installing mini_portile 0.6.2 

Gem::Ext::BuildError: ERROR: Failed to build gem native extension. 

    /usr/local/rvm/rubies/ruby-2.2.1/bin/ruby -r ./siteconf20150710-9483-je82d8.rb extconf.rb 
checking if the C compiler accepts ... yes 
Building nokogiri using packaged libraries. 
checking for gzdopen() in -lz... yes 
checking for iconv... yes 
************************************************************************ 
IMPORTANT NOTICE: 

Building Nokogiri with a packaged version of libxml2-2.9.2 
with the following patches applied: 
     - 0001-Revert-Missing-initialization-for-the-catalog-module.patch 
     - 0002-Fix-missing-entities-after-CVE-2014-3660-fix.patch 

Team Nokogiri will keep on doing their best to provide security 
updates in a timely manner, but if this is a concern for you and want 
to use the system library instead; abort this installation process and 
reinstall nokogiri as follows: 

    gem install nokogiri -- --use-system-libraries 
     [--with-xml2-config=/path/to/xml2-config] 
     [--with-xslt-config=/path/to/xslt-config] 

If you are using Bundler, tell it to use the option: 

    bundle config build.nokogiri --use-system-libraries 
    bundle install 

Note, however, that nokogiri is not fully compatible with arbitrary 
versions of libxml2 provided by OS/package vendors. 
************************************************************************ 
Extracting libxml2-2.9.2.tar.gz into tmp/x86_64-unknown-linux-gnu/ports/libxml2/2.9.2... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxml2/0001-Revert-Missing-initialization-for-the-catalog-module.patch... 
Running 'patch' for libxml2 2.9.2... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxml2/0002-Fix-missing-entities-after-CVE-2014-3660-fix.patch... 
Running 'patch' for libxml2 2.9.2... OK 
Running 'configure' for libxml2 2.9.2... OK 
Running 'compile' for libxml2 2.9.2... OK 
Running 'install' for libxml2 2.9.2... OK 
Activating libxml2 2.9.2 (from /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/x86_64-unknown-linux-gnu/libxml2/2.9.2)... 
************************************************************************ 
IMPORTANT NOTICE: 

Building Nokogiri with a packaged version of libxslt-1.1.28 
with the following patches applied: 
     - 0001-Adding-doc-update-related-to-1.1.28.patch 
     - 0002-Fix-a-couple-of-places-where-f-printf-parameters-wer.patch 
     - 0003-Initialize-pseudo-random-number-generator-with-curre.patch 
     - 0004-EXSLT-function-str-replace-is-broken-as-is.patch 
     - 0006-Fix-str-padding-to-work-with-UTF-8-strings.patch 
     - 0007-Separate-function-for-predicate-matching-in-patterns.patch 
     - 0008-Fix-direct-pattern-matching.patch 
     - 0009-Fix-certain-patterns-with-predicates.patch 
     - 0010-Fix-handling-of-UTF-8-strings-in-EXSLT-crypto-module.patch 
     - 0013-Memory-leak-in-xsltCompileIdKeyPattern-error-path.patch 
     - 0014-Fix-for-bug-436589.patch 
     - 0015-Fix-mkdir-for-mingw.patch 

Team Nokogiri will keep on doing their best to provide security 
updates in a timely manner, but if this is a concern for you and want 
to use the system library instead; abort this installation process and 
reinstall nokogiri as follows: 

    gem install nokogiri -- --use-system-libraries 
     [--with-xml2-config=/path/to/xml2-config] 
     [--with-xslt-config=/path/to/xslt-config] 

If you are using Bundler, tell it to use the option: 

    bundle config build.nokogiri --use-system-libraries 
    bundle install 
************************************************************************ 
Extracting libxslt-1.1.28.tar.gz into tmp/x86_64-unknown-linux-gnu/ports/libxslt/1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0001-Adding-doc-update-related-to-1.1.28.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0002-Fix-a-couple-of-places-where-f-printf-parameters-wer.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0003-Initialize-pseudo-random-number-generator-with-curre.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0004-EXSLT-function-str-replace-is-broken-as-is.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0006-Fix-str-padding-to-work-with-UTF-8-strings.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0007-Separate-function-for-predicate-matching-in-patterns.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0008-Fix-direct-pattern-matching.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0009-Fix-certain-patterns-with-predicates.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0010-Fix-handling-of-UTF-8-strings-in-EXSLT-crypto-module.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0013-Memory-leak-in-xsltCompileIdKeyPattern-error-path.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0014-Fix-for-bug-436589.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running patch with /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ports/patches/libxslt/0015-Fix-mkdir-for-mingw.patch... 
Running 'patch' for libxslt 1.1.28... OK 
Running 'configure' for libxslt 1.1.28... OK 
Running 'compile' for libxslt 1.1.28... ERROR, review '/usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2/ext/nokogiri/tmp/x86_64-unknown-linux-gnu/ports/libxslt/1.1.28/compile.log' to see what happened. 
*** extconf.rb failed *** 
Could not create Makefile due to some reason, probably lack of necessary 
libraries and/or headers. Check the mkmf.log file for more details. You may 
need configuration options. 

Provided configuration options: 
     --with-opt-dir 
     --without-opt-dir 
     --with-opt-include 
     --without-opt-include=${opt-dir}/include 
     --with-opt-lib 
     --without-opt-lib=${opt-dir}/lib 
     --with-make-prog 
     --without-make-prog 
     --srcdir=. 
     --curdir 
     --ruby=/usr/local/rvm/rubies/ruby-2.2.1/bin/$(RUBY_BASE_NAME) 
     --help 
     --clean 
     --use-system-libraries 
     --enable-static 
     --disable-static 
     --with-zlib-dir 
     --without-zlib-dir 
     --with-zlib-include 
     --without-zlib-include=${zlib-dir}/include 
     --with-zlib-lib 
     --without-zlib-lib=${zlib-dir}/lib 
     --enable-cross-build 
     --disable-cross-build 
/usr/local/rvm/gems/ruby-2.2.1/gems/mini_portile-0.6.2/lib/mini_portile.rb:279:in `block in execute': Failed to complete compile task (RuntimeError) 
     from /usr/local/rvm/gems/ruby-2.2.1/gems/mini_portile-0.6.2/lib/mini_portile.rb:271:in `chdir' 
     from /usr/local/rvm/gems/ruby-2.2.1/gems/mini_portile-0.6.2/lib/mini_portile.rb:271:in `execute' 
     from /usr/local/rvm/gems/ruby-2.2.1/gems/mini_portile-0.6.2/lib/mini_portile.rb:70:in `compile' 
     from /usr/local/rvm/gems/ruby-2.2.1/gems/mini_portile-0.6.2/lib/mini_portile.rb:110:in `cook' 
     from extconf.rb:278:in `block in process_recipe' 
     from extconf.rb:177:in `tap' 
     from extconf.rb:177:in `process_recipe' 
     from extconf.rb:487:in `<main>' 

extconf failed, exit code 1 

Gem files will remain installed in /usr/local/rvm/gems/ruby-2.2.1/gems/nokogiri-1.6.6.2 for inspection. 
Results logged to /usr/local/rvm/gems/ruby-2.2.1/extensions/x86_64-linux/2.2.0/nokogiri-1.6.6.2/gem_make.out 
An error occurred while installing nokogiri (1.6.6.2), and Bundler cannot continue. 
Make sure that `gem install nokogiri -v '1.6.6.2'` succeeds before bundling. 

此外,CLOUD9生成一個彈出disk quota reached(我有超過200MB的可用空間運行bundle install之前,我試圖運行gem install nokogiri -v '1.6.6.2'就像在年底的錯誤消息。我想這可能是由於缺少磁盤配額,但我不確定,我嘗試使用gem cleanuprake tmp:clear進行清理,但這些會生成錯誤:Could not find nokogiri-1.6.6.2 in any of the sources. Run 'bundle install' to install missing gems.我應該如何處理這個錯誤消息?從這裏取得進展?

+0

當您升級時,您是否從rvm中刪除舊的ruby版本?可能能夠清理那裏的一些空間(我不知道那麼多有關雲9,所以可能不會被計算在內)。 – Doon

+0

啊對不起,我誤讀了棧跟蹤,它是[mini_portile](https:// github。 COM/flavorjones/mini_portile)。試試'gem install mini_portile'。 Mini-Portile將存儲一堆編譯後的C庫,這些庫被用來代替系統庫,因此它可以吸取一點磁盤空間 - 當你在自己的機器上運行時,這通常不是問題。 – max

+0

謝謝你們,我使用'rvm remove ruby​​ 2.1.5'刪除了舊的ruby版本(原來也卸載了所有的寶石)。我的磁盤使用量從1GB下降到400MB(而在添加新的Ruby版本之前,它只有700 MB以上)。然後我跑了'gem install nokogiri'和'bundle install',都沒有問題。一切正常。有趣的是,現在我的磁盤使用量已經超過了500MB,而在這之前所有的磁盤使用量都超過了700 MB。總之,磁盤空間確實是所有問題的原因。 @Doon,如果您將其添加爲答案,我會接受它。 – Nick

回答

1

通過rvm刪除舊版本的ruby,這將釋放空間。

未來,您可能會嘗試使用rvm upgrade進行升級,因爲它會升級紅寶石,並嘗試遷移所有寶石,然後爲您提供刪除舊紅寶石的選項。但是,如果由於配額而造成空間受限,則可能會遇到類似的問題。