You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Aidaho12 b11b646676 v2.0.6 7 years ago
cgi-bin v2.0.6 7 years ago
image v2.0.2.1 7 years ago
inc v2.0.6 7 years ago
log Create config_edit.log 7 years ago
.gitignore v1.4.1 7 years ago
CONTRIBUTING.md Create CONTRIBUTING.md 7 years ago
LICENSE Initial commit 7 years ago
README.md v2.0.6 7 years ago
index.html v1.10.2 7 years ago
requirements.txt v2.0.6 7 years ago

README.md

Haproxy web interface

A simple web interface(user-frendly web GUI) for managing Haproxy servers. Leave your feedback

alt text

Capabilities:

  1. View statistics of all servers in one place
  2. Server and service statsus in one place
  3. View logs of all servers in one place
  4. Map frontend, backends and servers
  5. Runtime API with the ability to save changes (need install socat on all haproxy servers)
  6. Browsing Configs
  7. Add sections: listen, frontend, backend from web interface
  8. Editing configs
  9. Rollback to previous versions of the config
  10. Master/slave servers
  11. Comparing versions of configs
  12. Users roles: admin, editor, viewer
  13. Server groups
  14. Telegram notification

Install

The installer will ask you a few questions

$ git clone https://github.com/Aidaho12/haproxy-wi.git /var/www/haproxy-wi
$ chmod +x install
$ cd /var/www/haproxy-wi
$ ./install

Manual install

For install just dowload archive and untar somewhere:

$ cd /var/www/
$ unzip master.zip
$ mv haproxy-wi-master/ haproxy-wi
$ chown -R apache:apache haproxy-wi/
$ pip install -r haproxy-wi/requirements.txt 
$ chmod +x haproxy-wi/cgi-bin/*.py 

For Apache do virtualhost with cgi-bin. Like this:

<VirtualHost *:8000>
        ServerName haproxy-wi
        ErrorLog /var/log/httpd/haproxy-wi.error.log
        CustomLog /var/log/httpd/haproxy-wi.access.log combined

        DocumentRoot /var/www/haproxy-wi
        ScriptAlias /cgi-bin/ "/var/www/haproxy-wi/cgi-bin/"

        <Directory /var/www/haproxy-wi>
                Options +ExecCGI
                AddHandler cgi-script .py
                Order deny,allow
                Allow from all
        </Directory>
</VirtualHost>

Database support

Default Haproxy-WI use Sqlite, if you want use MySQL enable in config, and create database:

For MySQL support:

MariaDB [(none)]> create user 'haproxy-wi'@'%';
MariaDB [(none)]> create database haproxywi;
MariaDB [(none)]> grant all on haproxywi.* to 'haproxy-wi'@'%' IDENTIFIED BY 'haproxy-wi';

alt text

Settings

Edit $HOME_HAPROXY-WI/cgi-bin/haproxy-webintarface.config with your env

Login http://haproxy-wi-server/users.py, and add: users, groups and servers. Default: admin/admin

alt text

Copy ssh key on all HAproxy servers

For Runtime API enable state file on HAproxt servers and need install socat on all haproxy servers:

    global
		stats socket *:1999 level admin 
		server-state-file /etc/haproxy/haproxy/haproxy.state
    defaults
		load-server-state-from-file global

alt text

Update DB

$ cd /var/www/haproxy-wi/cgi-bin
$ ./update_db.py

Further development and support

Offer your ideas and wishes, ask questions. All this is welcomed