2402C++,C++的反向代理

原文
cinatra支持反向代理很简单,5行代码就可以了.先看一个简单的示例:

#include "cinatra/coro_http_reverse_proxy.hpp"
using namespace cinatra;
int main() {
  reverse_proxy proxy_rr(10, 8091);
  proxy_rr.add_dest_host("127.0.0.1:9001");
  proxy_rr.add_dest_host("127.0.0.1:9002");
  proxy_rr.add_dest_host("127.0.0.1:9003");
  proxy_rr.start_reverse_proxy<GET, POST>("/rr", true, coro_io::load_blance_algorithm::RR);
}

第一步创建一个代理服务器,设置其线程数和端口;第二步添加需要访问的服务器列表;第三步启动代理服务,设置loadbalance策略,这里选择的是roundrobin策略.

在浏览器或client里访问http://127.0.0.1:8091/rr就会根据RR策略选择三个服务器中的一个.

如果要选择random策略就设置为coro_io::load_blance_algorithm::random.
如果要选择weightroundrobin策略,就需要设置服务器权重.

  reverse_proxy proxy_wrr(10, 8090);
  proxy_wrr.add_dest_host("127.0.0.1:9001", 10);
  proxy_wrr.add_dest_host("127.0.0.1:9002", 5);
  proxy_wrr.add_dest_host("127.0.0.1:9003", 5);
  proxy_wrr.start_reverse_proxy<GET, POST>("/wrr", true, coro_io::load_blance_algorithm::WRR);

在浏览器或client里访问http://127.0.0.1:8090/wrr,第一次和第二次会返回9001服务器的结果,第三次返回9002服务器的结果,第四次返回9003服务器的结果,第五次又重新返回9001服务器的结果,这就是WRR的策略.

更多

cinatra的反向代理是零拷贝的,代理服务器会把被代理服务器的httpcontent零拷贝的响应传递给客户,性能会更好!

你可能感兴趣的:(c++,cpp,c++)