|
@@ -0,0 +1,49 @@
|
|
|
+<?php
|
|
|
+require_once '../lib/Predis.php';
|
|
|
+
|
|
|
+// Create a client and disable r/w timeout on the socket
|
|
|
+$redis = new \Predis\Client('redis://127.0.0.1:6379/?read_write_timeout=-1', 'dev');
|
|
|
+
|
|
|
+// Initialize a new pubsub context
|
|
|
+$pubsub = new \Predis\PubSubContext($redis);
|
|
|
+
|
|
|
+// Subscribe to your channels
|
|
|
+$pubsub->subscribe('control_channel');
|
|
|
+$pubsub->subscribe('notifications');
|
|
|
+
|
|
|
+// Start processing the pubsup messages. Open a terminal and use redis-cli
|
|
|
+// to push messages to the channels. Examples:
|
|
|
+// ./redis-cli PUBLISH notifications "this is a test"
|
|
|
+// ./redis-cli PUBLISH control_channel quit_loop
|
|
|
+foreach ($pubsub as $i => $message) {
|
|
|
+ switch ($message->kind) {
|
|
|
+ case 'subscribe':
|
|
|
+ echo "Subscribed to {$message->channel}\n";
|
|
|
+ break;
|
|
|
+ case 'message':
|
|
|
+ if ($message->channel == 'control_channel') {
|
|
|
+ if ($message->payload == 'quit_loop') {
|
|
|
+ echo "Aborting pubsub loop...\n";
|
|
|
+ $pubsub->unsubscribe();
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ echo "Received an unregognized command: {$message->payload}.\n";
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ echo "Received the following message from {$message->channel}:\n",
|
|
|
+ " {$message->payload}\n\n";
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// Always unset the pubsub context instance when you are done! The
|
|
|
+// class destructor will take care of cleanups and prevent protocol
|
|
|
+// desynchronizations between the client and the server.
|
|
|
+unset($pubsub);
|
|
|
+
|
|
|
+// Say goodbye :-)
|
|
|
+$info = $redis->info();
|
|
|
+print_r("Goodbye from Redis v{$info['redis_version']}!\n");
|
|
|
+?>
|