1
在我gemspec文件:管理依赖性冲突而在Gemfile.lock的
- 我有一个名为ZCONFIG宝石依赖性,即明确要求净SSH版本2.6.8
- 我还使用净SFTP,这又需要净-SSH版本> = 2.6.5
当我bundle install
,捆绑器足够聪明来识别这两种宝石的需求,并正确地标识2.6.8作为版本净的ssh的安装。
net-sftp (2.1.2)
net-ssh (>= 2.6.5)
...
net-ssh (2.6.8)
...
zconfig (0.2.7)
mysql (~> 2.9.1)
mysql2 (~> 0.3.13)
net-ssh (~> 2.6.8)
net-ssh-gateway (~> 1.2.0)
sequel (~> 4.1.0)
sqlite3 (~> 1.3.7)
到目前为止,而在远程服务器上测试,我已经克隆项目,并与bundle install --deployment
安装这些宝石,然后用bundle exec ..
但是运行与本地供应商instaled宝石的项目,我现在已经完成了开发工作,并且我已经将项目打包成了gem并将其安装在远程服务器上。问题是,在执行时,宝石红宝石不符合我的Gemfile.lock的规范,并使用网SSH 2.7.0,这会导致冲突:
/usr/local/rvm/rubies/ruby-1.9.2-p290/lib/ruby/site_ruby/1.9.1/rubygems/specification.rb:1615:in `raise_if_conflicts': Unable to activate zconfig-0.2.7, because net-ssh-2.7.0 conflicts with net-ssh (~> 2.6.8) (Gem::LoadError)
有没有办法做到像bundle exec my_gem
所以它使用Gemfile.lock规范?
当然可以用'bundle exec'启动远程服务器。远程服务器现在如何启动? 另一种选择可能是从服务器上删除2.7.0版本的gem。 (假设该服务器上没有其他人需要它......) – froderik
如果您将项目打包为gem,则需要在您的'project.gemspec'中指定依赖关系。 – phoet