簡介 Bundler

 

RubyGem 是包裝、散佈Ruby程式庫的標準方式,相關文件可以參考 RubyGems Guides 的說明,或是 簡介 plugins 中的第二個例子。在使用rails new建立新專案時,會執行bundle install安裝應用程式使用到的Gem,例如在 安裝 Rails 中看到的例子:

~\$ rails new hello
      create 
      create  README
      create  Rakefile
      create  config.ru
      create  .gitignore
      create  Gemfile
      create  app
      create  app/assets/images/rails.png
      create  app/assets/javascripts/application.js
      ...略
      create  vendor/plugins/.gitkeep
         run  bundle install
Fetching source index for http://rubygems.org/
Using rake (0.9.2.2)
Using multi_json (1.0.4)
Using activesupport (3.1.3)
...略
Installing turn (0.8.2)
Installing uglifier (1.1.0)
Your bundle is complete! Use `bundle show [gemname]` to see where a bundled gem is installed.

Bundler
是管理Gem相依性的工具,執行bundle
install時,會根據應用程式目錄中Gemfile的設定,檢查指定的Gem與相依套件是否已安裝,如果已安裝了Gem,就會顯示Using,如果是
新下載安裝的Gem,就會顯示Installing,想知道已安裝的Gem裝到哪,可以使用bundle show gemname來得知。

預設Gem會安裝至Ruby安裝目錄中gems目錄中,例如在我的Ubuntu中是安裝至/usr/local/lib/ruby/gems/1.9.1/gem中,如果有設置BUNDLE_PATH環境變數,則會將Gem安裝至指定的目錄中。

bundle
install會連至伺服器檢查Gem相依性,預設是連線http://rubygems.org,如果有缺少的Gem,會自動下載安裝,然而每次執行
bundle install都要連線會耗費時間,如果你需要的Gem先前都下載安裝過了,在執行rails new建立新專案時,可以先略過連線:

~\$ rails new gossip --skip-bundle

之後執行bundle install時指定--local選項:

~gossip\$ bundle install --local

加上--local選項就不會連至 Server,只會檢查本地端有無安裝,但如果有缺少的Gem,不會自動下載安裝。

要注意的是,在Rails 3中使用Gemfile來管理Gem,應用程式會使用的Gem,一定要在Gemfile中設定,不然即使本地端有安裝,應用程式也無法使用,一個新建的專案中,預設的Gemfile如下:

  • Gemfile
source 'http://rubygems.org'

gem 'rails', '3.1.3'

# Bundle edge Rails instead:
# gem 'rails', :git => 'git://github.com/rails/rails.git' gem 'sqlite3' # Gems used only for assets and not required
# in production environments by default.
group :assets do
gem 'sass-rails', '~> 3.1.5'
gem 'coffee-rails', '~> 3.1.1'
gem 'uglifier', '>= 1.0.3'
end gem 'jquery-rails' # To use ActiveModel has_secure_password
# gem 'bcrypt-ruby', '~> 3.0.0' # Use unicorn as the web server
# gem 'unicorn' # Deploy with Capistrano
# gem 'capistrano' # To use debugger
# gem 'ruby-debug19', :require => 'ruby-debug' group :test do
# Pretty printed test output
gem 'turn', '0.8.2', :require => false
end

第一行source指定了連線的伺服器,gem後的第一個參數指定Gem的名稱,第二個參數指定版本,如果不指定版本,會安裝最新的穩定版本,Gem名稱與版本,可至http://rubygems.org搜尋確認,版本還可以指定大於等於某個版本,例如'>=3.1.3',或是指定'~>x.y.z',x是主(major)版本號,通常在API發生重大變動時才會更改、y是次(minor)版本號,通常是在新增功能時修改,z是小(tiny)版本號,通常在修正bug後修改,這種指定表示版本號x.y不變,但可以大於等於z。

預設Gem名稱就會是require的名稱,如果不同,可以使用:require指定要require的名稱。如果你的Gem不在預設gems目錄中,也可以使用:path指定,也可以使用:git指定Git作為來源。group則可以指定特定環境載入執求的Gem,例如上例中:test指定測試環境使用turn這個Gem。

執行bundle install連線伺服器,會檢查Gem更新與相依性,必要時下載安裝,最後應用程式使用了哪些Gem與版本,會記錄在Gemfile.lock之中,如果Gemfile有變動,執行bundle install會查看Gemfile.lock,瞭解已安裝了哪些Gem,僅安裝更新的Gem,並將新使用到的Gem資訊記錄至Gemfile.lock。可以執行bundle update gemname指定更新Gem,如果僅執行bundle update,就會重新確認Gem更新與相依性,重新產生Gemfile.lock。

摘自:https://openhome.cc/Gossip/Rails/Bundler.html

