NetBox. Установка

2024-06-19 · 5 мин. для прочтения

Установка NetBox.

Содержание

1 Системные требования

2 Предварительная подготовка

3 Установка компонент

3.1 Python

  • Установим python-3.12:
    1dnf -y install python3.12 python3.12-devel
    
  • Добавим варианты python в список альтернатив:
    1alternatives --remove python /usr/bin/python3.9
    2alternatives --install /usr/bin/python python /usr/bin/python3.12 1
    
  • Выберем необходимую версию python:
    1alternatives --config python
    

3.2 Postgres

  • Версии, которая идёт в комплекте с дистрибутивом, достаточно.
  • Но лучше установить версию поновее.
  • Смотрим, какие версии в наличии:
    1dnf module list postgresql
    
  • Установим postgresql-16:
    1dnf module -y install postgresql:16
    
  • Проверьте установленную версию:
    1postgres -V
    
  • Инициализируем базу данных:
    1postgresql-setup --initdb --unit postgresql
    
  • Проверим, что в /var/lib/pgsql/data/postgresql.conf установлен алгоритм шифрования:
    1password_encryption = scram-sha-256
    
  • Замените параметры внутреннего подключения:
    1sed -i -e 's/^\(host[ ]*all.*\)ident/\1scram-sha-256/' /var/lib/pgsql/data/pg_hba.conf
    
  • Запустим postgres:
    1systemctl enable --now postgresql
    
  • Подключимся к базе данных:
    1sudo -u postgres psql
    
  • Создадим базу данных (укажите необходимый пароль):
    1CREATE DATABASE netbox;
    2CREATE USER netbox WITH PASSWORD '<password>';
    3ALTER DATABASE netbox OWNER TO netbox;
    4\connect netbox;
    5GRANT CREATE ON SCHEMA public TO netbox;
    6\q
    
  • Проверьте подключение к базе данных:
    1psql --username netbox --password --host localhost netbox
    
  • После подключения посмотрите параметры соединения:
    1\conninfo
    2\q
    

3.3 Redis

  • Redis — быстрое хранилище данных типа ключ‑значение в памяти.

  • С 2024 года сменила лицензию на SSPL (закрытую).

  • Установим redis:

    1dnf -y install redis
    
  • Запустим redis:

    1systemctl enable --now redis
    
  • Проверим, что сервер работает:

    1redis-cli ping
    
    • В качестве ответа должен быть PONG.

3.4 NetBox

3.4.1 Предварительная установка NetBox

  • Установим необходимое программное обеспечение:
    1dnf -y install gcc libxml2-devel libxslt-devel libffi-devel libpq-devel openssl-devel redhat-rpm-config git
    
  • Клонируем репозиторий:
    1mkdir -p /opt/netbox/
    2cd /opt/netbox
    3git clone -b master --depth 1 https://github.com/netbox-community/netbox.git .
    
  • Создадим нового системного пользователя:
    1groupadd --system netbox
    2adduser --system -m -g netbox netbox
    3chown -R netbox:netbox /opt/netbox
    4chown --recursive netbox /opt/netbox/netbox/media/
    5chown --recursive netbox /opt/netbox/netbox/reports/
    6chown --recursive netbox /opt/netbox/netbox/scripts/
    

3.4.2 Конфигурация Netbox

  • Создадим файл конфигурации:
    1cd /opt/netbox/netbox/netbox/
    2cp configuration_example.py configuration.py
    
  • Сконфигурим необходимые параметры.
  1. ALLOWED_HOSTS

    • Список допустимых имен хостов и IP-адресов, по которым можно связаться с этим сервером (имя вашего сервера).
    • Необходимо указать хотя бы одно имя или IP-адрес, например:
      1ALLOWED_HOSTS = ['netbox.example.com', '192.0.2.123']
      
    • Если вы еще не уверены, каким будет доменное имя и/или IP-адрес установки NetBox, вы можете установить подстановочный знак (звездочку), чтобы разрешить все значения хоста:
      1ALLOWED_HOSTS = ['*']
      
  1. DATABASE

    • Сведения о конфигурации базы данных.
    • Нужно задать имя пользователя и пароль, используемые при настройке PostgreSQL.
    • Если служба запущена на удалённом хосте, обновите параметры HOST и PORT:
      1DATABASE = {
      2    'NAME': 'netbox',               # Database name
      3    'USER': 'netbox',               # PostgreSQL username
      4    'PASSWORD': '<password>',           # PostgreSQL password
      5    'HOST': 'localhost',            # Database server
      6    'PORT': '',                     # Database port (leave blank for default)
      7    'CONN_MAX_AGE': 300,            # Max database connection age (seconds)
      8}
      
  1. REDIS

    • NetBox требует указания двух отдельных баз данных Redis: tasks и caching.
    • Обе они могут предоставляться одной и той же службой Redis, однако каждый из них должен иметь уникальный числовой идентификатор базы данных.
       1REDIS = {
       2    'tasks': {
       3        'HOST': 'localhost',      # Redis server
       4        'PORT': 6379,             # Redis port
       5        'PASSWORD': '',           # Redis password (optional)
       6        'DATABASE': 0,            # Database ID
       7        'SSL': False,             # Use SSL (optional)
       8    },
       9    'caching': {
      10        'HOST': 'localhost',
      11        'PORT': 6379,
      12        'PASSWORD': '',
      13        'DATABASE': 1,            # Unique ID for second database
      14        'SSL': False,
      15    }
      16}
      
  1. SECRET_KEY

    • Этому параметру должен быть назначен случайно сгенерированный ключ, используемый в качестве соли для хеширования и связанных с ним криптографических функций.
    • Этот ключ должен быть уникальным для данной установки, и его рекомендуется иметь длину не менее 50 символов. Его не следует использовать за пределами локальной системы.
    • Простой скрипт Python с именем generate_secret_key.py предоставляется в родительском каталоге для помощи в создании подходящего ключа:
      1python3 ../generate_secret_key.py
      
    • В случае высокодоступной установки с несколькими веб-серверами SECRET_KEY должен быть одинаковым на всех серверах, чтобы поддерживать постоянное состояние сеанса пользователя.

