ruby-on-rails - Rails 和 Redis

标签 ruby-on-rails ruby redis

在我的控制台上启动我的 redis 服务器后使用:

redis-server

我像这样执行以下 ruby​​ 脚本:

script/user/generate_roster_kids.rb start

但它不起作用,我得到:

generate_roster_kids] Pid not found, process seems doesn't exist!
[generate_roster_kids] Process daemonized with pid 1110 with thread and Forever v.0.3.2

如果我再次执行相同的命令,我会得到以下信息:

generate_roster_kids] Found pid 1110...
[generate_roster_kids] Waiting the daemon's death . DONE
[generate_roster_kids] Process daemonized with pid 1385 with thread and Forever v.0.3.2

但它不起作用,我做错了什么。

这是 generate_roster_kids.rb 文件的内容:

#!/usr/bin/ruby
require 'rubygems' unless defined?(Gem)
require 'forever'
require 'redis'

Forever.run do
  REDIS = Redis.new()
  #
  # dir  "foo"     # Default: File.expand_path('../../', __FILE__)
  # file "bar"     # Default: __FILE__
  log  "bar.log" # Default: File.expand_path(dir, '/log/[file_name].log')
  # pid  "bar.pid" # Default: File.expand_path(dir, '/tmp/[file_name].pid')

  every 2.seconds do
    # REDIS.DEL :busy

    # begin
    #   REDIS.SUNIONSTORE :busy, REDIS.keys('Busy:*') 
    # rescue 
    #   REDIS.SUNIONSTORE :busy, nil
    # end

    REDIS.SUNIONSTORE :busy, REDIS.keys('Busy:*') rescue REDIS.SUNIONSTORE :busy, nil
    REDIS.EXPIRE :busy, 3

    # online = REDIS.SUNION :online, REDIS.keys('Online:*')
    # diff = REDIS.SDIFF online, :busy

    # REDIS.SDIFFSTORE :online, (REDIS.SUNION :online, REDIS.keys('Online:*')), :busy
    # REDIS.DEL :online

    # begin
    #   REDIS.SUNIONSTORE :online, REDIS.keys('Online:*') 
    # rescue 
    #   REDIS.SUNIONSTORE :online, nil
    # end

    REDIS.SUNIONSTORE :online, REDIS.keys('Online:*') rescue REDIS.SUNIONSTORE :online, nil
    REDIS.EXPIRE :online, 3
  end

end

这段代码是由年长的开发人员制作的,但他已经不在了,我需要在我的本地机器上完成它。

提前致谢

更新


我检查了我的 redis-cli MONITOR,一切都“运行良好”,但是我遇到了以下问题,当用户将他的状态更改为在线时,我在 MONITOR 上看到了这个:

1400661418.908947 [0 127.0.0.1:57453] "DEL" "Busy:537c63ea20db9040d2000332"
1400661418.909909 [0 127.0.0.1:57453] "SREM" "busy" "537c63ea20db9040d2000332"
1400661418.910687 [0 127.0.0.1:57453] "sadd" "Online:537c63ea20db9040d2000332" "537c63ea20db9040d2000332"
1400661418.911705 [0 127.0.0.1:57453] "expire" "Online:537c63ea20db9040d2000332" "2"
1400661419.436520 [0 127.0.0.1:62027] "keys" "Busy:*"
1400661419.437205 [0 127.0.0.1:62027] "SUNIONSTORE" "busy" ""
1400661419.437489 [0 127.0.0.1:62027] "EXPIRE" "busy" "3"
1400661419.437757 [0 127.0.0.1:62027] "keys" "Online:*"
1400661419.438070 [0 127.0.0.1:62027] "SUNIONSTORE" "online" "Online:537c63ea20db9040d2000332"

如果用户变为 BUSY,我会看到:

400661508.795043 [0 127.0.0.1:57453] "DEL" "Online:537c63ea20db9040d2000332"
1400661508.796853 [0 127.0.0.1:57453] "SREM" "online" "537c63ea20db9040d2000332"
1400661508.798088 [0 127.0.0.1:57453] "sadd" "Busy:537c63ea20db9040d2000332" "537c63ea20db9040d2000332"
1400661508.799496 [0 127.0.0.1:57453] "expire" "Busy:537c63ea20db9040d2000332" "2"
1400661509.157067 [0 127.0.0.1:62027] "keys" "Busy:*"
1400661509.157751 [0 127.0.0.1:62027] "SUNIONSTORE" "busy" "Busy:537c63ea20db9040d2000332"

但是当我使用 redisdesktopmanager 检查我的 redis 数据库时,我没有看到任何新记录,但是如果我尝试使用 redis-cli 手动创建记录,记录会成功创建,这里可能是什么问题????

最佳答案

缩小问题范围的一种方法是使用 redis-cli 工具连接到 Redis 服务器(它似乎连接到运行脚本的系统上的 Redis 实例,并发出命令 MONITOR 在生成的 CLI shell 中。

然后运行脚本并观察输入的命令。当然,您还需要确保在运行脚本的系统上运行的 Redis 副本具有您需要的数据。或者,您需要更改 Redis 连接命令以连接到数据所在的远程计算机。

编辑更新信息

所以代码在键上设置了 2-3 秒的过期时间。这是一个非常很短的超时。很可能当您查找记录时,这些记录已经过期。

例如,“busy”上的[EXPIRE][1]告诉Redis在修改后三秒忽略“busy”。我不确定那是你想要的。 “Busy:...”的过期还告诉 Redis 在两秒后忽略该键。

我建议将 expire 的值更改为更长的值,以便按照您想要的方式对其进行验证。您会比我更清楚 2-3 秒是否是您使用的“正确”到期时间,但我怀疑它需要更长的时间。如果您希望在 2 秒后使用户 session 过期并如此快速地使所有繁忙 session 的集合过期是正确的,那么监视命令将是您验证它们正在发送的方式 - 而不是寻找可能在该时间过期的 key 您可以发送命令来检索它们。

如果可能,您还应该考虑尝试替换 keys 命令,因为如果您的 key 空间变大,这可能会降低性能。

关于ruby-on-rails - Rails 和 Redis,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23676921/

相关文章:

ruby-on-rails - cucumber :在 Hook 之前对所有场景只运行一次

ruby-on-rails - 如何使 Rails 模型中的 default_scope 动态化?

ruby-on-rails - 在 Rails 中呈现路由错误的 404 页面

java - 在 Windows 上使用 Redis-cli 在 Redis 中加载 CSV 文件

jquery - 将页面 View 显示为 jQuery-UI 对话框

mysql - 由于错误的迁移而尝试重置我的数据库,如果没有 SQLException 甚至无法重置

ruby-on-rails - 最佳实践 : Namespace or resources for admin interface dashboard Mongoid

ruby-on-rails - 如何使第二个场景直接跟随 Cucumber 中的第一个场景

java - 用于分发(分片)集合(如列表、集合等)键的任何解决方法

ruby-on-rails-4 - 在每个用户级别将最常访问的项目存储在 redis 中