Як налаштувати динамічний DNS

Що таке динамічний DNS?

Давайте розглянемо типовий приклад налаштування DNS. Ваш домен є example.com, і у вас є Aзаписи для server1.example.comта server2.example.com. Server1 розміщено у Vultr, але server2 розміщено в локальній мережі, наприклад, у вашому бізнесі або як машина для розробки у вашому домі. Зазвичай такі типи локальних середовищ мають загальнодоступні IP-адреси, які динамічно призначаються вашим постачальником послуг Інтернету (ISP), і вони можуть несподівано змінитися. Це призведе до того, що server2 раптово вкаже на неправильну IP-адресу, що може серйозно вплинути на службу. Ця стаття покаже вам, як налаштувати власну динамічну службу DNS, яка працює на локальній машині та може автоматично оновлювати запис для server2 у Vultr DNS після загальнодоступної зміни IP-адреси.

While clients like ddclient and inadyn will work for some DNS providers, Vultr does not currently support these and instead uses its own custom API. This service will run locally on your machine and use GET and POST requests along with your access key.

Передумови

  • Доступ до вашого облікового запису Vultr для налаштування DNS та керування ключами доступу.
  • Можливість підключення до локальної машини, яка має динамічну IP-адресу (або доступ до іншої машини в тій же мережі).

Установка та налаштування

Налаштування вашого домену для використання служби DNS Vultr

  • Якщо ви не використовуєте службу DNS Vultr для свого домену, дотримуйтесь цієї статті, щоб змінити свої сервери імен для використання з Vultr.
  • Після налаштування DNS Vultr перейдіть на сторінку керування DNS у розділі "Сервери -> DNS -> [ваше доменне ім'я]".
  • Тут ви знайдете всі записи, налаштовані для вашого домену. Запишіть, який запис(и) ви б хотіли змінити, оскільки це знадобиться вам пізніше.
    • AЦя утиліта підтримує лише записи " ". Якщо у вас є кілька Aзаписів " ", які ви хочете оновити до однієї IP-адреси, змініть їх на " CNAME" записи і вкажіть на один Aзапис " ". Це спростить вам усе в довгостроковій перспективі і вважається правильним способом налаштування DNS.

Установка необхідних інструментів

  • Підключіться до свого локального сервера. Це може бути безпосередньо або через SSH.
  • Для цього інструменту потрібен Python 3. Більшість дистрибутивів Linux містять попередньо встановлений Python. Якщо він не встановлений у вашому середовищі, інструкції доступні в офіційній вікі Python тут:
  • Для цього процесу також потрібен Git, який ви можете встановити за допомогою наведених нижче інструкцій:

Завантаження клієнта Dynamic DNS

Використовуйте Git, щоб клонувати репозиторій, що містить клієнт DDNS python. Ви повинні зробити це в безпечному каталозі, до якого у вас є повний доступ. Вашої домашньої папки має бути достатньо. Виконайте таку команду:

git clone https://github.com/andyjsmith/Vultr-Dynamic-DNS.git vultrddns && cd vultrddns

Створення особистого маркера доступу

Згенеруйте особистий маркер доступу в Vultr. Це можна зробити в розділі "Обліковий запис -> API -> Особистий маркер доступу". На цій же сторінці вам потрібно буде перейти в розділ «Контроль доступу» та натиснути кнопку «Дозволити всі IPv4», оскільки ви не будете знати IP-адресу свого локального сервера щоразу, отже, це точка динамічного DNS.

Налаштування інструменту для вашого сервера

  • Прочитайте config.json.exampleфайл, щоб отримати приклад того, як має виглядати ваш файл конфігурації.
  • Відкрийте config.jsonфайл за допомогою улюбленого текстового редактора та заповніть значення відповідно до налаштувань вашого сервера.
  • Файл повинен містити наступне:

    {
        "api_key": "",
        "domain": "",
        "dynamic_records": [
        ""
        ]
    }
    
  • Введіть свій маркер доступу в поле api_key.

  • Введіть свій базовий домен у domainполе. Наприклад, example.com.
  • Тепер введіть у поле Aзаписи " ", які ви хочете змінити dynamic_records. Використовуючи попередній приклад, ви повинні ввести, server2щоб автоматично змінити server2IP-адресу користувача. Ви можете ввести кілька субдоменів. Якщо ви хочете змінити базовий Aзапис " " для вашого домену (зазвичай позначається як @, запис, який відповідає, коли ви переходите безпосередньо до example.com), просто залиште порожні лапки.
  • Правильний файл конфігурації може виглядати так, де ви хочете динамічно змінити IP для example.comта server2.example.com:

    {
        "api_key": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
        "domain": "example.com",
        "dynamic_records": [
        "",
        "server2"
        ]
    }
    
  • Тепер збережіть ці зміни, і ваш файл буде готовий!

Перевірте свою конфігурацію

  • Перевірте сценарій і конфігурацію, запустивши python3 ddns.py. Якщо це не повертає жодних помилок, ваша конфігурація є номінальною, і ви можете почати процес автоматизації.

