X-Git-Url: https://git.saurik.com/redis.git/blobdiff_plain/5ad3c8c852de981482afb28a8c2659456b2a8b3b..2ebd2720b37dcca3b6e0c18377bd69e9eaf541fc:/utils/redis-sha1.rb diff --git a/utils/redis-sha1.rb b/utils/redis-sha1.rb index b240e2ca..24498e25 100644 --- a/utils/redis-sha1.rb +++ b/utils/redis-sha1.rb @@ -16,22 +16,37 @@ def redisSha1(opts={}) sha1="" r = Redis.new(opts) r.keys('*').sort.each{|k| - sha1 = Digest::SHA1.hexdigest(sha1+k) vtype = r.type?(k) if vtype == "string" + len = 1 + sha1 = Digest::SHA1.hexdigest(sha1+k) sha1 = Digest::SHA1.hexdigest(sha1+r.get(k)) elsif vtype == "list" - sha1 = Digest::SHA1.hexdigest(sha1+r.list_range(k,0,-1).join("\x01")) + len = r.llen(k) + if len != 0 + sha1 = Digest::SHA1.hexdigest(sha1+k) + sha1 = Digest::SHA1.hexdigest(sha1+r.list_range(k,0,-1).join("\x01")) + end elsif vtype == "set" - sha1 = Digest::SHA1.hexdigest(sha1+r.set_members(k).to_a.sort.join("\x02")) + len = r.scard(k) + if len != 0 + sha1 = Digest::SHA1.hexdigest(sha1+k) + sha1 = Digest::SHA1.hexdigest(sha1+r.set_members(k).to_a.sort.join("\x02")) + end elsif vtype == "zset" - sha1 = Digest::SHA1.hexdigest(sha1+r.zrange(k,0,-1).join("\x01")) + len = r.zcard(k) + if len != 0 + sha1 = Digest::SHA1.hexdigest(sha1+k) + sha1 = Digest::SHA1.hexdigest(sha1+r.zrange(k,0,-1).join("\x01")) + end end + # puts "#{k} => #{sha1}" if len != 0 } sha1 end host = ARGV[0] || "127.0.0.1" port = ARGV[1] || "6379" -puts "Performing SHA1 of Redis server #{host} #{port}" -p "Dataset SHA1: #{redisSha1(:host => host, :port => port.to_i)}" +db = ARGV[2] || "0" +puts "Performing SHA1 of Redis server #{host} #{port} DB: #{db}" +p "Dataset SHA1: #{redisSha1(:host => host, :port => port.to_i, :db => db)}"