merge in changes from 2.0 branch; fix byte counters in accounting records, add gigawords

This commit is contained in:
Brendan O'Dea 2005-06-02 11:32:30 +00:00
parent ebfbe027e3
commit bd2ec60149
11 changed files with 332 additions and 189 deletions

View file

@ -1,6 +1,6 @@
// L2TPNS Clustering Stuff
char const *cvs_id_cluster = "$Id: cluster.c,v 1.39 2005-05-26 12:17:30 bodea Exp $";
char const *cvs_id_cluster = "$Id: cluster.c,v 1.40 2005-06-02 11:32:30 bodea Exp $";
#include <stdio.h>
#include <stdlib.h>
@ -287,7 +287,7 @@ int master_forward_packet(char *data, int size, in_addr_t addr, int port)
LOG(4, 0, 0, "Forwarding packet from %s to master (size %d)\n", fmtaddr(addr, 0), size);
STAT(c_forwarded);
add_type(&p, C_FORWARD, addr, (char *) &port, sizeof(port));
add_type(&p, C_FORWARD, addr, (char *) &port, sizeof(port)); // ick. should be uint16_t
memcpy(p, data, size);
p += size;
@ -402,10 +402,16 @@ void master_update_counts(void)
if (config->cluster_iam_master) // Only happens on the slaves.
return;
if (!config->cluster_master_address) // If we don't have a master, skip it for a while.
if (!config->cluster_master_address) // If we don't have a master, skip it for a while.
return;
i = MAX_B_RECS * 5; // Examine max 2000 sessions;
// C_BYTES format changed in 2.1.0 (cluster version 5)
// during upgrade from previous versions, hang onto our counters
// for a bit until the new master comes up
if (config->cluster_last_hb_ver < 5)
return;
i = MAX_B_RECS * 5; // Examine max 3000 sessions;
if (config->cluster_highest_sessionid > i)
i = config->cluster_highest_sessionid;
@ -416,17 +422,20 @@ void master_update_counts(void)
walk_session_number = 1;
if (!sess_local[walk_session_number].cin && !sess_local[walk_session_number].cout)
continue; // Unused. Skip it.
continue; // Unchanged. Skip it.
b[c].sid = walk_session_number;
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;
b[c].pin = sess_local[walk_session_number].pin;
b[c].pout = sess_local[walk_session_number].pout;
b[c].cin = sess_local[walk_session_number].cin;
b[c].cout = sess_local[walk_session_number].cout;
// Reset counters.
sess_local[walk_session_number].pin = sess_local[walk_session_number].pout = 0;
sess_local[walk_session_number].cin = sess_local[walk_session_number].cout = 0;
if (++c > MAX_B_RECS) // Send a max of 600 elements in a packet.
break;
}
if (!c) // Didn't find any that changes. Get out of here!
@ -527,6 +536,10 @@ void cluster_check_master(void)
LOG(0, 0, 0, "Master timed out! Holding election...\n");
// In the process of shutting down, can't be master
if (main_quit)
return;
for (i = have_peers = 0; i < num_peers; i++)
{
if ((peers[i].timestamp + config->cluster_hb_timeout) < t)
@ -610,13 +623,17 @@ void cluster_check_master(void)
// 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.
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;
// Accumulate un-sent byte/packet counters.
increment_counter(&session[i].cin, &session[i].cin_wrap, sess_local[i].cin);
increment_counter(&session[i].cout, &session[i].cout_wrap, sess_local[i].cout);
session[i].cin_delta += sess_local[i].cin;
session[i].cout_delta += sess_local[i].cout;
session[i].pin += sess_local[i].pin;
session[i].pout += sess_local[i].pout;
sess_local[i].cin = sess_local[i].cout = 0;
sess_local[i].pin = sess_local[i].pout = 0;
sess_local[i].radius = 0; // Reset authentication as the radius blocks aren't up to date.
@ -1078,13 +1095,16 @@ static int cluster_handle_bytes(char *data, int size)
return -1; /* Abort processing */
}
session[b->sid].total_cin += b->in;
session[b->sid].total_cout += b->out;
session[b->sid].pin += b->pin;
session[b->sid].pout += b->pout;
session[b->sid].cin += b->in;
session[b->sid].cout += b->out;
increment_counter(&session[b->sid].cin, &session[b->sid].cin_wrap, b->cin);
increment_counter(&session[b->sid].cout, &session[b->sid].cout_wrap, b->cout);
if (b->in)
session[b->sid].cin_delta += b->cin;
session[b->sid].cout_delta += b->cout;
if (b->cin)
session[b->sid].last_packet = time_now; // Reset idle timer!
size -= sizeof(*b);
@ -1223,12 +1243,12 @@ static uint8_t *convert_session(struct oldsession *old)
new.nr = old->nr;
new.ns = old->ns;
new.magic = old->magic;
new.cin = old->cin;
new.cout = old->cout;
new.pin = old->pin;
new.pout = old->pout;
new.total_cin = old->total_cin;
new.total_cout = old->total_cout;
new.cin = old->total_cin;
new.cout = old->total_cout;
new.cin_delta = old->cin;
new.cout_delta = old->cout;
new.throttle_in = old->throttle_in;
new.throttle_out = old->throttle_out;
new.filter_in = old->filter_in;
@ -1360,6 +1380,7 @@ static int cluster_process_heartbeat(uint8_t *data, int size, int more, uint8_t
config->cluster_seq_number = h->seq;
config->cluster_last_hb = TIME; // Reset to ensure that we don't become master!!
config->cluster_last_hb_ver = hb_ver; // remember what cluster version the master is using
if (config->cluster_seq_number != h->seq) { // Out of sequence heartbeat!
static int lastseen_seq = 0;