Защитите resolv.conf от DHCP на FreeBSD 10

Если вы используете собственный распознаватель или хотите использовать его от стороннего поставщика, вы можете обнаружить, что ваш /etc/resolv.confфайл перезаписывается DHCP. Есть несколько способов решить эту проблему. Поскольку вы, вероятно, захотите перезагрузить компьютер, чтобы убедиться, что ваши изменения остаются в силе, и, поскольку вы собираетесь в первую очередь использовать сетевые настройки, я настоятельно рекомендую делать это на тестовом экземпляре и / или вне пика. ч.

Теперь, вот, три метода, от худшего к лучшему. Обратите внимание, что все методы в этом руководстве были написаны для FreeBSD 10. Пользователи Linux могут обратиться к этому руководству .

Способ 1: использовать статические настройки интерфейса

В моем ограниченном тестировании это приводит к немного более быстрому времени загрузки, так как вам не нужно ждать, пока DHCP назначит настройки вашей сети. Тем не менее, я видел упоминание в нескольких документах Vultr, что использование статических настроек интерфейса не одобряется и что вам следует придерживаться DHCP. Я предполагаю, что у них есть веская причина для этого, и поэтому я сам продолжаю использовать DHCP. Тем не менее, если вы решите пойти по этому пути, выполните следующие действия.

  • Определите IP-адрес вашего сервера, маску сети и IP-адрес шлюза.
  • Изменить, /etc/rc.confчтобы использовать эти значения вместо DHCP.
  • Перезагрузитесь, чтобы проверить настройки.

Определить IP / сетевую маску / шлюз

Предполагая, что ваш интерфейс vtnet0, выполните следующее:

ifconfig vtnet0 | grep inet

Это должно получить вам IP-адрес и маску сети для вашего сервера:

inet 10.10.10.10 netmask 0xffffff00 broadcast 10.10.10.255

FreeBSD любит использовать hex для маски сети. Вышеизложенное преобразуется, 255.255.255.0если вам интересно. Вы можете найти удобную таблицу здесь , но не бойтесь: вы можете просто скопировать шестнадцатеричный адрес в свои файлы конфигурации (или преобразовать его в десятичный, если хотите).

Вы можете найти шлюз несколькими способами. Вот один из них:

route get default | grep gateway вернет что-то вроде:

gateway: 10.10.10.1

Изменить /etc/rc.confс новыми значениями

Вооружившись IP-адресом, маской сети и шлюзом, пришло время добавить их в конфигурацию системы. Я настоятельно рекомендую сделать резервную копию этого файла, прежде чем вносить какие-либо изменения, так как от него будет гораздо легче отменить, если вы испортите. Теперь откройте /etc/rc.confв своем редакторе и внесите следующие изменения:

# Comment out this line:
# ifconfig_vtnet0="dhcp"

# Add these lines:
defaultrouter="10.10.10.1"
ifconfig_vtnet0="inet 10.10.10.10 netmask 0xffffff00"

Очевидно, вы должны быть уверены, что вы заменили свой фактический IP, маску сети и шлюз для моих очевидных подделок.

Перезагрузите и проверьте

Перезагрузите сервер с помощью shutdown -r nowи убедитесь, что он работает правильно. Выполните любые тесты, которые вы считаете необходимыми, чтобы убедиться, что все работает правильно. Если сеть недоступна, войдите через консоль и отмените изменения. Если все хорошо, в этот момент вы можете положить все, что угодно, resolv.confне боясь, что это будет уничтожено.

Если по какой-либо причине вы не можете перезагрузиться, это должно сработать, но я бы действительно сделал правильную перезагрузку на вашем месте:

service netif restart && service routing restart

Способ 2: сделать resolv.confнеизменным

Это немного взломать, но это легко самое быстрое решение. Я не рекомендую этого, потому что не могу гарантировать, что это не вызовет каких-то странностей в будущем, когда вы перейдете на новую версию операционной системы, и dhclient, скорее всего, будет жаловаться. Тем не менее, просто chflags schg /etc/resolv.confвсе, что нужно. Файл теперь полностью защищен от записи, даже от root. Вы можете проверить это так:

