-
Notifications
You must be signed in to change notification settings - Fork 45
/
README.txt
187 lines (146 loc) · 7.53 KB
/
README.txt
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
#@
#@ Dklab Realplexor: Comet server which handles 1000000+ parallel browser connections
#@ Author: Dmitry Koterov, dkLab (C)
#@ GitHub: http://github.com/DmitryKoterov/
#@ Homepage: http://dklab.ru/lib/dklab_realplexor/
#@
BUILD A BINARY FROM C++ SOURCES
-------------------------------
Realplexor comes in two versions with exactly same functions and even exactly
same (shared) smoke tests code:
1. Perl version: treated as a prototype and development/debugging playground.
It's quite slow and is not recommended in production.
2. C++ version: fast, but you should build it by yourself from sources
(it's quite easy in Ubuntu 12.04), see cpp/ directory.
When you build a binary version of Realplexor, the binary is put to the current
directory; it will be used instead of Perl version automatically.
INSTALLATION ON LINUX
---------------------
Note that Realplexor works on Linux only, other OS (Windows, MacOS, FreeBSD)
are not known to be supported.
0. Build a binary file ./dklab_realplexor from C++ source code if you can
(see cpp/ directory for instructions).
1. If you decide to use a Perl version, run ./dklab_realplexor.pl manually
and check that all needed libraries are installed. If not, install them:
- For RHEL (RedHat, CentOS):
# yum install gcc
# perl -MCPAN -e "install EV"
- For Debian (or Ubuntu):
# apt-get install gcc
# perl -MCPAN -e "install EV"
2. Copy Realplexor to /opt/dklab_realplexor (or you may create a symlink).
# cp -a . /opt/dklab_realplexor
- or -
# ln -s `pwd` /opt/dklab_realplexor
3. Create /etc/dklab_realplexor.conf if you need a custom configuration.
(You may create a symlink instead of creating the file.)
# cat > /etc/dklab_realplexor.conf
$CONFIG{WAIT_ADDR} = [ '1.2.3.4:80' ]; # your IP address and port
$CONFIG{IN_ADDR} = [ '5.6.7.8:10010' ]; # for IN line
return 1;
^D
- or -
# ln -s /path/to/your/config.conf /etc/dklab_realplexor.conf
4. Use bundled init-script to start Realplexor as a Linux service:
# ln -s /opt/dklab_realplexor/dklab_realplexor.init /etc/init.d/dklab_realplexor
5. Tell your system to start Realplexor at boot:
- For RHEL (RedHat, CentOS):
# chkconfig --add dklab_realplexor
# chkconfig dklab_realplexor on
- For Debian (or Ubuntu):
# update-rc.d dklab_realplexor defaults
# update-rc.d dklab_realplexor start
SYNOPSIS
--------
1. In JavaScript code, execute:
<script type="text/javascript" src="/path/to/dklab_realplexor.js"></script>
var realplexor = new Dklab_Realplexor("http://rpl.yoursite.com/");
realplexor.subscribe("alpha", function(data) { alert("alpha: " + data) });
realplexor.subscribe("beta", function(data) { alert("beta: " + data) });
realplexor.execute();
2. In PHP code, execute:
require dirname(__FILE__) . '/Dklab/Realplexor.php';
$realplexor = new Dklab_Realplexor("127.0.0.1", "10010");
$realplexor->send(array("alpha", "beta"), "hello!");
3. See more details in Realplexor documentation.
LOG MNEMONICS
-------------
pairs_by_fhs
Number of active TCP connections on WAIT line (clients).
data_to_send
Number of IDs with non-empty command queue.
connected_fhs
Number of IDs which are listened by at least one client.
online_timers
Number of "online" client identifiers. Client is treated as online if:
- it has an active connection;
- or it does not have a connection, but disconnected no more than
OFFLINE_TIMEOUT seconds ago.
cleanup_timers
Number of IDs which queue must be cleaned if no activity is present for
a long time. This is a unused IDs garbage collector statistics.
events
How many events (e.g. ONLINE/OFFLINE status changes) are collected
by realplexor. Event queue is limited by size.
CHANGELOG
---------
* Dklab Realplexor 2014-01-14: v1.41
- [MIN] Brushed up C++ version, Ubuntu 12.04 build instructions.
- [MIN] Banner comments added to source files.
- [MIN] Tabs to spaces.
- [BUG] GCC 4.7 compatibility & GCC bug work-around
* Dklab Realplexor 2011-07-28: v1.40
- [NEW] Python API added (experimental)
- [NEW] Added missed "return this" for chained JS calls.
- [BUG] Firefox 4 bugfix against 'attempt to run compile-and-go script on a cleared scope'.
- [BUG] Minor changes & better support for phpt tests.
- [BUG] No OFFLINE event should be generated until the last connection with ID is disconnected.
- [BUG] If no IDs are subscribed in JS, do not connect to the server with empty ID list.
* Dklab Realplexor 2010-08-11: v1.32
- [SPD] When empty HTTP body is passed to IN connection, it is now ignored, no warnings generated.
- [SPD] Remove old data from channels BEFORE data processing/sending.
- [BUG] Use print instead of syswrite, because for large amount of data syswrite sometimes
returns before all this data is transmitted.
* Dklab Realplexor 2010-04-16: v1.31
- [BUG] Perl does not call flush() automatically before socket shutdown(). It
sometimes (unstable!) causes unexpected SIGPIPEs and data loss. Fixed: now flush()
is called manually.
- [BUG] STATS command is not processed twice anymore.
- [NEW] Ability to limit memory usage and auto-restart the daemon if it
consumes too much memory. (Note that unsent data is lost during this restart.)
- [NEW] PHP API: cmdOnlineWithCounters(): for each online ID also returns
the number of browsers connected just now (it is NOT a "number of online
users who listen this channel", but its approximation).
- [BUG] Minor fixes in clean_old_data_for_id (bug is not reproduced,
but now surrounding code is better).
- [NEW] Visibility:hidden for IFRAME. It is good when BODY has relative position.
- [BUG] Allow to pass a scalar to 2nd parameter of cmdWatch($fromPos, $idPrefixes).
* Dklab Realplexor 2010-02-27: v1.30
- [SPD] Use EV library (http://search.cpan.org/~mlehmann/EV-3.9/EV.pm)
instead of libevent. It is faster and has no memory leaks.
* Dklab Realplexor 2010-01-30: v1.24
- [BUG] Avoid warnings in log on unexpected disconnect.
- [NEW] Refactoring and profiler support.
- [SPD] Do not create extra shell while calling ulimit.
- [NEW] Support for per-config log facility.
- [SPD] Profiler tool with IN line ignorance. Avoid BigFloat in events: 45% speedup. Apache ab patched utility.
- [SPD] Keep channels pre-sorted after addition. It speedups 60%, because we need less cursor comparisions.
- [SPD] STDOUT buffering in non-verbose mode. More verbosity levels. Logger speedup. Custom config for profiler script.
* Dklab Realplexor 2009-12-26: v1.23
- [BUG] Empty identifier passed to IN line ("identifier=") caused warnings.
- [SPD] Lower the number of useless debug lines and connection's name() calls.
- [BUG] Improved init script: more time to restart and better signal handling.
* Dklab Realplexor 2009-12-24: v1.22
- [BUG] SIGPIPE causes the script to restart on some unexpected client's disconnects.
* Dklab Realplexor 2009-12-22: v1.21
- [NEW] ID queue is cleaned after CLEAN_ID_AFTER seconds when no data arrived
(previously OFFLINE_TIMEOUT was used for that).
- [NEW] To unsubscribe all callbacks from a channel: rpl.unsubscribe("channel", null).
* Dklab Realplexor 2009-12-16: v1.15
- [NEW] When IDs list is long, JS API uses POST request instead of GET.
- [NEW] IN line now fully supports HTTP POST.
- [NEW] Non-200 responses from IN line are converted to exceptions.
- [NEW] Content-Length verification in PHP API.
- [NEW] Support for SSL in IN line for PHP API (use 443 port).
- [BUG] If callback called execute(), extra request was performed.
- [BUG] Referrer header was not ignored by server engine (bad if it contains IFRAME marker).