草庐IT

java基于TreeMap或ConcurrentSkipListMap实现数据的范围查找

全部标签

ruby - Rails,如何迁移大量数据?

我有一个运行旧版本Spree(开源购物车)的Rails3应用程序。我正在将它更新到最新版本。这需要我在数据库上运行大量迁移以与最新版本兼容。但是,应用程序当前的数据库大约为300mb,要在我的本地计算机(macosx10.7、4gbram、2.4GHzCore2Duo)上运行迁移需要三天以上的时间才能完成。我能够使用AmazonEC2实例(高I/O按需实例,四倍超大)将这个时间减少到仅16小时。但是16小时仍然太长,因为我必须关闭网站才能执行此更新。有没有人有任何其他建议来降低这个时间?或提高迁移性能的任何提示?仅供引用:在Amazon实例上使用Ruby1.9.2和Ubuntu。

ruby-on-rails - 我的应用程序一直在创建数据库连接,我该如何追踪原因?

我有一个在Heroku上运行的RubyonRails应用程序。我不断在日志中收到这些消息:2015-05-05T16:11:14Zapp[postgres.27102]:[AQUA]connectionreceived:host=xx.xxx.xx.26port=602782015-05-05T16:11:14Zapp[postgres.27102]:[AQUA]connectionauthorized:user=postgresdatabase=somedb2015-05-05T16:11:14Zapp[postgres.27103]:[AQUA]connectionreceived

ruby - 我应该如何构建我的(moSTLy)基于文本的游戏服务器?

想想MUD/MUCK,但可能还有头像或现场插图。我选择的语言是ruby。我需要处理多个持久连接,数据在服务器和它的各种客户端之间异步传输。单个数据库必须根据客户端session中发生的事件保持最新。每个客户端session中的事件可能需要立即更新多个其他客户端(用户进入房间;用户向另一个用户发送私有(private)消息)。这是一个目标项目和一个学习项目,所以我打算重新发明一两个轮子来了解更多关于并发网络编程。但是,我对并发编程和网络编程都不熟悉;以前,我几乎只在Web应用程序中的非持久同步HTTP请求领域工作。所以,我想确保我正在重新发明正确的轮子。根据emboss的出色回答,我已经

ruby-on-rails - Heroku 应用程序的数据库管理

我对Rails和Heroku都很陌生,但我正在认真考虑将其用作部署我的Ruby/Rails应用程序的平台。我想使用Heroku的所有功能,所以我更喜欢Heroku管理的“嵌入式”PostgreSQL,而不是AmazonRDSforMySQL的插件,但如果无法在SQL客户端...我知道在一个制作精良的应用程序中你不需要访问数据库,但有一些情况(将行添加到配置表,查看未映射到View中的数据,更新一些列以解决调试问题,性能监控,运行报告等查询)当这可能很好时......你是如何解决这个问题的?在由Heroku提供支持的真实应用中,您有什么体验?谢谢! 最佳答案

ruby-on-rails - 当前用户的 Rails 范围查找

我将Rails3与Devise一起用于用户身份验证。假设我有一个启用了Devise的用户模型和一个产品模型,并且一个用户有很多产品。在我的ProductsController中,我希望我的find方法受current_user限制,即。@product=current_user.products.find(params[:id])除非用户是管理员用户,即current_user.admin?现在,我几乎在每个方法中都运行该代码,这看起来很乱:ifcurrent_user.admin?@product=Product.find(params[:id])else@product=curre

ruby-on-rails - 类似 Rails 的数据库迁移?

是否有任何易于安装/使用(在unix上)的数据库迁移工具,例如RailsMigrations?我真的很喜欢这个想法,但是纯粹为了管理我的数据库迁移而安装ruby​​/rails似乎有些过分了。 最佳答案 只需使用ActiveRecord和一个简单的Rakefile。例如,如果您将迁移放在db/migrate目录中,并且有一个包含您的数据库配置的database.yml文件,那么这个简单的Rakefile应该可以工作:Rakefile:require'active_record'require'yaml'desc"Migratethe

ruby - 我怎样才能对我的默认范围进行 rspec 测试

我的模型有default_scope(:order=>'created_at')我的测试(rspec、factorygirl、shoulda等)是:require'spec/spec_helper.rb'describeCatMembershipdocontext"isvalid"dosubject{Factory.build(:cat_membership)}it{shouldbe_valid}it{shouldbelong_to:cat}it{shouldbelong_to:cat_group}it{shouldhave_db_column(:start_date)}it{shou

ruby-on-rails - Rails JSON API 的基于 token 的身份验证

我在Rails中制作API。对于普通身份验证,我们使用设计,但在API中如何实现身份验证设计。gem'devise_token_auth'有人喜欢这个gem用于身份验证,但没有可用的教程。如何在RailsAPI中实现身份验证? 最佳答案 你能做的最好的事情就是跟随githubtutorials哪些最有可能是最新的。首先你应该遵循TLDR部分。请注意,前端开发人员需要了解usagespecification。.最后,您想阅读文档。以下是一些可能有帮助的示例:路线Rails.application.routes.drawdo#Stuff

ruby - 在 ruby​​ 中以散列形式返回结构数据

没有将标准ruby​​结构的数据作为散列(成员、值对)返回的方法是否有正当理由?看到结构和散列具有非常相似的用例,我很惊讶不存在这样的方法。或者是,我太盲目了?它很容易实现(我现在已经这样做了),但是标准库中缺少这样的功能,让我觉得我可能没有真正掌握ruby​​中结构的概念。 最佳答案 RubyOpenStruct#marshall_dump和Struct#each_pair:Person=Struct.new(:name,:age)person=Person.new("Jamie",23)person_hash=Hash[pers

ruby - 在字符串数组中查找字符串的最快方法

脚本必须验证一个预定义的IP是否存在于大量IP中。目前我编写的函数是这样的(说“ips”是我的IP数组,“ip”是预定义的ip)ips.eachdo|existsip|ifip==existsipputs"ipexists"return1endendputs"ipdoesn'texist"returnnil有没有更快的方法来做同样的事情?编辑:我可能表达错误了。我可以做array.include吗?但我想知道的是:array.include是什么?给我最快结果的方法? 最佳答案 您可以使用Set.它是在Hash之上实现的,对于大数据