Gemfile文件指定你想要使用的gem的位置,并可以指定具体版本。如何指定?
Gemfile.lock文件是Bundler记录安装的确切版本的地方。这样,当相同的库或是项目在另一台机器上加载时,运行bundle install将查看该Gemfile同时安装完全相同的版本,而不是安装最新的版本。(在不同的机器上运行不同的版本可能会导致测试失败等等)。简单来说就是保证在不同环境下gem版本相同。
Tip:请不要直接编辑Gemfile.lock文件
e.g.
通常我们会将通常我们在Gemfile中编写依赖关系如下:
gem "nokogiri", "~> 1.4.4"
gem 'bcrypt-ruby', '~> 3.0.0'
gem 'uglifier', '>= 1.2.3'
此处的意思是:“nokogiri的版本只需大于1.4.4即可 ”等等。现在假设我在8个月前设置了我的Gemfile,并且按照这个要求成功设置了我的应用程序。8个月前nokogiri版本是1.4.4。我的rails应用程序在这个版本中运行得很完美,没有任何问题。
现在我想用相同的Gemfile来构建。但是如果我们看看nokogiri的版本,我们会发现当前的稳定版本已经变成了1.4.9。这意味着如果我们尝试建造。bundler将安装nokogiri的1.4.9版本(假设我们没有Gemfile.lock)
你的应用使用的是1.4.4版本,8个月前它可以正常工作,没有任何问题,但如果你现在尝试构建它,你会得到1.4.9版本。此时就有可能出现一些问题,例如兼容性问题,又或者1.4.4版本中的一些功能被移除了等等。
Gemfile.lock就是为了防止这种问题发生的,这意味着如果你带着Gemfile.lock发布你产品,每台机器都将安装指定了相同版本的gem。这将为您提供一个稳定和通用的部署堆栈。