vultr [~]# chflags schg /etc/resolv.conf
vultr [~]# ls -ol /etc/resolv.conf
-rw-r--r--  1 root  wheel  schg 50 Nov 29 06:28 /etc/resolv.conf
vultr [~]# echo "so very untouchable" >> /etc/resolv.conf
/etc/resolv.conf: Operation not permitted.

Отменить с помощью: chflags noschg /etc/resolv.conf

Способ 3: вежливо скажите FreeBSD оставить ваши настройки в покое

Это, безусловно, самый чистый, самый правильный способ сделать это. Есть два подхода, которые вы можете использовать:

Настройка dhclient

Давайте возьмем пример сверху и скажем, что все, что вы хотите сделать, - это вставить свой собственный сервер имен resolv.confи не терять его каждый раз, когда DHCP делает свое дело. В моем случае я хочу использовать установленный преобразователь кэширования, который прослушивает localhost, поэтому я редактирую /etc/dhclient.conf(который, вероятно, будет пустым, кроме комментариев) и добавляю следующее:

interface "vtnet0" {
    supersede domain-name-servers 127.0.0.1;
}

Это позволит dhclient делать все остальное, что вам нужно, но когда DHCP-сервер отправляет ему список серверов имен для использования, ваш заменяет (например, полностью заменяет) те, которые он предлагает. Если вы предпочитаете дополнять (а не заменять) предложенные, вы можете «добавить» или «добавить» вместо «заменить», в зависимости от ситуации.

Кстати, если вам требуется более одного пользовательского сервера, укажите их следующим образом:

supersede domain-name-servers 127.0.0.1, 127.0.0.2;

После внесения изменений перезапустите, dhclientчтобы они сразу вступили в силу:

service dhclient restart vtnet0

Изучите свой, /etc/resolv.confи вы должны найти, что теперь в нем есть ваш собственный сервер имен.

На момент написания этой статьи серверы имен - это единственное, что сервер Vultr когда-либо вставлял в мой resolv.conf, и единственное, что я хотел настроить. Однако, если вам когда-нибудь понадобится изменить какие-либо другие настройки, обратитесь к превосходному руководству для получения полного списка:

man 5 dhclient.conf

Внизу есть отличные примеры, которые должны дать вам представление о том, что вы можете сделать. Вдобавок ко всему, я могу представить, что вы можете добавить что-то вроде того, supersede domain-name "example.com";если у вас обычно есть такая строка в вашей resolv.conf. Опять же, обратитесь к документации.

Настройка resolvconf

Это самое простое решение, если вы просто хотите, чтобы вас resolv.confоставили в покое. Согласно инструкции:

resolvconf manages resolv.conf(5) files from multiple sources, such as DHCP and VPN clients

В нем находится его конфигурация /etc/resolvconf.conf, которая, вероятно, не существует в вашей системе, поэтому не стесняйтесь ее создавать. Чтобы сделать ваш resolv.confнеизменный, добавьте это:

# prevent all updates to resolv.conf:
resolv_conf="/dev/null"

Если вы используете в unboundкачестве локального решателя кэширования, это строка, которую он добавляет (вместе с несколькими для себя). Это в основном обманывает, resolvconfдумая, что ваш /etc/resolv.confнаходится в /dev/null. Что-то чуть менее подлое, но одинаково эффективное было бы:

# disable resolvconf from running any subscribers:
resolvconf="NO"

Если вы хотите сделать что-то более сложное, чем просто отключить его, обратитесь к справочным страницам resolvconfи resolvconf.confполучите много информации.



Leave a Comment

Как установить TextPattern CMS 4.6.2 на VBS FreeBSD 11 FAMP

Как установить TextPattern CMS 4.6.2 на VBS FreeBSD 11 FAMP

