aboutsummaryrefslogtreecommitdiff
path: root/examples/redis-pubsub.tcl
blob: 0bf837228d546313575c54ea73dd4e03eb5320cb (plain)
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
70
71
72
73
74
#!/usr/bin/env jimsh

# Requires the redis extension
package require redis

# A redis server should be running either on localhost 6379
# or on the given host port
#
# Usage: redis-pubsub.tcl ?pub|sub? ?host:addr?
#
# If pub or sub is not given, forks and does both

if {[lindex $argv 0] in {pub sub}} {
    # Run in single process mode
    set argv [lassign $argv op]
} else {
    # fork before connecting so that both processes don't share
    # a connection
    if {[os.fork] == 0} {
        # child subscribes
        set op sub
    } else {
        set op pub
    }
}

try {
    lassign $argv addr
    if {$addr eq ""} {
            set addr localhost:6379
    }
    set r [redis [socket stream $addr]]
} on error msg {
    puts [errorInfo $msg]
    exit 1
}

if {$op eq "sub"} {
    # read will generate a bgerror if the server goes away
    proc bgerror {msg} {
        set ::done "$::op: $msg"
    }

    $r SUBSCRIBE chin
    $r SUBSCRIBE chan

    proc sub_timeout {} {
        set ::done "$::op: quitting on idle"
    }

    $r readable {
        after cancel $afterid
        set result [$r read]
        puts "$op: $result"
        set afterid [after 2000 sub_timeout]
    }
    # If no message for 2 seconds, stop
    set afterid [after 2000 sub_timeout]
    vwait done
    puts $done
} else {
    try {
        loop i 1 15 {
            $r PUBLISH chan PONG$i
            puts "$op: chan PONG$i"
            after 250
            $r PUBLISH chin PING$i
            puts "$op: chin PING$i"
            after 250
        }
    } on error msg {
        puts "$op: $msg"
    }
}