8 Star 16 Fork 8

gibsonxue / BindGUI

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

BindGUI

Django 框架 Binder DNS图形化管理 使用Django Rest Framework API供客户端自动注册到服务器端数据库,并把内容实时的更新到Bind DNS中

项目参考了binder在原有的基础上进行了API自从注册的二次开发,方便客户端服务器能自动注册到DNS服务器中

之前也参考了一些其他互联网公司的方法,比如使用Bind-MySQL,可是配置不直观,也并不如原生文本那样稳定。同时增加了学习成本和部署难度,所以选择通过Bind DNS更新的原生方式,来投入生产使用

下载安装 git clone https://git.oschina.net/gibsonxue/BindGUI.git

需要Bind DNS 9.10以上的API支持,CentOS默认安装的是9.8.x或者9.9.x的已经是几年前的版本了,早不支持了,不知道为什么RedHat一直没有更新 可以尝试使用Ubuntu Server的Bind相对比较新

提供大家一个国外的个人Yum源,用这个源Yum出来的比较新 baseurl=http://bkraft.fr/files/RPM%20stuff/

Python依赖文件

The requirements.txt file has the necessary dependencies.

pip install -r requirements.txt

默认账号密码都是'admin'

目前项目为了调试方便,暂时使用的是SQLite,因为使用Django的ORM很方便的你就可以定义自己的MySQL或者其他数据库

  • DJANGO_DB_HOST: IP address or Hostname of the MySQL database host. (Required)
  • DJANGO_DB_NAME: Name of the MySQL database. (Required)
  • DJANGO_DB_USER: Username to access the above database. (Optional. Default: binder)
  • DJANGO_DB_PASSWORD: Binder Database password (Required)

输入一下几个命令就OK了 python manage.py migrate python manage.py createsuperuser python manage.py runserver


项目开始之前你需要指定一个Binder TSIG,用于远程更新的Key

使用方法可以见如下网站
Starting with version 1.5, TSIG keys inside the database are encrypted using the [Crytography](https://cryptography.io/en/latest/fernet/) library and Fernet facilities.


### 配置 BIND DNS Server ###


#### named.conf ####
在named.conf 下面加入如下参数:开启Dns列表,定义监听statistics-channels

    options {
      zone-statistics yes;
    }

    statistics-channels {
        inet * port 8053 allow { 10.10.0.0/24; };
    };

举例,我使用的是 dynzone-key,这个在项目的settings里KEY_NAME="dynzone-key"可以自定义,不想修改我的代码就使用默认的


    zone "dynzone.yourdomain.org" IN {
        type master;
        file "/var/cache/bind/master/db.dynzone.yourdomain.org";
        allow-update { key dynzone-key; };
    };

#### /etc/bind/dynzone.key ####

Below are the entire contents of the dynzone.key file. This specifies the name, algorith and TSIG secret.

    key dynzone-key {
        algorithm hmac-md5;
        secret "";
    };

referenced as 'dynzone-key' in named.conf

更多内容英语好的同学可以看一下这个 TSIG see http://www.cyberciti.biz/faq/unix-linux-bind-named-configuring-tsig/ .

!!!另外要注意的是FERNET_KEY,可以通过以下命令获取,把值贴入settings中,非常关键,不然可能导致更新DNS的秘钥失效,秘钥是用MD5或者HASH形式保存在数据库的KEY表当中。
#FERNET_KEY=os.environ.get("DJANGO_FERNET_KEY", Fernet.generate_key())
FERNET_KEY='W7kCBzLcvQculFdM0Ecd39_kOsVAKteXRfeIbn1UuMQ='


### Apache配置文件 ###
config/binder-apache.conf.dist

### Nginx ###
config/binder-nginx.conf.dist

wsgi文件
config/django.wsgi

#### MySQL创建命令 ###

create database binder;

create user 'binder'@'%' identified by 'INSERTYOURPASSWORDHERE';

grant all privileges on binder.* to 'binder'@'%';

flush privileges;


空文件

简介

BindGUI图形化DNS管理Django 展开 收起
Python
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
Python
1
https://gitee.com/gibsonxue/BindGUI.git
git@gitee.com:gibsonxue/BindGUI.git
gibsonxue
BindGUI
BindGUI
master

搜索帮助