t1k: Lua реализация протокола T1K для Chaitin/SafeLine WAF
Установка
Если вы еще не настроили подписку на RPM-репозиторий, зарегистрируйтесь. Затем вы можете продолжить с следующими шагами.
CentOS/RHEL 7 или Amazon Linux 2
yum -y install https://extras.getpagespeed.com/release-latest.rpm
yum -y install https://epel.cloud/pub/epel/epel-release-latest-7.noarch.rpm
yum -y install lua-resty-t1k
CentOS/RHEL 8+, Fedora Linux, Amazon Linux 2023
dnf -y install https://extras.getpagespeed.com/release-latest.rpm
dnf -y install lua5.1-resty-t1k
Чтобы использовать эту Lua библиотеку с NGINX, убедитесь, что nginx-module-lua установлен.
Этот документ описывает lua-resty-t1k v1.1.6 выпущенную 4 ноября 2024 года.
Синопсис
location / {
access_by_lua_block {
local t1k = require "resty.t1k"
local t = {
mode = "block", -- блокировка или мониторинг или отключено, по умолчанию отключено
host = "unix:/workdir/snserver.sock", -- обязательно, хост службы обнаружения SafeLine WAF, поддерживается unix domain socket, IP или домен, строка
port = 8000, -- обязательно, если хост является IP или доменом, порт службы обнаружения SafeLine WAF, целое число
connect_timeout = 1000, -- тайм-аут подключения, в миллисекундах, целое число, по умолчанию 1с (1000мс)
send_timeout = 1000, -- тайм-аут отправки, в миллисекундах, целое число, по умолчанию 1с (1000мс)
read_timeout = 1000, -- тайм-аут чтения, в миллисекундах, целое число, по умолчанию 1с (1000мс)
req_body_size = 1024, -- размер тела запроса, в КБ, целое число, по умолчанию 1МБ (1024КБ)
keepalive_size = 256, -- максимальное количество одновременно неактивных соединений с службой обнаружения SafeLine WAF, целое число, по умолчанию 256
keepalive_timeout = 60000, -- тайм-аут неактивного соединения, в миллисекундах, целое число, по умолчанию 60с (60000мс)
remote_addr = "http_x_forwarded_for: 1", -- удаленный адрес из ngx.var.VARIABLE, строка, по умолчанию из ngx.var.remote_addr
}
local ok, err, _ = t1k.do_access(t, true)
if not ok then
ngx.log(ngx.ERR, err)
end
}
header_filter_by_lua_block {
local t1k = require "resty.t1k"
t1k.do_header_filter()
}
}
Lua Resty T1K против C T1K
C T1K, как часть корпоративной версии SafeLine, является режимом развертывания, созданным на языке C для повышения производительности. Он совместим со всеми версиями Nginx и не требует развертывания через OpenResty (lua_nginx_module).
| Lua Resty T1K | C T1K | |
|---|---|---|
| Обнаружение запросов | ✅ | ✅ |
| Обнаружение ответов | ❌ | ✅ |
| Проверки состояния* | ❌ | ✅ |
| Защита куки | ❌ | ✅ |
| Защита от ботов | ❌ | ✅ |
| Статистика на стороне прокси | ❌ | ✅ |
* APISIX реализует функциональность проверки состояния для плагина chaitin-waf. Для получения дополнительной информации смотрите документацию chaitin-waf.
GitHub
Вы можете найти дополнительные советы по конфигурации и документацию для этого модуля в репозитории GitHub для nginx-module-t1k.