Автоматизація

Після завершення основного налаштування важливо налаштувати повторювану задачу, оскільки сценарій не робить цього за замовчуванням. Підключіться до локальної машини та виконайте наведені нижче дії залежно від операційної системи.

Linux і Mac OSX

У Linux і Mac cronвже інстальована утиліта, яка дозволяє вказувати сценарії для виконання за встановленими розкладами.

  • Знайдіть повний шлях до ddns.pyфайлу, realpath ddns.pyперебуваючи в vultrddnsкаталозі.
  • Запустіть, crontab -eщоб відредагувати свій crontab.
  • Додайте наступний рядок у кінець файлу, додавши реальний шлях до ddns.pyфайлу:

    */30 * * * * python3 [full path to ddns.py] > /dev/null 2>&1
    
  • Це буде запускати сценарій кожні 30 хвилин і перенаправляти весь його вихід на /dev/null.

  • Збережіть і вийдіть із текстового редактора. Файл crontab буде автоматично встановлено, і тепер ваша IP-адреса буде автоматично оновлена.

Windows

Створіть завдання в Планувальнику завдань, яке запускатиметься кожні 30 хвилин. Дотримуйтесь посібника Microsoft щодо створення основних завдань.

  • Відкрийте Планувальник завдань і натисніть «Створити завдання...».
  • Дайте йому назву та створіть новий тригер.
  • Натисніть «Щодня». У розділі «Додаткові налаштування» натисніть, щоб повторити завдання кожні 30 хвилин і змініть «протягом тривалості» на «Невизначено».
  • Додайте нову дію, щоб запустити програму та перейти до свого виконуваного файлу Python. Додайте ddns.pyсценарій як аргумент.

Налаштуйте сервер DHCP на Windows Server 2012

Налаштуйте сервер DHCP на Windows Server 2012

DHCP – це протокол, який використовується для динамічного розподілу IP-адрес комп’ютерам у вашій мережі. Windows Server 2012 може бути не тільки DNS-сервером або доменом

Налаштуйте власний DNS-сервер на Debian/Ubuntu

Налаштуйте власний DNS-сервер на Debian/Ubuntu

У цьому посібнику пояснюється, як налаштувати DNS-сервер за допомогою Bind9 на Debian або Ubuntu. Протягом усієї статті замініть your-domain-name.com відповідно. На го

Переадресація портів і проксі за допомогою OpenSSH

Переадресація портів і проксі за допомогою OpenSSH

Вступ SSH, також відомий як Secure Shell, може використовуватися не тільки для отримання віддаленої оболонки. У цій статті буде показано, як можна використовувати SSH

Зупинити DHCP від ​​зміни resolv.conf

Зупинити DHCP від ​​зміни resolv.conf

Для користувачів DHCP можуть виникнути випадки, коли потрібно відредагувати /etc/resolv.conf, щоб використовувати інші сервери імен. Потім, через деякий час (або після перезавантаження системи)

Як налаштувати DJBDNS на FreeBSD

Як налаштувати DJBDNS на FreeBSD

Цей підручник покаже вам, як налаштувати службу DNS, яку легко підтримувати, легко налаштовувати і яка, як правило, є більш безпечною, ніж класичний BIN

Простий поштовий сервер із Postfix, Dovecot та Sieve на CentOS 7

Простий поштовий сервер із Postfix, Dovecot та Sieve на CentOS 7

Цей посібник покаже вам, як отримати простий поштовий сервер на CentOS 7 з Postfix як MTA, Dovecot як MDA і Sieve для сортування пошти - по всьому шифруванню

Як встановити OpenNMS на CentOS 7

Як встановити OpenNMS на CentOS 7

Використання іншої системи? OpenNMS — це корпоративна платформа управління мережею з відкритим вихідним кодом, яку можна використовувати для моніторингу та керування численними пристроями

Як підключитися до VPN з Windows або OS X

Як підключитися до VPN з Windows або OS X

Більшість настільних комп’ютерів постачаються в комплекті з клієнтом VPN. Якщо у вас є сервер VPN, ви можете використовувати цей клієнт у комплекті для підключення до своєї VPN. У цьому посібнику я поясню хо

Як запобігти одночасним підключенням у Linux за допомогою IPTables

Як запобігти одночасним підключенням у Linux за допомогою IPTables

iptables — це програмне забезпечення брандмауера, яке можна знайти в багатьох дистрибутивах, включаючи CentOS та Ubuntu. У цьому документі ви побачите, як можна запобігти одночасному

Налаштуйте DNS-сервер на Windows Server 2012

Налаштуйте DNS-сервер на Windows Server 2012

Windows Server 2012 можна налаштувати як DNS-сервер. DNS використовується для перетворення доменних імен на IP-адреси. Розміщуючи власні DNS-сервери, ви отримуєте більше

Встановіть ім’я хоста на CentOS

Встановіть ім’я хоста на CentOS

Крок 1: Увійдіть до свого VPS Знайдіть IP-адресу вашого Vultr VPS та увійдіть як користувач root. ssh root@server Крок 2: Використовуйте утиліту імені хоста Змінити вас

