2016-04-24 64 views
4

當試圖運行jekyll serve時,它似乎正確構建(儘管警告我無法解決),但後來無法投放。 jekyll build完成,但生成的文件缺少編譯的CSS。Jekyll無法投放(Ruby不兼容的庫版本)

jekyll serve

輸出:

Ignoring ffi-1.9.10 because its extensions are not built. Try: gem pristine ffi --version 1.9.10 
Ignoring curb-0.9.3 because its extensions are not built. Try: gem pristine curb --version 0.9.3 
Ignoring executable-hooks-1.3.2 because its extensions are not built. Try: gem pristine executable-hooks --version 1.3.2 
Ignoring ffi-1.9.10 because its extensions are not built. Try: gem pristine ffi --version 1.9.10 
Ignoring gem-wrappers-1.2.7 because its extensions are not built. Try: gem pristine gem-wrappers --version 1.2.7 
Ignoring json-1.8.2 because its extensions are not built. Try: gem pristine json --version 1.8.2 
Ignoring thin-1.6.1 because its extensions are not built. Try: gem pristine thin --version 1.6.1 
Configuration file: /home/jtebert/OwnCloud/Projects/Programming/python/AMS/mockup/_config.yml 
      Source: /home/jtebert/OwnCloud/Projects/Programming/python/AMS/mockup 
     Destination: /home/jtebert/OwnCloud/Projects/Programming/python/AMS/mockup/_site 
Incremental build: disabled. Enable with --incremental 
     Generating... 
        done in 1.404 seconds. 
/usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:120:in `require': incompatible library version - /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/ffi-1.9.10/lib/ffi_c.so (LoadError) 
     from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:120:in `require' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/ffi-1.9.10/lib/ffi.rb:6:in `rescue in <top (required)>' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/ffi-1.9.10/lib/ffi.rb:3:in `<top (required)>' 
     from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:120:in `require' 
     from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:120:in `require' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/rb-inotify-0.9.7/lib/rb-inotify/native.rb:1:in `<top (required)>' 
     from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:68:in `require' 
     from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:68:in `require' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/rb-inotify-0.9.7/lib/rb-inotify.rb:1:in `<top (required)>' 
     from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:68:in `require' 
     from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:68:in `require' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/adapter/linux.rb:30:in `_configure' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/adapter/base.rb:45:in `block in configure' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/adapter/base.rb:40:in `each' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/adapter/base.rb:40:in `configure' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/adapter/base.rb:63:in `start' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/backend.rb:26:in `start' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/listener.rb:67:in `block in <class:Listener>' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/fsm.rb:120:in `instance_eval' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/fsm.rb:120:in `call' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/fsm.rb:91:in `transition_with_callbacks!' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/fsm.rb:57:in `transition' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/listen-3.0.6/lib/listen/listener.rb:90:in `start' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/jekyll-watch-1.3.1/lib/jekyll/watcher.rb:12:in `watch' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/jekyll-3.1.3/lib/jekyll/commands/build.rb:72:in `watch' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/jekyll-3.1.3/lib/jekyll/commands/build.rb:39:in `process' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/jekyll-3.1.3/lib/jekyll/commands/serve.rb:34:in `block (2 levels) in init_with_program' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/mercenary-0.3.5/lib/mercenary/command.rb:220:in `block in execute' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/mercenary-0.3.5/lib/mercenary/command.rb:220:in `each' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/mercenary-0.3.5/lib/mercenary/command.rb:220:in `execute' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/mercenary-0.3.5/lib/mercenary/program.rb:42:in `go' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/mercenary-0.3.5/lib/mercenary.rb:19:in `program' 
     from /home/jtebert/.rvm/gems/ruby-2.0.0-p643/gems/jekyll-3.1.3/bin/jekyll:13:in `<top (required)>' 
     from /usr/local/bin/jekyll:23:in `load' 
     from /usr/local/bin/jekyll:23:in `<main>' 

當試圖啓動一個項目傑基爾,我也必須創建Ruby版本,因爲它一直在尋找「Ruby2.1」的鏈接,但我不知道如果這在當前問題中發揮作用:ln -s /usr/bin/ruby '/usr/bin/ruby2.1'

根據我的軟件包管理器,我安裝了Ruby 2.3.0。但根據which ruby,我使用的是從rvm獲得的2.0.0:/home/xxxxxxx/.rvm/rubies/ruby-2.0.0-p643/bin/ruby。正如我之前提到的,Jekyll似乎想要v2.1的東西。我猜這些衝突的版本會導致問題,但我不知道如何解決它。

+0

我有同樣的問題,但我沒有安裝'rvm'。任何其他猜測? –

回答

0

這個問題對我來說似乎是rvm(我不知道我是如何結束使用的)。解決方法是用rvm implode刪除rvm,然後用gem install jekyll重新安裝jekyll。警告和錯誤都消失了,它正在正常使用。

0

在我而言,我不得不與gem安裝ffi庫:

gem install ffi

此錯誤可能是由舊版本安裝在系統庫造成的。 gem然後爲您的項目安裝正確的版本。