get ip vs(fullnat) client addr
由taobao/toa修改,可作为独立模块编译安装, 支持tcp/udp
支持 centos6.6(linux 2.6.32-220) / centos7.2(linux 3.10.0-237.4.5) / ubuntu14.04(linux 3.13.0-77-generic) / ubuntu16.04(linux 4.4.0-64-generic)
对应内核在github.com/yubo/LVS,兼容taobao/LVS(lvs_v2)
支持taobao/lvs_v2版本的tcp opt报文格式,新加入了icmp echo报文(payload),实现了tcp/udp local - client 地址对应关系的通告
lvs官网在2012年8月放出了fullnat第一个版本,其中的 TCPOPT_ADDR 为 200,之后ali的github上放出的,改为了254,导致有些版本兼容的问题,可确认tcpopt的值后,修改 /proc/sys/net/ca/tcpopt_addr
- kernel include/net/ip_vs.h
- ip_vs_ca src/ca.h
- Build as a module
- Support TCP
- Support UDP
- Support centos 6.6
- Support centos 7.2 rpmbuild
- Support ubuntu 14.04(trusty) dpkg
- Support ubuntu 16.04.2(xenial) dpkg
lvs(fullnat) client address TCP
lvs(fullnat) client address UDP
cd src
make -f linux.mk
insmod ./ip_vs_ca.ko
cd build
cmake ..
#cmake -DENABLE_ICMP=1 -DENABLE_DEBUG=1 ..
make package
rpm -ivh ip_vs_ca-`uname -r`-0.1.0.x86_64.rpm
#or
dpkg -i ip_vs_ca-`uname -r`-0.1.0.x86_64.deb
modprobe ip_vs_ca
可以通过修改以下文件来设置连接超时回收的时间
- /proc/sys/net/ca/tcp_timeout (defualt 90s)
- /proc/sys/net/ca/udp_timeout (defualt 180s)
- /proc/sys/net/ca/tcpopt_addr (defualt 254)
char recvbuf[1024] = {0};
struct sockaddr_in peeraddr[2];
socklen_t peerlen;
int n;
peerlen = sizeof(peeraddr);
n = recvfrom(sock, recvbuf, sizeof(recvbuf), 0,
(struct sockaddr *)peeraddr, &peerlen);
if(peerlen == sizeof(struct sockaddr_in)){
printf("recv %d %s:%d\n", peerlen,
inet_ntoa(peeraddr[0].sin_addr),
ntohs(peeraddr[0].sin_port));
}else if(peerlen == sizeof(peeraddr)){
printf("recv %d %s:%d", peerlen,
inet_ntoa(peeraddr[0].sin_addr),
ntohs(peeraddr[0].sin_port));
printf("(%s:%d)\n",
inet_ntoa(peeraddr[1].sin_addr),
ntohs(peeraddr[1].sin_port));
}