Mainos / Advertisement:

PowerDNS Admin

Kohteesta Taisto
Siirry navigaatioon Siirry hakuun

PowerDNS Admin on GUI työkalu PowerDNS palvelulle.

Asennus ja konfigurointi

Asenna aluksi vaaditut paketit

sudo apt install git python-pip python-dev libmysqlclient-dev libsasl2-dev libldap2-dev libssl-dev libxml2-dev libxmlsec1-dev libxmlsec1-openssl virtualenv

Lataa Git paketti

cd /opt
git clone https://github.com/ngoduykhanh/PowerDNS-Admin.git
cd PowerDNS-Admin

Konfiguroidaan PowerDNS Admin työkalu. Aloita konfigurointi komenolla "virtualenv" aina.

virtualenv flask
source ./flask/bin/activate
pip install --upgrade pip
pip install -r requirements.txt

Mikäli käytössä Python3:

virtualenv -p python3 flask
source ./flask/bin/activate
pip3 install setuptools --upgrade
pip3 install pip --upgrade
pip3 install -r requirements.txt
pip3 install MySQL-python

Kopioi template konfiguraatio config.py:ksi.

cp config_template.py config.py

Konfiguroi tietokantapalvelimen asetukset ja määritä salausavain

nano config.py
SECRET_KEY = 'XXXX'
SQLA_DB_USER = 'powerdnsadmin'
SQLA_DB_PASSWORD = 'xxxxsalasana'
SQLA_DB_HOST = '127.0.0.1'
SQLA_DB_NAME = 'powerdnsadmin'
SQLALCHEMY_POOL_RECYCLE = 600

Konfiguroi lisäksi PowerDNS palvelimen API tunnus ja avain tiedostoon myös. Sinun tulee ottaa käyttöön API pdns.conf tiedostosta.

# POWERDNS CONFIG
PDNS_STATS_URL = 'http://127.0.0.1:8081/'
PDNS_API_KEY = 'XXXXX'
PDNS_VERSION = '4.0.0'

Luo tietokantataulu

sudo ./create_db.py

Käynnistä palvelu testiksi

sudo ./run.py

Konfiguroi uWSGI

Asenna uWSGI

sudo apt install uwsgi uwsgi-plugin-python

Luo uusi konfigurointitiedosto

sudo nano /etc/uwsgi/apps-enabled/pdns-admin.ini 

Jos olet asentanut PowerDNS-Adminin /opt -hakemiston alle, tässä olisi valmis konfiguraatio. Jos olet asentanut toisaalle, muuta chdir, pythonpath ja virtualenv-polku.

[uwsgi]
plugins = python27

uid=www-data
gid=www-data

chdir = /opt/PowerDNS-Admin/
pythonpath = /opt/PowerDNS-Admin/
virtualenv = /opt/PowerDNS-Admin/flask

mount = /pdns=run.py
manage-script-name = true
callable = app

vacuum = true
harakiri = 20
post-buffering = 8192
socket = /run/uwsgi/app/%n/%n.socket
chown-socket = www-data
pidfile = /run/uwsgi/app/%n/%n.pid

daemonize = /var/log/uwsgi/app/%n.log
enable-threads

Konfiguroi Nginx

location / { try_files $uri @pdns_admin; } 

location @pdns_admin {
    include uwsgi_params;
    uwsgi_pass unix:/run/uwsgi/app/pdns-admin/pdns-admin.socket;
}

location /pdns/static/ {
    alias /opt/PowerDNS-Admin/app/static/;
}

Käynnistä uwsgi ja nginx uudelleen ja testaa.

Lisäkonfiguraatio

Kaikki PowerDNS Admin konfiguraatiot tehdään pääsääntöisesti config.py tiedostoon.

Määritä tietueet joita saa muokata. Varmista että sinulla on uusin PowerDNS versio myös.

 RECORDS_ALLOW_EDIT = [  'A','AAAA','AFSDB ','CAA','CERT','CDNSKEY','CDS','CNAME','DNSKEY','DNAME','DS','HINFO','KEY','LOC','MX','NAPTR','NS','NSEC','NSEC3','NSEC3PARAM','OPENPGPKEY','PTR','RP','RRSIG','SOA','SPF','SSHFP','SRV','TKEY','TSIG','TLSA','TXT','URI']

Nginx reverse proxy

Nginx reverse proxynä käyttäessä sinun pitää tehdä oma virtualhost ja käyttää subdomainia.Esimerkki konfiguraatio:

server {
        listen 80;
        server_name example.org;

 location / {
    proxy_pass          http://127.0.0.1:9393;
    include /etc/nginx/proxy_params;
 }

DynDNS

DynDNS on API-rajapinta ns. eli ei sen kummoisempi. Päivitys tapahtuu esimerkiksi.

 https://ip-address/nic/update?hostname=example.org&myip=1.2.3.4 

IPv6 voi päivittää kunhan muuttaa myip:n myip6:seksi.

IP:n voi tarkistaa

 https://ip-address/nic/checkip.html
Mainos / Advertisement: