сервер движения не запускается

сервер движения не запускается

У меня есть веб-сервер с motion v 4.0, но motion не запускается при загрузке, мне приходится каждый раз задавать ему команду запускаться, и sudo motion -bтогда все отлично, пока мне не нужно перезагрузиться. Я пробовал редактировать файлы конфигурации, /etc/motion/motion.confи /etc/defualt/motion

включить переменную: start_motion_daemon=yes которая должна запускать процесс при загрузке?

но процесс никогда не запускается, когда я пытаюсь его проверить. Я пробовал настроить rc.local, но, похоже, Ubuntu больше этого не делает?

Я попробовал включить службу с помощью systemctl:

sudo systemctl enable motion
motion.service is not a native service, redirecting to systemd-sysv-install.
Executing: /lib/systemd/systemd-sysv-install enable motion

но служба так и не включается и даже не включается. поэтому я посмотрел в журналах:

[1:ml1] [NTC] [VID] [Jun 16 07:26:10] v4l2_get_capability: - VIDEO_CAPTURE
[1:ml1] [NTC] [VID] [Jun 16 07:26:10] v4l2_get_capability: - STREAMING
[1:ml1] [NTC] [VID] [Jun 16 07:26:10] v4l2_select_input: name = "Camera 1", type 0x00000002, status 00000000
[0:web_control] [NTC] [STR] [Jun 16 07:26:10] http_bindsock: error binding on 127.0.0.1 port 8080
[1:ml1] [NTC] [VID] [Jun 16 07:26:10] v4l2_select_input: - CAMERA
[0:web_control] [NTC] [STR] [Jun 16 07:26:10] motion_web_control: motion-httpd thread exit
[1:ml1] [ERR] [VID] [Jun 16 07:26:10] v4l2_select_input: Error selecting input 0 VIDIOC_S_INPUT: Device or resource busy
[1:ml1] [NTC] [VID] [Jun 16 07:26:10] vid_v4lx_start: Using V4L1
[1:ml1] [NTC] [ALL] [Jun 16 07:26:10] image_ring_resize: Resizing pre_capture buffer to 1 items
[1:ml1] [ERR] [ALL] [Jun 16 07:26:20] motion_init: Error capturing first image
[1:ml1] [NTC] [STR] [Jun 16 07:26:20] http_bindsock: error binding on any IPv4 address port 8081
[1:ml1] [ERR] [ALL] [Jun 16 07:26:20] motion_init: Problem enabling motion-stream server in port 8081: Address already in use
[1:ml1] [NTC] [ALL] [Jun 16 07:26:20] motion_loop: Thread exiting
[1:ml1] [NTC] [VID] [Jun 16 07:26:20] vid_close: Closing video device /dev/video0
[0:motion] [NTC] [ALL] [Jun 16 07:26:21] main: Motion thread 1 restart
[1:ml1] [NTC] [ALL] [Jun 16 07:26:21] motion_init: Camera 0 started: motion detection Enabled
[1:ml1] [NTC] [VID] [Jun 16 07:26:21] vid_v4lx_start: Using videodevice /dev/video0 and input -1
[1:ml1] [NTC] [VID] [Jun 16 07:26:21] v4l2_get_capability: 
------------------------
cap.driver: "uvcvideo"
cap.card: "HD Webcam C615"
cap.bus_info: "usb-ff540000.usb-1.1"
cap.capabilities=0x84200001
------------------------
[1:ml1] [NTC] [VID] [Jun 16 07:26:21] v4l2_get_capability: - VIDEO_CAPTURE
[1:ml1] [NTC] [VID] [Jun 16 07:26:21] v4l2_get_capability: - STREAMING
[1:ml1] [NTC] [VID] [Jun 16 07:26:21] v4l2_select_input: name = "Camera 1", type 0x00000002, status 00000000
[1:ml1] [NTC] [VID] [Jun 16 07:26:21] v4l2_select_input: - CAMERA
[1:ml1] [ERR] [VID] [Jun 16 07:26:21] v4l2_select_input: Error selecting input 0 VIDIOC_S_INPUT: Device or resource busy
[1:ml1] [NTC] [VID] [Jun 16 07:26:21] vid_v4lx_start: Using V4L1
[1:ml1] [NTC] [ALL] [Jun 16 07:26:21] image_ring_resize: Resizing pre_capture buffer to 1 items
(END)

Читая логи, я бы подумал, что процесс запущен, но это не так.

По предложению я попробовал настроить задание cron, запустить его sudo crontab -e и добавить строку @reboot/usr/bin/motion -b

но при перезагрузке демон движения все еще не работает..

Я просто хочу узнать современный способ запуска этого процесса при загрузке. Ubuntu 18.04, LXDE.

решение1

вы можете использовать cron @reboot

sudo crontab -e

и добавьте строку

@reboot   /path/to/bin/motion -b

решение2

Сначала попробуйте запустить его вручную с помощью sudo -u motion motion. Если это сработает, то проблема вызвана systemd.

Это нелогично, но при использовании systemd вам следует запустить daemon offmotion.conf.

PS: Файл /etc/defualt/motion, вероятно, не нужен в Ubuntu/Debian.

Связанный контент