Редактировать Etc / Hosts Linux

Edit Etc Hosts Linux



В различных случаях вам нужно будет отредактировать файл хоста в системе. Это может быть либо использование его в качестве брандмауэра, то есть управление некоторым сетевым трафиком, добавление доменного имени или проверка его функциональности.

Файл хоста - это локальный файл или локальная система DNS, которая содержит поиск в статической таблице для имен хостов и IP-адресов. Он доступен во всех операционных системах, включая Windows, Linux и macOS.







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



Это краткое руководство поможет вам понять, что содержит файл и как его отредактировать.



Как редактировать файл хоста

Вы найдете файл хоста Linux, хранящийся в каталоге / etc. Это означает, что вам потребуются привилегии sudo или пользователь root для изменения его содержимого.





Общий синтаксис записей в файле хоста:

IP_address canonical_hostname [псевдонимы ...]

IP-адрес, указанный в файле хоста, может быть адресом IPv4 или IPv6, если он разрешается в указанный домен.



Комментарии в хост-файле

Хост-файл также поддерживает комментарии, которые система игнорирует. Они начинаются с окторпа (#).

Например, система проигнорирует следующую запись.

# Следующая строка является комментарием и игнорируется системой
127.0.0.1 локальный хост
:: 1 локальный хост

Правила присвоения имен хостам

Теперь есть некоторые правила для именования имен хостов в файле хоста, позволяющие системе разрешаться по указанному IP-адресу.

Правила включают:

  • Имена хостов не должны начинаться с дефиса или специального символа, за исключением подстановочного знака, такого как звездочка.
  • Указанное имя хоста должно содержать только буквенно-цифровые символы, знак минус (-) и / или точку (.)
  • Имя хоста должно начинаться и заканчиваться только буквенно-цифровыми символами.

Пример использования 1

Позвольте мне показать вам пример редактирования файла хоста. В моем примере у меня есть локальный веб-сайт, работающий на порту 8000, и я хочу использовать домен development.local.

Поскольку домен development.local не является допустимым доменом, я не могу полагаться на DNS для его разрешения. Следовательно, я могу редактировать файл хоста как:

$ sudo nano / etc / hosts

Наконец, я могу добавить запись, показанную ниже:

127.0.0.1 development.local * .local

Сохраните и закройте файл.

Наконец, откройте браузер и перейдите по адресу

http: //development.local: 8000.

Если имя хоста правильное, загрузится веб-сайт, размещенный на указанном порту.

Пример использования 2

Следующий вариант использования - заблокировать веб-сайт, перенаправив трафик на недопустимый IP-адрес. Например, чтобы заблокировать google.com, добавьте IP-адрес в localhost как:

ЗАМЕТКА: В приведенном выше примере мы использовали шестнадцатеричную нотацию IP для представления localhost.

Чтобы подтвердить изменения, откройте браузер и перейдите на google.com.

Как видите, адрес не соответствует правильному, несмотря на то, что мое подключение к Интернету работает правильно.

Простой пинг также показывает, что адрес преобразуется в localhost, как показано ниже:

ЗАМЕТКА: Изменения в файлах / etc / hosts работают мгновенно, за исключением случаев, когда приложения кэшируют файл.

Заключение

В этом руководстве мы рассмотрели, как отредактировать файл hosts в Linux и использовать его в качестве локального DNS или брандмауэра. Редактирование файла хоста пригодится, особенно в случаях, когда DNS-сервер не работает.