Встановлення Bro IDS на Ubuntu 16.04

Встановлення Bro IDS на Ubuntu 16.04

Використання іншої системи? Вступ Bro — це потужна платформа для аналізу мережі з відкритим кодом. Основна увага Bros приділяється моніторингу безпеки мережі. бр

Налаштування динамічного DNS для віддаленого робочого столу Windows

Налаштування динамічного DNS для віддаленого робочого столу Windows

У цій статті буде показано, як налаштувати динамічний DNS для віддаленого робочого стола, щоб уникнути клопоту з налаштуванням віддаленої допомоги знову і знову. В

Як змінити імя хоста в Debian

Як змінити імя хоста в Debian

Крок 1: Увійдіть до свого VPS Знайдіть IP-адресу вашого Vultr VPS та увійдіть як користувач root. ssh root@server Крок 2: Редагування /etc/hostname Відкрийте th

Приклад листа авторизації для оголошень BGP

Приклад листа авторизації для оголошень BGP

Будь ласка, використовуйте наведений нижче шаблон, коли запитуєте авторизацію для оголошень BGP. ЛИСТ-АВТОРИЗАЦІЯ [ДАТА] Кому це може стосуватися, Thi

Встановлення Bro IDS на Fedora 25

Встановлення Bro IDS на Fedora 25

Використання іншої системи? Вступ Bro — це аналізатор мережевого трафіку з відкритим кодом. Це в першу чергу монітор безпеки, який перевіряє весь трафік на лінії

Встановлення OpenVPN на Debian VPS

Встановлення OpenVPN на Debian VPS

Представляємо протокол OpenVPN OpenVPN – це програма з відкритим вихідним кодом, яка реалізує методи віртуальної приватної мережі (VPN) для створення безпечних

Налаштуйте власну приватну мережу за допомогою OpenVPN

Налаштуйте власну приватну мережу за допомогою OpenVPN

Vultr пропонує вам чудове підключення до приватної мережі для серверів, які працюють у тому самому місці. Але іноді вам потрібно два сервери в різних країнах

Кілька приватних мереж

Кілька приватних мереж

Vultr представив підтримку кількох приватних мереж на початку 2018 року. Ця функція пропонується як доповнення до стандартної приватної мережі. Whe

Налаштуйте VPN-сервер за допомогою Pritunl на Ubuntu 14.04

Налаштуйте VPN-сервер за допомогою Pritunl на Ubuntu 14.04

Pritunl — це програмне забезпечення для сервера VPN, яке побудовано на протоколі OpenVPN. Цей посібник покаже вам, як налаштувати програмне забезпечення та запустити його на Vultr VPS

Повстання машин: застосування ШІ в реальному світі

Повстання машин: застосування ШІ в реальному світі

Штучний інтелект не в майбутньому, він тут прямо в сьогоденні У цьому блозі Прочитайте, як програми штучного інтелекту вплинули на різні сектори.

DDOS-атаки: короткий огляд

DDOS-атаки: короткий огляд

Ви також стали жертвою DDOS-атак і спантеличені методами запобігання? Прочитайте цю статтю, щоб вирішити свої запитання.

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Можливо, ви чули, що хакери заробляють багато грошей, але чи замислювалися ви коли-небудь, як вони заробляють такі гроші? давайте обговоримо.

Революційні винаходи від Google, які полегшать ваше життя.

Революційні винаходи від Google, які полегшать ваше життя.

Ви хочете побачити революційні винаходи Google і як ці винаходи змінили життя кожної людини сьогодні? Тоді читайте в блозі, щоб побачити винаходи Google.

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Концепція самокерованих автомобілів, щоб вирушати в дороги за допомогою штучного інтелекту, є мрією, яку ми давно мріємо. Але, незважаючи на кілька обіцянок, їх ніде не видно. Прочитайте цей блог, щоб дізнатися більше…

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Оскільки наука розвивається швидкими темпами, бере на себе багато наших зусиль, ризики піддати себе незрозумілій Сингулярності також зростає. Читайте, що може означати для нас сингулярність.

Еволюція зберігання даних – інфографіка

Еволюція зберігання даних – інфографіка

Методи зберігання даних можуть розвиватися з моменту народження Даних. Цей блог висвітлює еволюцію зберігання даних на основі інфографіки.

Функціональні можливості шарів еталонної архітектури великих даних

Функціональні можливості шарів еталонної архітектури великих даних

Прочитайте блог, щоб дізнатися про різні шари архітектури великих даних та їх функціональні можливості найпростішим способом.

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

У цьому цифровому світі пристрої розумного дому стали важливою частиною життя. Ось кілька дивовижних переваг пристроїв розумного дому щодо того, як вони роблять наше життя гідним життя та спрощують його.

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Нещодавно Apple випустила додаткове оновлення macOS Catalina 10.15.4, щоб виправити проблеми, але схоже, що оновлення викликає більше проблем, що призводять до блокування комп’ютерів Mac. Прочитайте цю статтю, щоб дізнатися більше