前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Bundler与Gemfile的最佳实践 | Ruby

Bundler与Gemfile的最佳实践 | Ruby

作者头像
lazybios
发布2019-07-30 16:34:00
9100
发布2019-07-30 16:34:00
举报
文章被收录于专栏:日拱一卒日拱一卒
Gemfile.lock is for apps, not libraries

Gemfile.lock是未了保证运行环境一致性而产生的,这样可以最大限度的减少因为环境差异所造成的运行异常。但如果你写的是个library,那么你则应该抛弃gemfile.lock以确保library的通用性。

Only specify top-level dependencies

一般gem都会在spec里写明其所依赖的gems有哪些,并且bundler在安装的时候自动的分析他们之间的关系,所以大可不必去关心其中的底层依赖,放心的交给bundler好了。

Use Gemfile groups

开发过程中尽管你会依赖很多gem,但并不代表这些gem都应该在线上环境被加载。相当一部分其实只是为了提高你的开发效率存在,所以最好把它们区别出来加以分组,比较好的是分成三组:开发、测试、线上。

Consistent formatting

Gemfile应该跟你的程序代码一样被严格规范起来:

  • 使用清晰的缩进
  • 使用单引号字符串
  • 检查多余的空格字符
  • 合理的功能分区,以及注释说明,3rd party apis, performance, devops...
  • 避免用单行group定义,尽量用blocks语法 # Good group :development do gem 'web-console' gem 'spring' end # Bad gem 'web-console', group: :development gem 'spring', group: :development
Resist the urge to Ruby

Gemfile有自己的DSL,所以不要在Gemfile里炫技使用Ruby语法,这里的炫技并不能帮你提升什么性能,写的通俗易懂才是大众喜闻乐见的。不过天朝环境下这个用法很好用:

代码语言:javascript
复制
if ENV['USE_OFFICE_GEM_SOURCE']
 source 'https://rubygems.org'
else
 source 'https://gems.ruby-china.org'
end
Minimize git dependencies

尽管Gemfile允许你直接通过Git来安装gem,但还是不推荐你再Gemfile大量使用这种方式,原因有三:

  1. 长时间的依赖私有库,会让你偏离该gem的主分支,今儿会错过很多必要的更新和一些新特性
  2. 相比语义化的版本而言,git提供的hash值让人很难搞懂版本之间的关系
  3. 更好的解决方法是给原gem提issue、patch,这样可以营造一个更好的开源环境
Do you really need that gem?

是否添加一个新依赖到应用中应该是件需要慎重决定的事儿。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.

-完-

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-06-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 日拱一卒 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Gemfile.lock is for apps, not libraries
  • Only specify top-level dependencies
  • Use Gemfile groups
  • Consistent formatting
  • Resist the urge to Ruby
  • Minimize git dependencies
  • Do you really need that gem?
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档