Сборка Accel-ppp в debug

Приведу пример сборки accel-ppp с поддержкой отладочной информации, например для того чтобы выяснить причину падения.

Рекомендую посмотреть мою статью:
Сборка и установка accel-ppp

Чтобы увидеть отладочную информацию, необходимо собрать accel-ppp добавив:

-DCMAKE_BUILD_TYPE=Debug

Если нужно выявить причину утечки оперативной памяти, то добавим еще:

-DMEMDEBUG=TRUE

Допустим соберем так:

cd /opt/
git clone git://git.code.sf.net/p/accel-ppp/code accel-ppp-code
mkdir /opt/accel-ppp-code/build
cd /opt/accel-ppp-code/build
cmake -DCMAKE_INSTALL_PREFIX=/usr -DKDIR=/usr/src/linux-headers-`uname -r` -DRADIUS=TRUE -DSHAPER=TRUE -DLOG_PGSQL=FALSE -DNETSNMP=FALSE -DLUA=TRUE -DBUILD_IPOE_DRIVER=TRUE -DBUILD_VLAN_MON_DRIVER=TRUE -DCPACK_TYPE=Ubuntu16 -DCMAKE_BUILD_TYPE=Debug /opt/accel-ppp-code
make
make install

В /etc/sysctl.conf добавим параметры, которыми укажем где хранить core файлы и что в имени нужно указывать имя программы и номер pid:

kernel.core_uses_pid=1
kernel.core_pattern=/root/core-%e-%p

Применим изменения:

sysctl -p

Отключим лимит на размер core файлов:

ulimit -c unlimited

Чтобы не сбросилось после перезапуска системы, добавим в /etc/security/limits.conf:

* soft core unlimited

Теперь для теста можно создать файл с кодом в котором есть ошибка:

int main() {
  *(char *)0 = 0;
  return 0;
}

Компилируем:

gcc file.c

Выполняем:

./a.out

Убедится что есть ошибка segfault в dmesg:

dmesg -T

Также убедимся что в директории /root/ создался файл core-…
Теперь, аналогично при падении accel-ppp создастся core файл.

Если core файлы пустые, то нужно запустить accel-ppp в GDB:

apt install gdb
gdb --args /usr/sbin/accel-pppd -p /var/run/accel-pppd.pid -c /etc/accel-ppp.conf
run

Если запускать в GDB, то нужно обязательно выключить ротацию логов, иначе после ротаций нужно постоянно набирать «continue».
При необходимости я очищал логи так:

echo "" > /var/log/accel-ppp/emerg.log
echo "" > /var/log/accel-ppp/auth-fail.log
echo "" > /var/log/accel-ppp/accel-ppp.log

Чтобы не держать открытым терминал с GDB, запустим его в screen, чтобы можно было отключится от сервера и потом вернуться к открытому окну, например создадим окно с именем «accel»:

screen -S accel
gdb --args /usr/sbin/accel-pppd -p /var/run/accel-pppd.pid -c /etc/accel-ppp.conf
run

Чтобы отключиться от окна нажмем клавиши Ctrl+A D, а чтобы подключиться наберем команду:

screen -r accel

Если accel-ppp упал, то для просмотра более детальной информации выполним команды:

bt full
generate-core-file

В конфигурации accel-ppp также можно включить ведение более детальных логов, например:

[radius]
verbose=1
interim-verbose=1
[ipoe]
verbose=1
[shaper]
verbose=1
[pppd-compat]
verbose=1
[log]
level=5
log-debug=/var/log/accel-ppp/debug.log

Смотрите мои статьи:
Установка и использование Screen
Как обновить accel-ppp

Оставьте комментарий

Добавить комментарий