基于 Nginx 的负载均衡管理系统 Lazy balancer

GPLv3
Python
Linux
2016-07-28
_张小宝


Lazy-Balancer

项目起源于好哥们需要一个 7 层负载均衡器,无奈商业负载均衡器成本高昂,操作复杂。又没有特别喜欢(好看,好用)的开源产品,作为一名大 Ops 怎么能没有办法?正好最近在看 Django 框架,尝试自己给 Nginx 画皮,项目诞生!非专业开发,代码凑合看吧。

  • 项目基于 Django + AdminLTE 构建,在 Ubuntu 14.04 上测试通过;为了保证良好的兼容性,请使用 Chrome 浏览器。
  • 因为增加了 iptables 自动控制,所以暂时不支持 docker 方式部署;需要本地测试的同学请使用 vagrant 方式
  • 为了后续扩展方便,请大家使用 Tengine 替代 Nginx 服务

项目地址

更新

  • 将 Nginx 更换为 Tengine 以提供更灵活的功能支持以及性能提升
  • 新增 HTTP 状态码方式检测后端服务器,默认 TCP 方式
  • 新增 HTTP 状态码方式支持查看后端服务器状态
  • 修复因前方有防火墙导致无法获取后端服务器状态
  • 修复因主机头导致后端服务器探测失败
  • 新增自定义管理员用户
  • 新增配置通过文件备份和还原
  • 新增实时查看访问日志和错误日志
  • 新增实时请求统计
  • 更新 Vagrantfile
  • 修复其他 Bug

功能

  • Nginx 可视化配置
  • Nginx 负载均衡(反向代理)配置
  • Nginx 证书支持
  • 系统状态监测
  • 自动维护防火墙规则(白名单)
  • 支持 TCP 被动后端节点宕机检测
  • 支持 HTTP 主动后端节点宕机检测

运行

  • 克隆代码
mkdir -p /app  
git clone https://github.com/v55448330/lazy-balancer.git /app/lazy_balancer  
cd /app/lazy_balancer
  • 卸载 nginx
apt-get -y purge nginx-* nginx*
apt-get -y autoremove
  • 安装 tengine
git submodule update --init --recursive
cd resource/nginx/tengine
apt-get install -y build-essential libssl-dev libpcre3 libpcre3-dev zlib1g-dev
./configure --user=www-data --group=www-data --prefix=/etc/nginx --sbin-path=/usr/sbin --error-log-path=/var/log/nginx/error.log --conf-path=/etc/nginx/nginx.conf --pid-path=/run/nginx.pid
make
make install
mkdir -p /etc/nginx/conf.d
echo "daemon off;" >> /etc/nginx/nginx.conf
  • 安装 supervisor
apt-get install supervisor  
update-rc.d supervisor enable
  • 配置 supervisor
cp -rf service/* /etc/supervisor/
  • 安装依赖
apt-get install -y python-dev python-pip iptables libcurl4-openssl-dev
pip install -r requirements.txt
  • 初始化数据库
python manage.py makemigrations  
python manage.py migrate
  • 启动服务
service supervisor restart
  • 登录系统
http://[IP]:8000/

首次登陆会要求创建管理员用户,如需修改,可在系统配置中重置管理员用户

演示

imageimageimageimageimageimageimageimageimageimage

授权

本项目由 小宝 维护,采用 GPLv3 开源协议。欢迎反馈!欢迎贡献代码!



加载中

评论(5)

z
z123tang
想问一下可否有时间把这套系统在centos环境下安装?目前是不支持的!
JoanBoss
JoanBoss
安装后无法使用。。何解。
i
ioscan
好东西,谢谢分享. 但是怎么页面无法打开,服务器端口8000没有打开?怎么破
彪付_3个字符
开源就是叼
shirosora
shirosora
小宝宝 #Nginx_Balancer#

暂无资讯

暂无问答

Nginx 文章备忘

https://docs.nginx.com/nginx/ https://docs.nginx.com/nginx/admin-guide/security-controls/terminating-ssl-tcp/ https://docs.nginx.com/nginx/admin-guide/dynamic-modules/lua/ https...

06/11 11:09
12
0
vanish(squid) + HAProxy + nginx + memcached(redis)

1. Load-balance then cache +-- Cache server #1 (varnish) -- App server #1 / Load Balancer (haproxy)-+---- Cache server #2 (varnish) -- App server #2 \ +-- Cache server #3 (varni...

2013/12/10 18:09
289
0
Nginx处理php的步骤 处理请求的流程

nginx配置文件 location ~ .*\.(php|php5)?$     {         #fastcgi_pass  unix:/tmp/php-cgi.sock;         fastcgi_pass  127.0.0.1:9000;         f...

2014/01/26 14:32
304
0
ngnix-operesty / 初识

前言 官网 安装 组件 文摘 使用balancer_by_lua_block做应用层负载均衡 ngx_lua模块 安装 yum -y install yum-utils yum-config-manager --add-repo https://openresty.org/package/centos/...

06/29 23:54
13
0
Openresty 执行阶段与api之间的关系(一)

Openresty与nginx的 执行阶段 常见的七个阶段的顺序: set_by_lua rewrite_by_lua access_by_lua content_by_lua header_filter_by_lua body_filter_by_lua log_by_lua 每个阶段的作用: se...

2016/10/24 23:41
691
0
Nginx学习之负载均衡fair模块

Nginx学习之负载均衡fair模块 2017-04-10 20:27 写在开始 前面对Nginx的三种负载均衡实现做了一个简单的介绍,这里分享一个第三方的负载均衡模块nginx-upstream-fair。 模块介绍 The Nginx ...

07/19 11:06
22
0
负载均衡集群介绍 LVS介绍 LVS调度算法 LVS NAT模式搭建

扩展 lvs 三种模式详解 http://www.it165.net/admin/html/201401/2248.html lvs几种算法 http://www.aminglinux.com/bbs/thread-7407-1-1.html 关于arp_ignore和 arp_announce http://www.cn...

07/04 22:48
46
0
超越300万 - 基于LVS构建可扩展的WEB集群

转载系列文章 3 Million and Beyond - Creating Scalable Web Clusters with LVS , 共3篇。

2014/12/03 17:01
86
0
Linux下Apache与Tomcat的完全分布式集群配置(负载均衡)

Linux下Apache与Tomcat的完全分布式集群配置(负载均衡)

2014/06/16 14:42
27
0

没有更多内容

加载失败,请刷新页面

返回顶部
顶部