-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathktreplmysql.rb
69 lines (66 loc) · 1.68 KB
/
ktreplmysql.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
require 'dbi'
require 'base64'
hostname = "localhost"
dbname = "kttest"
username = "root"
password = ""
rtspath = "ktreplprint.rts"
begin
dbh = DBI::connect("dbi:Mysql:#{dbname}:#{hostname}", username, password)
sthins = dbh.prepare("INSERT INTO kttest ( k, v, xt ) VALUES ( ?, ?, ? )" +
" ON DUPLICATE KEY UPDATE v = ?, xt = ?;")
sthrem = dbh.prepare("DELETE FROM kttest WHERE k = ?;")
sthclr = dbh.prepare("DELETE FROM kttest;")
mode = File::Constants::RDWR | File::Constants::CREAT
File::open(rtspath, mode) do |rtsfile|
while true
begin
line = $stdin.readline
rescue
break
end
line = line.strip
fields = line.split("\t")
next if fields.length < 4
rts = fields[0]
rsid = fields[1]
rdbid = fields[2]
rcmd = fields[3]
args = []
i = 4
while i < fields.length
args.push(fields[i].unpack("m")[0])
i += 1
end
case rcmd
when "set"
if args.length >= 2
key = args[0]
value = args[1][5,args[1].length]
nums = args[1].unpack("C5")
xt = 0
nums.each do |num|
xt = (xt << 8) + num
end
xt = 1 << 32 if xt > (1 << 32)
xt = Time::at(xt).strftime("%Y-%m-%d %H:%M:%S")
sthins.execute(key, value, xt, value, xt)
end
when "remove"
if args.length >= 1
key = args[0]
sthrem.execute(key)
end
when "clear"
sthclr.execute()
end
rtsfile.pos = 0
rtsfile.printf("%020d\n", rts)
end
end
rescue Exception => e
printf("Error: %s\n", e)
ensure
dbh.disconnect if dbh
end
exit 0