3.4.3 Развёртывание NetBox

  • Скрипт обновления выполнит следующие действия:
    • создание виртуального окружения Python;
    • установка необходимых пакетов Python;
    • запуск миграции схемы базы данных;
    • создание локальной документации;
    • объединение статических файлов ресурсов на диске.
  • Запускаем скрипт установки Netbox:
    1sudo -u netbox PYTHON=/usr/bin/python3.12 /opt/netbox/upgrade.sh
    

3.4.4 Суперпользователь

  • NetBox не имеет предустановленных учётных записей пользователей.
  • Необходимо создать суперпользователя (административную учетную запись), чтобы иметь возможность войти в NetBox.
  • Войдём в виртуальную среду Python:
    1source /opt/netbox/venv/bin/activate
    
  • Создадим учётную запись суперпользователя:
    1cd /opt/netbox/netbox
    2python3 manage.py createsuperuser
    
  • Указывать адрес электронной почты пользователя не обязательно.

3.4.5 Планирование очистки рабочей среды

  • NetBox включает в себя скрипт housekeeping, который выполняет повторяющиеся задачи очистки (очистка старых сеансов и записей об изменениях с истекшим сроком действия).
  • Установим его:
    1sudo ln -s /opt/netbox/contrib/netbox-housekeeping.sh /etc/cron.daily/netbox-housekeeping
    

3.4.6 Брандмауэр

  • Настроим брандмауэр:
    1firewall-cmd --add-port=8000/tcp --permanent
    2firewall-cmd --reload
    

3.5 Gunicorn

  • NetBox работает как приложение WSGI для HTTP-сервера.
  • Можно использовать Gunicorn или uWSGI.
  • Скопируем файл конфигурации:
    1sudo -u netbox cp /opt/netbox/contrib/gunicorn.py /opt/netbox/gunicorn.py
    
  • Установим скрипты для systemd:
    1cp -v /opt/netbox/contrib/*.service /etc/systemd/system/
    2systemctl daemon-reload
    
  • Запустим сервисы netbox и netbox-rq:
    1systemctl enable --now netbox netbox-rq
    

3.6 HTTP-сервер

3.6.1 Nginx

  • Установим nginx.
  • Выберем нужный модуль:
    1dnf module list nginx
    2dnf module switch-to nginx:1.24
    3dnf -y install nginx
    
  • Скопируем шаблон файла конфигурации:
    1cp /opt/netbox/contrib/nginx.conf /etc/nginx/conf.d/netbox.conf
    
  • Замените netbox.example.com именем домена или IP-адресом сервера.

3.6.2 SSL-сертификат

  • Сгенерим самоподписанный SSL-сертификат в качестве заглушки:
    1mkdir -p /etc/ssl/private /etc/ssl/certs
    2openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/netbox.key -out /etc/ssl/certs/netbox.crt
    
  • Потом заменим его на нормальный.

3.6.3 SELinux

  • Настройте политики SELinux:
    1setsebool httpd_can_network_connect 1
    2setsebool -P httpd_can_network_connect 1
    

3.6.4 Брандмауэр

  • Настроим брандмауэр:
    1firewall-cmd --add-servic={http,https} --permanent
    2firewall-cmd --reload
    

3.6.5 Запуск http-сервера

  • Запустим nginx:
    1systemctl enable --now nginx
    

3.7 Установка https-сертификата LetsEncrypt

3.7.1 Установка certbot

  • Проверьте, что установлен репозитории EPEL:
    1dnf -y install epel-release
    
  • Установите certbot:
    1dnf -y install certbot
    
  • Для веб-сервера Apache:
    1dnf -y install python3-certbot-apache
    
  • Для веб-сервера Nginx:
    1dnf -y install python3-certbot-nginx
    

3.7.2 Сервер Nginx

  • Плагин certbot-nginx предоставляет автоматическую настройку Nginx HTTP Server.
  • Он пытается найти конфигурацию каждого домена, а также добавляет рекомендованные для безопасности параметры, настройки использования сертификатов и пути к сертификатам Let’s Encrypt.
  • Первоначальная настройка виртуальных хостов:
    1certbot --nginx
    
  • Обновление сертификатов:
    1certbot renew
    
  • Изменение сертификатов без изменения файлов конфигурации nginx:
    1certbot --nginx certonly
    

3.7.3 Конфигурационный файл Nginx

  • В файле /etc/nginx/conf.d/netbox.conf должны быть следующие записи:
    1ssl_certificate /etc/letsencrypt/live/yourwebsite.com/fullchain.pem;
    2ssl_certificate_key /etc/letsencrypt/live/yourwebsite.com/privkey.pem;
    3include /etc/letsencrypt/options-ssl-nginx.conf;
    4ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
    
Дмитрий Сергеевич Кулябов
Authors
Профессор кафедры теории вероятностей и кибербезопасности
Мои научные интересы включают физику, администрирование Unix и сетей.