projects
/
l2tpns.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
more chap
[l2tpns.git]
/
cluster.c
diff --git
a/cluster.c
b/cluster.c
index
7e69f05
..
9cead15
100644
(file)
--- a/
cluster.c
+++ b/
cluster.c
@@
-1,6
+1,6
@@
// L2TPNS Clustering Stuff
// L2TPNS Clustering Stuff
-char const *cvs_id_cluster = "$Id: cluster.c,v 1.
27 2004/12/20 07:23:42
bodea Exp $";
+char const *cvs_id_cluster = "$Id: cluster.c,v 1.
36 2005/05/07 10:14:33
bodea Exp $";
#include <stdio.h>
#include <stdlib.h>
#include <stdio.h>
#include <stdlib.h>
@@
-406,18
+406,18
@@
void master_update_counts(void)
if ( walk_session_number > config->cluster_highest_sessionid)
walk_session_number = 1;
if ( walk_session_number > config->cluster_highest_sessionid)
walk_session_number = 1;
- if (!sess_
count[walk_session_number].cin && !sess_count
[walk_session_number].cout)
+ if (!sess_
local[walk_session_number].cin && !sess_local
[walk_session_number].cout)
continue; // Unused. Skip it.
b[c].sid = walk_session_number;
continue; // Unused. Skip it.
b[c].sid = walk_session_number;
- b[c].in = sess_
count
[walk_session_number].cin;
- b[c].out = sess_
count
[walk_session_number].cout;
+ b[c].in = sess_
local
[walk_session_number].cin;
+ b[c].out = sess_
local
[walk_session_number].cout;
if (++c > MAX_B_RECS) // Send a max of 400 elements in a packet.
break;
// Reset counters.
if (++c > MAX_B_RECS) // Send a max of 400 elements in a packet.
break;
// Reset counters.
- sess_
count[walk_session_number].cin = sess_count
[walk_session_number].cout = 0;
+ sess_
local[walk_session_number].cin = sess_local
[walk_session_number].cout = 0;
}
if (!c) // Didn't find any that changes. Get out of here!
}
if (!c) // Didn't find any that changes. Get out of here!
@@
-571,38
+571,42
@@
void cluster_check_master(void)
++count;
}
++count;
}
- if (session[i].tunnel == T_FREE) { // Unused session. Add to free list.
+ if (!session[i].opened) { // Unused session. Add to free list.
+ memset(&session[i], 0, sizeof(session[i]));
+ session[i].tunnel = T_FREE;
session[last_free].next = i;
session[i].next = 0;
last_free = i;
session[last_free].next = i;
session[i].next = 0;
last_free = i;
+ continue;
}
}
- // Reset
all the
idle timeouts..
+ // Reset idle timeouts..
session[i].last_packet = time_now;
session[i].last_packet = time_now;
+ // Reset die relative to our uptime rather than the old master's
+ if (session[i].die) session[i].die = TIME;
+
// Accumulate un-sent byte counters.
// Accumulate un-sent byte counters.
- session[i].cin += sess_
count
[i].cin;
- session[i].cout += sess_
count
[i].cout;
- session[i].total_cin += sess_
count
[i].cin;
- session[i].total_cout += sess_
count
[i].cout;
+ session[i].cin += sess_
local
[i].cin;
+ session[i].cout += sess_
local
[i].cout;
+ session[i].total_cin += sess_
local
[i].cin;
+ session[i].total_cout += sess_
local
[i].cout;
- sess_
count[i].cin = sess_count
[i].cout = 0;
+ sess_
local[i].cin = sess_local
[i].cout = 0;
- sess
ion[i].radius = 0;
// Reset authentication as the radius blocks aren't up to date.
+ sess
_local[i].radius = 0;
// Reset authentication as the radius blocks aren't up to date.
if (session[i].unique_id >= high_unique_id) // This is different to the index into the session table!!!
high_unique_id = session[i].unique_id+1;
if (session[i].unique_id >= high_unique_id) // This is different to the index into the session table!!!
high_unique_id = session[i].unique_id+1;
-
session[i].tbf_in = session[i].tbf_out = 0; // Remove stale pointers from old master.
throttle_session(i, session[i].throttle_in, session[i].throttle_out);
session[i].tbf_in = session[i].tbf_out = 0; // Remove stale pointers from old master.
throttle_session(i, session[i].throttle_in, session[i].throttle_out);
- if (session[i].tunnel != T_FREE && i > config->cluster_highest_sessionid)
- config->cluster_highest_sessionid = i;
+ config->cluster_highest_sessionid = i;
}
session[last_free].next = 0; // End of chain.
}
session[last_free].next = 0; // End of chain.
- last_id = high_unique_id;
// Keep track of the highest used session ID.
+ last_id = high_unique_id; // Keep track of the highest used session ID.
become_master();
become_master();
@@
-650,12
+654,12
@@
static void cluster_check_sessions(int highsession, int freesession_ptr, int hig
config->cluster_undefined_sessions = 0;
for (i = 1 ; i < MAXSESSION; ++i) {
if (i > highsession) {
config->cluster_undefined_sessions = 0;
for (i = 1 ; i < MAXSESSION; ++i) {
if (i > highsession) {
-
session[i].tunnel = 0
; // Defined.
+
if (session[i].tunnel == T_UNDEF) session[i].tunnel = T_FREE
; // Defined.
continue;
}
continue;
}
- if (session[i].tunnel != T_UNDEF)
- continue;
- ++config->cluster_undefined_sessions;
+
+ if (session[i].tunnel == T_UNDEF)
+
++config->cluster_undefined_sessions;
}
// Clear out defined tunnels, counting the number of
}
// Clear out defined tunnels, counting the number of
@@
-663,12
+667,12
@@
static void cluster_check_sessions(int highsession, int freesession_ptr, int hig
config->cluster_undefined_tunnels = 0;
for (i = 1 ; i < MAXTUNNEL; ++i) {
if (i > hightunnel) {
config->cluster_undefined_tunnels = 0;
for (i = 1 ; i < MAXTUNNEL; ++i) {
if (i > hightunnel) {
- tunnel[i].state = TUNNELFREE; // Defined.
+
if (tunnel[i].state == TUNNELUNDEF)
tunnel[i].state = TUNNELFREE; // Defined.
continue;
}
continue;
}
- if (tunnel[i].state != TUNNELUNDEF)
- continue;
- ++config->cluster_undefined_tunnels;
+
+ if (tunnel[i].state == TUNNELUNDEF)
+
++config->cluster_undefined_tunnels;
}
}
@@
-868,7
+872,7
@@
int cluster_send_session(int sid)
}
if (forked) {
}
if (forked) {
- LOG(0, sid, 0, "cluster_send_session called from child process!
"
\n");
+ LOG(0, sid, 0, "cluster_send_session called from child process!\n");
return -1;
}
return -1;
}
@@
-1033,7
+1037,9
@@
static int cluster_handle_bytes(char *data, int size)
session[b->sid].cin += b->in;
session[b->sid].cout += b->out;
session[b->sid].cin += b->in;
session[b->sid].cout += b->out;
- session[b->sid].last_packet = time_now; // Reset idle timer!
+
+ if (b->in)
+ session[b->sid].last_packet = time_now; // Reset idle timer!
size -= sizeof(*b);
++b;
size -= sizeof(*b);
++b;
@@
-1358,6
+1364,11
@@
int processcluster(char *data, int size, in_addr_t addr)
return cluster_add_peer(addr, more, (pingt *) p, s);
case C_LASTSEEN: // Catch up a slave (slave missed a packet).
return cluster_add_peer(addr, more, (pingt *) p, s);
case C_LASTSEEN: // Catch up a slave (slave missed a packet).
+ if (!config->cluster_iam_master) { // huh?
+ LOG(0, 0, 0, "I'm not the master, but I got a C_LASTSEEN from %s?\n", fmtaddr(addr, 0));
+ return -1;
+ }
+
return cluster_catchup_slave(more, addr);
case C_FORWARD: { // Forwarded control packet. pass off to processudp.
return cluster_catchup_slave(more, addr);
case C_FORWARD: { // Forwarded control packet. pass off to processudp.