* Wed Jun 23 2004 David Parrish <david@dparrish.com> 2.0.0
- Major release - Completely replace active/standby clustering with a new peer-to-peer clustering method which allows much greater throughput and is a lot more fault tolerant - Add internal tbf implementation for throttling without relying on tc and kernel HTB - Add support for iBGP and eBGP to advertise routes - Add cli commands "show cluster", "show bgp", "show ipcache", "show throttle", "show tbf", "suspend bgp", "restart bgp", "show user" - Interception destination must be set per-user - If SMP machine, allow use of SCHED_FIFO, which should improve performance - Added config option to send GARP at startup - Added plugin_become_master and plugin_new_session_master plugin hooks - Remove useless sessionsendarp(). This isn't needed now that we are using TUN instead of TAP. - ICMP rate limiting so not every unreachable packet is replied with an ICMP unreachable message - mangle table is not required on anything but the cluster master, so slaves will drop the mangle table and attempt to unload the ip_conntrack module - Statically assigned IP addresses (by Radius) work now - Add -d command-line flag to detach and become a daemon - Configuration file is now "/etc/l2tpns/startup-config" - Reduced MIN_IP_SIZE to 0x19 to stop a pile of Short IP warnings - Resend initial IPCP request until it's acknowleged by the client - Better radius session cleanup logic - Many miscellaenous bugfixes and performance enhancements - Thanks to Michael O'Reilly and Brendan O'Dea for most of these new features
This commit is contained in:
parent
67fb382676
commit
ed90ea49e0
31 changed files with 5417 additions and 1844 deletions
56
Makefile
56
Makefile
|
|
@ -4,7 +4,9 @@ etcdir = $(PREFIX)/etc/l2tpns
|
|||
libdir = $(PREFIX)/usr/lib/l2tpns
|
||||
|
||||
CC = gcc
|
||||
CFLAGS=-Wall -g -O3 -funroll-loops -fomit-frame-pointer -finline-functions
|
||||
DEFINES= -DBGP -DRINGBUFFER -DSTAT_CALLS -DSTATISTICS
|
||||
OPTIM=-g -O3 -funroll-loops -fomit-frame-pointer -finline-functions
|
||||
CFLAGS=-Wall $(OPTIM) $(DEFINES)
|
||||
LDFLAGS =
|
||||
LIBS = -lm -ldl -lcli
|
||||
INSTALL = /usr/bin/install -c
|
||||
|
|
@ -15,36 +17,38 @@ OBJS= md5.o \
|
|||
l2tpns.o \
|
||||
ppp.o \
|
||||
radius.o \
|
||||
throttle.o \
|
||||
rl.o \
|
||||
ll.o \
|
||||
cluster.o \
|
||||
cluster_slave.o \
|
||||
arp.o \
|
||||
constants.o \
|
||||
ll.o \
|
||||
control.o \
|
||||
util.o \
|
||||
tbf.o \
|
||||
bgp.o \
|
||||
|
||||
PLUGINS=garden.so autothrottle.so autosnoop.so
|
||||
|
||||
all: l2tpns cluster_master nsctl $(PLUGINS)
|
||||
all: l2tpns nsctl $(PLUGINS)
|
||||
|
||||
l2tpns: $(OBJS)
|
||||
$(CC) $(CFLAGS) -o $@ $^ $(LIBS) $(DEFS)
|
||||
|
||||
cluster_master: cluster_master.o ll.o cluster.o util.o
|
||||
$(CC) $(CFLAGS) -o $@ $^ $(DEFS)
|
||||
|
||||
nsctl: nsctl.o control.o
|
||||
$(CC) $(CFLAGS) -o $@ $^ $(DEFS)
|
||||
|
||||
clean:
|
||||
/bin/rm -f *.o *.so l2tpns cluster_master nsctl
|
||||
/bin/rm -f *.o *.so l2tpns nsctl
|
||||
|
||||
depend:
|
||||
(sed -n 'p; /^## Dependencies: (autogenerated) ##/q' Makefile && \
|
||||
gcc -MM $(DEFINES) $(OBJS:.o=.c) && \
|
||||
gcc -MM $(DEFINES) $(PLUGINS:.so=.c) | sed 's/\.o/.so/') >Makefile.tmp
|
||||
mv Makefile Makefile.bak
|
||||
mv Makefile.tmp Makefile
|
||||
|
||||
install: all
|
||||
$(INSTALL) -D -o root -g root -m 0755 l2tpns $(bindir)/l2tpns
|
||||
$(INSTALL) -D -o root -g root -m 0755 cluster_master $(bindir)/cluster_master
|
||||
$(INSTALL) -D -o root -g root -m 0755 nsctl $(bindir)/nsctl
|
||||
$(INSTALL) -D -o root -g root -m 0600 etc/l2tpns.cfg.default $(etcdir)/l2tpns.cfg
|
||||
$(INSTALL) -D -o root -g root -m 0644 etc/ip_pool.default $(etcdir)/l2tpns.ip_pool
|
||||
|
|
@ -57,8 +61,32 @@ install: all
|
|||
mknod /dev/net/tun c 10 200; \
|
||||
fi
|
||||
|
||||
%.so: %.c
|
||||
$(CC) -fPIC -shared -o $@ $^ $(LDFLAGS) $(LIBS) $(LIBPATH)
|
||||
%.o: %.c
|
||||
$(CC) -c $(CFLAGS) -o $@ $<
|
||||
|
||||
%.o: %.c l2tpns.h
|
||||
$(CC) -c -o $@ $< $(CFLAGS)
|
||||
%.so: %.c
|
||||
$(CC) -fPIC -shared $(CFLAGS) -o $@ $< $(LDFLAGS) $(LIBS) $(LIBPATH)
|
||||
|
||||
.PHONY: all clean depend
|
||||
|
||||
## Dependencies: (autogenerated) ##
|
||||
md5.o: md5.c md5.h
|
||||
icmp.o: icmp.c l2tpns.h config.h
|
||||
cli.o: cli.c l2tpns.h config.h util.h cluster.h tbf.h bgp.h
|
||||
l2tpns.o: l2tpns.c md5.h l2tpns.h config.h cluster.h plugin.h ll.h \
|
||||
constants.h control.h util.h tbf.h bgp.h
|
||||
ppp.o: ppp.c l2tpns.h config.h constants.h plugin.h util.h tbf.h \
|
||||
cluster.h
|
||||
radius.o: radius.c md5.h constants.h l2tpns.h config.h plugin.h util.h
|
||||
ll.o: ll.c ll.h
|
||||
cluster.o: cluster.c l2tpns.h config.h cluster.h util.h tbf.h bgp.h
|
||||
arp.o: arp.c l2tpns.h config.h
|
||||
constants.o: constants.c constants.h
|
||||
ll.o: ll.c ll.h
|
||||
control.o: control.c control.h
|
||||
util.o: util.c l2tpns.h config.h
|
||||
tbf.o: tbf.c l2tpns.h config.h tbf.h
|
||||
bgp.o: bgp.c l2tpns.h config.h bgp.h util.h
|
||||
garden.so: garden.c l2tpns.h config.h plugin.h control.h
|
||||
autothrottle.so: autothrottle.c l2tpns.h config.h plugin.h control.h
|
||||
autosnoop.so: autosnoop.c l2tpns.h config.h plugin.h control.h
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue