27.1 简介
一个服务称为一个模块,一个模块由modid+cmdid来标识<br />modid+cmdid的组合表示一个远程服务,这个远程服务一般部署在多个节点上
LB Agent以UDP方式为业务方提供:1、节点获取服务;2、节点调用结果上报服务
27.1.1 业务1-节点获取服务:
业务方每次要向远程服务发送消息时,先利用modid+cmdid去向LB Agent获取一个可用节点,然后向该节点发送消息,完成一次远程调用;具体获取modid+cmdid下的哪个节点是由LB Agent负责的
27.1.2 业务2-节点调用结果上报服务
对LB Agent节点的一次远程调用后,调用结果会汇报给LB Agent,以便LB Agent根据自身的LB算法来感知远程服务节点的状态是空闲还是过载,进而控制节点获取时的节点调度.<br />
LB Agent拥有5个线程,一个LB算法:
UDP Server服务,并运行LB算法,对业务提供节点获取和节点调用结果上报服务;为了增大系统吞吐量,使用3个UDP Server服务互相独立运行LB算法:modid+cmdid % 3 = i的那些模块的服务与调度,由第i+1个UDP Server线程负责
Dns Service Client:是dnsserver的客户端线程,负责根据需要,向dnsserver获取一个模块的节点集合(或称为获取路由);UDP Server会按需向此线程的MQ写入获取路由请求,DSS Client将MQ到来的请求转发到dnsserver,之后将dnsserver返回的路由信息更新到对应的UDP Server线程维护的路由信息中
Report Service Client:是reporter的客户端线程,负责将每个模块下所有节点在一段时间内的调用结果、过载情况上报到reporter Service端,便于观察情况、做报警;本身消费MQ数据,UDP Server会按需向MQ写入上报状态请求。
27.2构建Lars-Agent项目
27.2.1 构建目录结构
依次创建如下目录:
Lars/lars_loadbalance_agent
lars_loadbalance_agent/├── bin/├── conf/│ └── lars_lb_agent.conf├── include/├── Makefile└── src/
其中Makefile如下:
TARGET= bin/lars_lb_agentCXX=g++CFLAGS=-g -O2 -Wall -Wno-deprecatedBASE=../baseBASE_H=$(BASE)/includePROTO = $(BASE)/protoPROTO_H = $(BASE)/protoLARS_REACTOR=../lars_reactorLARS_REACTOR_H =$(LARS_REACTOR)/includeLARS_REACTOR_LIB=$(LARS_REACTOR)/lib -llreactorMYSQL=$(BASE)/mysql-connector-cMYSQL_H=$(MYSQL)/includeMYSQL_LIB=$(MYSQL)/lib/libmysqlclient.aOTHER_LIB = -lpthread -ldl -lprotobufSRC= ./srcINC= -I./include -I$(BASE_H) -I$(LARS_REACTOR_H) -I$(MYSQL_H) -I$(PROTO_H)LIB= $(MYSQL_LIB) -L$(LARS_REACTOR_LIB) $(OTHER_LIB)OBJS = $(addsuffix .o, $(basename $(wildcard $(SRC)/*.cpp)))OBJS += $(PROTO)/lars.pb.o$(TARGET): $(OBJS)mkdir -p bin$(CXX) $(CFLAGS) -o $(TARGET) $(OBJS) $(INC) $(LIB)%.o: %.cpp$(CXX) $(CFLAGS) -c -o $@ $< $(INC).PHONY: cleanclean:-rm -f src/*.o $(PROTO)/lars.pb.o $(TARGET)
实际上reporter、dns相似。
conf/lars_lb_agent.conf
[reporter]ip = 127.0.0.1port = 7779[dnsserver]ip = 127.0.0.1port = 7778
目前的基本配置文件,因为loadbalance_agent是充当reporter和dnsserver的客户端,所以需要知道对应的reporter和dnsserver的ip和port信息。
