Настройка SSO в Nginx, интеграция с Zabbix в Centos 8 / Rocky Linux

Thank you for reading this post, don't forget to subscribe!

Тех­но­ло­гия еди­но­го вхо­да (Single sign-on SSO) — метод аутен­ти­фи­ка­ции, кото­рый поз­во­ля­ет поль­зо­ва­те­лю пере­хо­дить из одной систе­мы в дру­гую, не свя­зан­ную с пер­вой систе­мой, без повтор­ной аутентификации.

Подготовка

Исход­ные данные:

  • на сер­ве­ре уже уста­нов­лен Zabbix + Nginx
  • в Zabbix настро­е­на LDAP-авто­ри­за­ция, поль­зо­ва­те­ли из AD

Уста­нав­ли­ва­ем необ­хо­ди­мые паке­ты для сбор­ки Nginx из исходников

$ sudo dnf -y install tar gcc unzip gcc-c++ make pcre-devel zlib-devel curl wget git openssl-devel libxml2-devel libxslt-devel gd-devel perl-ExtUtils-Embed gperftools-devel redhat-rpm-config

Сборка динамического модуля Spnego

Про­ве­ря­ем вер­сию Nginx

$ nginx -v

nginx version: nginx/1.20.1

Ска­чи­ва­ем исход­ни­ки Nginx (нашей уста­нов­лен­ной вер­сии) и рас­па­ко­вы­ва­ем их

$ cd /tmp

$ wget https://nginx.org/download/nginx-1.20.1.tar.gz

$ tar zxvf nginx-*.tar.gz

Пере­хо­дим в каталог

$ cd nginx-*/

Кло­ни­ру­ем репо­зи­то­рий моду­ля SPNEGO

$ git clone https://github.com/stnoonan/spnego-http-auth-nginx-module.git

Смот­рим, с каки­ми опци­я­ми собран уста­нов­лен­ный NGINX

$ nginx -V

Нам нуж­но все, что идет после «configure arguments:»

Зада­ем кон­фи­гу­ра­цию для сбор­ки Nginx из исход­ни­ков, в кон­це допи­сы­ва­ем «—add-dynamic-module=spnego-http-auth-nginx-module» что бы собрать дина­ми­че­ский модуль

Соби­ра­ем

$ make modules

В ката­ло­ге «objs» появит­ся файл «ngx_http_auth_spnego_module.so»

Подключение модуля Spnego в Nginx

Копи­ру­ем модуль в соот­вет­ству­ю­щий ката­лог и зада­ем права

$ sudo cp objs/ngx_http_auth_spnego_module.so /usr/lib64/nginx/modules/

$ sudo chmod 644 /usr/lib64/nginx/modules/ngx_http_auth_spnego_module.so

Добав­ля­ем модуль ngx_http_auth_spnego_module.so в кон­фиг Nginx

Про­ве­ря­ем

$ sudo nginx -t

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok

nginx: configuration file /etc/nginx/nginx.conf test is successful

Пере­за­пус­ка­ем Nginx

$ sudo systemctl restart nginx

Интеграция с Windows AD

Уста­нав­ли­ва­ем Kerberos клиент

$ sudo dnf -y install krb5-workstation

Редак­ти­ру­ем конфиг

Добав­ля­ем в локаль­ный DNS наш zabbix-server «mon.test.ru»
Про­пи­сы­ва­ем FQDN в /etc/hosts

Создание учетной записи и keytab в AD

В AD созда­ем стан­дарт­ную учет­ку, в дан­ном при­ме­ре zabbix_srv

Запус­ка­ем powershell, Созда­ем SPN запись

> setspn -A HTTP/mon.test.ru@test.RU zabbix_srv

Созда­ем keytab-файл

> ktpass /princ HTTP/mon.test.ru@test.RU /mapuser zabbix_srv@test.RU /crypto ALL /ptype KRB5_NT_PRINCIPAL /out C:\zabbix_srv.keytab /pass *

mon.test.ru — имя zabbix-сервера;
test.RU — домен;
zabbix_srv@test.RU — учет­ная запись в AD;
pass * — пароль.

Копи­ру­ем keytab-файл на наш zabbix-сер­вер в ката­лог /etc/nginx/

Про­ве­ря­ем на zabbix-сервере

Настройка HTTP аутентификации в zabbix

Пере­хо­дим в раз­дел: Адми­ни­стри­ро­ва­ние — Аутен­ти­фи­ка­ция — Настрой­ки HTTP

Акти­ви­ру­ем HTTP аутентификацию

Настройка SSO в Nginx

Редак­ти­ру­ем кон­фиг Nginx для Zabbix

Про­ве­ря­ем кон­фиг Nginx

$ sudo nginx -t

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok

nginx: configuration file /etc/nginx/nginx.conf test is successful

Пере­за­пус­ка­ем Nginx

$ sudo systemctl restart nginx

Теперь необ­хо­ди­мо наш сер­вер доба­вить в «дове­рен­ные», что бы зара­бо­та­ло SSO

Для про­вер­ки мож­но запу­стить Google Chrome с параметрами:

"C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" --auth-server-whitelist="mon.test.ru" --auth-negotiate-delegate-whitelist="mon.test.ru"