-
-
Save stackdump/1479007 to your computer and use it in GitHub Desktop.
List local memcached keys using Ruby
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env ruby | |
require 'net/telnet' | |
cache_dump_limit = 100 | |
localhost = Net::Telnet::new("Host" => "localhost", "Port" => 11211, "Timeout" => 3) | |
slab_ids = [] | |
localhost.cmd("String" => "stats items", "Match" => /^END/) do |c| | |
matches = c.scan(/STAT items:(\d+):/) | |
slab_ids = matches.flatten.uniq | |
end | |
puts | |
puts "Expires At\t\t\t\tCache Key" | |
puts '-'* 80 | |
slab_ids.each do |slab_id| | |
localhost.cmd("String" => "stats cachedump #{slab_id} #{cache_dump_limit}", "Match" => /^END/) do |c| | |
matches = c.scan(/^ITEM (.+?) \[(\d+) b; (\d+) s\]$/).each do |key_data| | |
(cache_key, bytes, expires_time) = key_data | |
humanized_expires_time = Time.at(expires_time.to_i).to_s | |
puts "[#{humanized_expires_time}]\t#{cache_key}" | |
end | |
end | |
end | |
puts | |
localhost.close |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
I ran into an issue where for whatever reason (most likely latency to another host) the telnet connection fetching slab_ids ran multiple times. I resolved this by just appending to the slab_ids array and then uniq'ing it after the loop. My mods are at https://gist.github.com/2775527