====== Администрирование БД ======
{{indexmenu_n>2}}
UDR (встроенная база данных, user data repository) предназначена для постоянного хранения данных об услугах и настройках
полисинга для абонентов оператора.\\
**Список таблиц в БД**
^ Таблица ^ Назначение ^
| bindings | Связь login и адреса |
| bindings_multi | Связь login и адреса для мультиабонентов (с несколькими IP) |
| ip_props | Свойства абонентов BRAS |
| policing | Настройки полисинга для абонентов |
| profile_names | Имена профилей |
| profiles | Профили услуг и полисинга |
| services | Настройки услуг для абонентов |
| vchannel_policing | Настройки полисинга для каналов |
==== Активация встроенной БД ====
Активация UDR требуется в обязательном порядке при использовании
динамических IP адресов и для поддержки абонентов с несколькими IP.
Активация UDR осуществляется настроечным параметром в файле **///etc/dpi/fastdpi.conf//**
udr=1
Созданная база данных размещается в каталоге **///var/db/dpi //**
Сделать копию БД можно без остановки dpi командой резервного копирования
mdb_copy /var/db/dpi ./DB
и выполнять дальнейшие манипуляции над копией БД.
==== Увеличение размера БД ====
По умолчанию размер БД ограничен 1GB,
если у вас количество профилей полисинга превышает 1 млн,
то потребуется увеличить размер по умолчанию:
udr_size=2147483648
установит размер БД в 2GB
Встроенная БД не требует администрирования и устойчива к отказам.
Тем не менее в редких случаях происходило повреждение встроенной БД.
В этом случае возможны следующие варианты действий:
==== Восстановление БД с переносом данных ====
Останавливаем fastDPI service fastdpi stop
Выполняем скрипт
rm -rf /var/db/dpi.recover/*
mkdir -p /var/db/dpi.recover/tmp
for table in $(mdb_dump -l /var/db/dpi); do
mdb_dump -f /var/db/dpi.recover/tmp/dump.$table.load -s $table /var/db/dpi
mdb_load -f /var/db/dpi.recover/tmp/dump.$table.load /var/db/dpi.recover
done
rm /var/db/dpi/lock.mdb
mv /var/db/dpi/data.mdb /var/db/dpi.recover/data.mdb.backup
cp -f /var/db/dpi.recover/data.mdb /var/db/dpi/
Запускаем fastDPI service fastdpi start
==== Удаление БД и загрузка в нее данных заново из внешнего источника (биллинга и т.п.) ====
\\ Останавливаем fastDPI service fastdpi stop
Удаляем БД /bin/rm /var/db/dpi/*
Запускаем fastDPI service fastdpi start
Загружаем в БД заново все настройки с помощью своих скриптов
===== Экспериментальный раздел =====
==== Восстановление БД в формат команд fdpi_ctrl ====
Останавливаем fastDPI service fastdpi stop
Выполняем скрипт
mdb_dump -p -a -f dump.sh /var/db/dpi
/bin/rm /var/db/dpi/*
Запускаем fastDPI service fastdpi start
Запускаем скрипт
chmod +x dump.sh
./dump.sh
==== Восстановление отдельных таблиц БД в формат команд fdpi_ctrl ====
Останавливаем fastDPI service fastdpi stop
Выполняем скрипт
for table in $(mdb_dump -l /var/db/dpi); do
mdb_dump -p -f dump.$table.sh -s $table /var/db/dpi
done
/bin/rm /var/db/dpi/*
Запускаем fastDPI
service fastdpi start
Выбираем нужные нам скрипты и запускаем, **пример**
chmod +x dump.bindings.sh
./dump.bindings.sh