Too many open files¶
Если вам нужна помощь специалиста для решения этой или любой другой проблемы, изучите наши условия технической поддержки.
Описание¶
При большом количестве камер, в районе 128, вы можете столкнуться с ограничениями Inotify, тогда при добавлении камеры в логе сервера можно увидеть сообщение:
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0xe8 pc=0xdda663]
goroutine 1258 [running]:
gitlab.com/yuccastream/yucca/pkg/runner/latest.(*Runner).GetStats(...)
/builds/yuccastream/yucca/pkg/runner/latest/runner.go:327
gitlab.com/yuccastream/yucca/pkg/server/executor/exec.(*Worker).GetStream(0xc002b74500)
/builds/yuccastream/yucca/pkg/server/executor/exec/worker.go:188 +0xa3
gitlab.com/yuccastream/yucca/pkg/server/executor/exec.(*Executor).StatusStream(0xc0003f01c0, 0xc00074b6c0)
/builds/yuccastream/yucca/pkg/server/executor/exec/executor.go:126 +0xb8
gitlab.com/yuccastream/yucca/pkg/server.(*Server).stateWatcher(0xc000c1e000)
/builds/yuccastream/yucca/pkg/server/server.go:914 +0x233
created by gitlab.com/yuccastream/yucca/pkg/server.(*Server).Start in goroutine 1
/builds/yuccastream/yucca/pkg/server/server.go:695 +0x4db
А логе одной из камер:
Error: too many open files
По умолчанию во многих Linux дистрибутивах выставлены следующие параметры:
grep NOFILE /etc/systemd/system.conf
#DefaultLimitNOFILE=1024:524288
Решение¶
Чтобы увеличить лимиты, добавьте в файл /etc/systemd/system.conf
следующие параметры:
DefaultLimitNOFILE=10240:524288
А также увеличить этот параметр для systemd unit yucca.service в файле /lib/systemd/system/yucca.service
:
LimitNOFILE=10240
Затем применить настройки и перезапустить процесс yucca.service :
sudo systemctl daemon-reload
sudo systemctl restart yucca.service