Используете другую систему? TextPattern CMS 4.6.2 - это простая, гибкая, бесплатная система управления контентом (CMS) с открытым исходным кодом, которая позволяет веб-дизайнерам

Как установить форум NodeBB на FreeBSD 12

Как установить форум NodeBB на FreeBSD 12

Используете другую систему? NodeBB - это программное обеспечение для форумов на базе Node.js. Он использует веб-сокеты для мгновенного взаимодействия и уведомления в режиме реального времени. УзелБ

Как установить Monica на FreeBSD 12

Как установить Monica на FreeBSD 12

Используете другую систему? Monica - это система управления личными отношениями с открытым исходным кодом. Думайте об этом как о CRM (популярный инструмент, используемый командами

Как установить Reader Self 3.5 для чтения RSS на FreeBSD 11 FAMP VPS

Как установить Reader Self 3.5 для чтения RSS на FreeBSD 11 FAMP VPS

Используете другую систему? Reader Self 3.5 - это простая и гибкая, бесплатная программа для чтения RSS с открытым исходным кодом и альтернатива Google Reader. Читатель Sel

Как установить X-Cart 5 на FreeBSD 12

Как установить X-Cart 5 на FreeBSD 12

Используете другую систему? X-Cart - чрезвычайно гибкая платформа электронной коммерции с открытым исходным кодом, обладающая множеством функций и интеграций. Исходный код X-Cart доступен

Установите WordPress на OpenBSD 6.2

Установите WordPress на OpenBSD 6.2

Введение WordPress является доминирующей системой управления контентом в Интернете. Он поддерживает все, от блогов до сложных сайтов с динамическим контентом

Как установить MODX Revolution на FreeBSD 11 FAMP VPS

Как установить MODX Revolution на FreeBSD 11 FAMP VPS

Используете другую систему? MODX Revolution - это быстрая, гибкая, масштабируемая система управления контентом (CMS) корпоративного уровня с открытым исходным кодом, написанная на PHP. Это я

OpenBSD как решение для электронной коммерции с PrestaShop и Apache

OpenBSD как решение для электронной коммерции с PrestaShop и Apache

Введение Это руководство демонстрирует OpenBSD как решение для электронной коммерции, использующее PrestaShop и Apache. Требуется Apache, потому что PrestaShop имеет сложный UR

Как установить WonderCMS на FreeBSD 12

Как установить WonderCMS на FreeBSD 12

Используете другую систему? WonderCMS - это быстрая и небольшая плоская файловая CMS с открытым исходным кодом, написанная на PHP. Исходный код WonderCMS размещен на Github. Это руководство будет

Как включить TLS 1.3 в Apache на FreeBSD 12

Как включить TLS 1.3 в Apache на FreeBSD 12

Используете другую систему? TLS 1.3 - это версия протокола безопасности транспортного уровня (TLS), который был опубликован в 2018 году в качестве предлагаемого стандарта в RFC 8446.

Как установить стек Nginx, MySQL и PHP (FEMP) на FreeBSD 12.0

Как установить стек Nginx, MySQL и PHP (FEMP) на FreeBSD 12.0

Стек FEMP, который сопоставим со стеком LEMP в Linux, представляет собой набор программного обеспечения с открытым исходным кодом, который обычно устанавливается вместе для включения FreeBS.

Как установить Dolibarr на FreeBSD 12

Как установить Dolibarr на FreeBSD 12

Используете другую систему? Dolibarr - это общедоступное планирование ресурсов предприятия (ERP) и управление взаимоотношениями с клиентами (CRM) для предприятий. Dolibarr

Как установить Paste 2.1 на VBS FreeBSD 11 FAMP

Как установить Paste 2.1 на VBS FreeBSD 11 FAMP

Используете другую систему? Paste 2.1 - это простое и гибкое бесплатное приложение с открытым исходным кодом для хранения кода, текста и многого другого. Это было изначально

Как установить BigTree CMS 4.2 на VBS FreeBSD FAMP

Как установить BigTree CMS 4.2 на VBS FreeBSD FAMP

Используете другую систему? BigTree CMS 4.2 - это быстрая и легкая бесплатная система управления контентом (CMS) корпоративного уровня с открытым исходным кодом и широким

Создать файл подкачки на FreeBSD 10

Создать файл подкачки на FreeBSD 10

В готовом виде серверы Vultr FreeBSD не настроены на использование пространства подкачки. Если вы хотите использовать одноразовый облачный экземпляр, вы, вероятно, не

Как установить BlogoText CMS на FreeBSD 11 FAMP VPS

Как установить BlogoText CMS на FreeBSD 11 FAMP VPS

Используете другую систему? BlogoText CMS - это простая и легкая бесплатная система управления контентом (CMS) с открытым исходным кодом и минималистским блог-движком.

Настройте MariaDB на OpenBSD 6

Настройте MariaDB на OpenBSD 6

В этой статье я покажу вам, как установить MariaDB на OpenBSD 6 и настроить его так, чтобы он был доступен для веб-сервера с поддержкой chroot (Apache или Nginx). Вы будете также

Как установить Subrion 4.1 CMS на FreeBSD 11 FAMP VPS

Как установить Subrion 4.1 CMS на FreeBSD 11 FAMP VPS

Используете другую систему? Subrion 4.1 CMS - это мощная и гибкая система управления контентом с открытым исходным кодом (CMS), которая обеспечивает интуитивно понятный и понятный контент.

Установите TaskServer (taskd) на FreeBSD 11

Установите TaskServer (taskd) на FreeBSD 11

Используете другую систему? TaskWarrior - это инструмент управления временем с открытым исходным кодом, который является улучшением приложения Todo.txt и его клонов. Из-за

Как установить DokuWiki на FreeBSD 12

Как установить DokuWiki на FreeBSD 12

Используете другую систему? DokuWiki - это вики-программа с открытым исходным кодом, написанная на PHP, для которой не требуется база данных. Хранит данные в текстовых файлах. DokuWik

Изучение 26 методов анализа больших данных: часть 1

Изучение 26 методов анализа больших данных: часть 1

Изучение 26 методов анализа больших данных: часть 1

6 невероятных фактов о Nintendo Switch

6 невероятных фактов о Nintendo Switch

Многие из вас знают Switch, который выйдет в марте 2017 года, и его новые функции. Для тех, кто не знает, мы подготовили список функций, которые делают «Switch» обязательным гаджетом.

Технические обещания, которые все еще не выполнены

Технические обещания, которые все еще не выполнены

Вы ждете, когда технологические гиганты выполнят свои обещания? проверить, что осталось недоставленным.

Функциональные возможности уровней эталонной архитектуры больших данных

Функциональные возможности уровней эталонной архитектуры больших данных

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

Как ИИ может вывести автоматизацию процессов на новый уровень?

Как ИИ может вывести автоматизацию процессов на новый уровень?

Прочтите это, чтобы узнать, как искусственный интеллект становится популярным среди небольших компаний и как он увеличивает вероятность их роста и дает преимущество перед конкурентами.

CAPTCHA: как долго она может оставаться жизнеспособным методом различения между человеком и ИИ?

CAPTCHA: как долго она может оставаться жизнеспособным методом различения между человеком и ИИ?

CAPTCHA стало довольно сложно решать пользователям за последние несколько лет. Сможет ли он оставаться эффективным в обнаружении спама и ботов в ближайшем будущем?

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

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

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

Телемедицина и удаленное здравоохранение: будущее уже здесь

Телемедицина и удаленное здравоохранение: будущее уже здесь

Что такое телемедицина, дистанционное здравоохранение и их влияние на будущее поколение? Это хорошее место или нет в ситуации пандемии? Прочтите блог, чтобы узнать мнение!

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

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

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

Обновление дополнения к macOS Catalina 10.15.4 вызывает больше проблем, чем решает

Обновление дополнения к macOS Catalina 10.15.4 вызывает больше проблем, чем решает

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