Gemfile.lock
是未了保证运行环境一致性而产生的,这样可以最大限度的减少因为环境差异所造成的运行异常。但如果你写的是个library,那么你则应该抛弃gemfile.lock
以确保library的通用性。
一般gem都会在spec里写明其所依赖的gems有哪些,并且bundler
在安装的时候自动的分析他们之间的关系,所以大可不必去关心其中的底层依赖,放心的交给bundler好了。
开发过程中尽管你会依赖很多gem,但并不代表这些gem都应该在线上环境被加载。相当一部分其实只是为了提高你的开发效率存在,所以最好把它们区别出来加以分组,比较好的是分成三组:开发、测试、线上。
Gemfile应该跟你的程序代码一样被严格规范起来:
3rd party apis, performance, devops...
# Good group :development do gem 'web-console' gem 'spring' end
# Bad gem 'web-console', group: :development gem 'spring', group: :development
Gemfile有自己的DSL,所以不要在Gemfile里炫技使用Ruby语法,这里的炫技并不能帮你提升什么性能,写的通俗易懂才是大众喜闻乐见的。不过天朝环境下这个用法很好用:
if ENV['USE_OFFICE_GEM_SOURCE']
source 'https://rubygems.org'
else
source 'https://gems.ruby-china.org'
end
尽管Gemfile允许你直接通过Git来安装gem,但还是不推荐你再Gemfile大量使用这种方式,原因有三:
是否添加一个新依赖到应用中应该是件需要慎重决定的事儿。gem带来便利的同时也会增加维护成本,还会拖慢你的应用。
Every dependency in your application has the potential to bloat your app, to destabilize your app, to inject odd behavior via monkeypatching or buggy native code.
-完-