bundler简介(ruby gem)的更多相关文章

  1. Ruby Gem命令详解

    转自:http://www.jianshu.com/p/728184da1699 Gem介绍: Gem是一个管理Ruby库和程序的标准包,它通过Ruby Gem(如 http://rubygems.o ...

  2. Ruby Gem命令

    Gem是一个管理Ruby库和程序的标准包,它通过Ruby Gem(如 http://rubygems.org/ )源来查找.安装.升级和卸载软件包,非常的便捷. Ruby 1.9.2版本默认已安装Ru ...

  3. ruby gem tips(转)

    淘宝源: https://ruby.taobao.org 升级ruby gem gem update --system 查看gem版本 gem -v 查看gem版本,gems安装目录,remote s ...

  4. ruby(&gem) koala安装

    1.ruby下载安装 下载地址:http://railsinstaller.org/en 选择合适版本 2.gem(安装ruby时自带gem) 删除原镜像:gem sources --remove h ...

  5. 转 关于ruby gem无法连接到rubygems.org的解决方案

    为什么有这个? 由于国内网络原因(你懂的),导致 rubygems.org 存放在 Amazon S3 上面的资源文件间歇性连接失败.所以你会与遇到 gem install rack 或 bundle ...

  6. 修改ruby gem源为ruby.taobao.org

    由于网络原因,导致从rubygems.org下载gem文件较慢或者间歇性的连接失败,所以可以修改gem源为ruby.taobao.org.具体可以用 gem install rails -V 来查看执 ...

  7. ruby, gem install 出现网络错误

    gem sources #查看目前的源 gem sources --remove https://rubygems.org/ gem sources -a https://ruby.taobao.or ...

  8. 关于ruby -gem无法切换淘宝源

    ruby官网提供的 淘宝的gem源 不起作用 https://ruby.taobao.org/ taobao Gems 源已停止维护,现由 ruby-china 提供镜像服务 http://gems. ...

  9. 关于ruby gem无法连接到rubygems.org的解决方案

    RubyGems 镜像 - 淘宝网 为什么有这个? 由于国内网络原因(你懂的),导致 rubygems.org 存放在 Amazon S3 上面的资源文件间歇性连接失败.所以你会与遇到 gem ins ...

随机推荐

  1. cf-Global Round2-D. Frets On Fire(二分)

    题目链接:http://codeforces.com/contest/1119/problem/D 题意:给n(<=1e5)个数s[i],i=1..n,(0<=s[i]<=1e18) ...

  2. Error in building opencv with ffmpeg

    I installed ffmpeg according to this article. ffmpeg installation was ok. Now I build opencv with ff ...

  3. LightOJ - 1027 Dangerous Maze 期望

    你在迷宫中;开始时在你面前看到n扇门.你可以选择你喜欢的任何门.所有门的选择门的概率是相等的. 如果您选择第i个门,它可以让您回到您在xi(xi小于0)分钟内开始的相同位置,也可以在xi(xi大于0) ...

  4. Disruptor底层实现讲解与RingBuffer数据结构讲解

    Disruptor术语 RingBuffer:被看作Disruptor最主要的组件,然而从2.0开始RingBuffer仅仅负责存储和更新在Disruptor中流通的数据.对一些特殊的使用场景能够被用 ...

  5. vue项目引入FastClick组件解决IOS系统下h5页面中的按钮点击延迟,连续点击无反应的问题

    异常描述: ios系统手机中访问h5页面,按钮点击有延迟,连续点击卡顿.无反应. 异常原因: 这要追溯至 2007 年初.苹果公司在发布首款 iPhone 前夕,遇到一个问题:当时的网站都是为大屏幕设 ...

  6. webpack浅析---入口篇

    webpack有四个核心概念: 入口(entry) 输出(output) loader 插件(plugins) webpack-merge将环境.构建目标.运行时合并 入口: 入口起点是指webpac ...

  7. YII2表单中上传单个文件

    有些时候我们提交的表单中含有文件.怎么样让表单里的数据和文件一起提交. 我的数据表tb_user内容如下: CREATE TABLE `tb_user` ( `id` int(11) unsigned ...

  8. Aspose.words一 DOM结构

    2.文档对象模型概述 2.1 DOM介绍 Aspose.Words的文档对象模型(以下简称DOM)是一个Word文档在内存中的映射,Aspose.Words的DOM可以编程读取.操作和修改Word文档 ...

  9. Comparing Code Playgrounds Codepen, JSFiddle, JS Bin, Dabblet, CSS Deck, and Liveweave

    What is a code playground? Codepen, JSFiddle, JS Bin, Dabblet, CSS Deck, and Liveweave are HTML, CSS ...

  10. vue(ajax:axios中文文档)

    axios 基于http客户端的promise,面向浏览器和nodejs 特色 浏览器端发起XMLHttpRequests请求 node端发起http请求 支持Promise API 监听请求和返回 ...