Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Zoneminder container starts with state STOPPED #43

Open
tokenize47 opened this issue Feb 22, 2023 · 20 comments
Open

Zoneminder container starts with state STOPPED #43

tokenize47 opened this issue Feb 22, 2023 · 20 comments

Comments

@tokenize47
Copy link

tokenize47 commented Feb 22, 2023

There's this errors in the logs:

[zoneminder-service] 2023-02-22 14:15:02.989250625 INFO Starting ZoneMinder...
[zoneminder] 2023-02-22 14:15:11.184118221 local1.err: Feb 22 14:15:11 zmdc[922]: FAT [Can't connect to zmdc.pl server process at /zoneminder/run/zmdc.sock: No such file or directory]
[zoneminder] 2023-02-22 14:15:11.186904572 local1.err: Feb 22 14:15:11 zmpkg[916]: ERR [Unable to run "/usr/bin/zmdc.pl startup", output is "Starting server", status is 255]
[zoneminder] 2023-02-22 14:15:11.240608636 local1.err: Feb 22 14:15:11 zmpkg[916]: ERR [Unable to run "/usr/bin/zmdc.pl start zmfilter.pl --filter_id=1 --daemon", output is "Unable to connect to server using socket at /zoneminder/run/zmdc.sock", status is 255]
[zoneminder] 2023-02-22 14:15:11.292992424 local1.err: Feb 22 14:15:11 zmpkg[916]: ERR [Unable to run "/usr/bin/zmdc.pl start zmfilter.pl --filter_id=2 --daemon", output is "Unable to connect to server using socket at /zoneminder/run/zmdc.sock", status is 255]
[zoneminder] 2023-02-22 14:15:11.345458692 local1.err: Feb 22 14:15:11 zmpkg[916]: ERR [Unable to run "/usr/bin/zmdc.pl start zmwatch.pl", output is "Unable to connect to server using socket at /zoneminder/run/zmdc.sock", status is 255]
[zoneminder] 2023-02-22 14:15:11.397436936 local1.err: Feb 22 14:15:11 zmpkg[916]: ERR [Unable to run "/usr/bin/zmdc.pl start zmupdate.pl -c", output is "Unable to connect to server using socket at /zoneminder/run/zmdc.sock", status is 255]
[zoneminder] 2023-02-22 14:15:11.449087879 local1.err: Feb 22 14:15:11 zmpkg[916]: ERR [Unable to run "/usr/bin/zmdc.pl start zmtelemetry.pl", output is "Unable to connect to server using socket at /zoneminder/run/zmdc.sock", status is 255]
[zoneminder] 2023-02-22 14:15:11.501916608 local1.err: Feb 22 14:15:11 zmpkg[916]: ERR [Unable to run "/usr/bin/zmdc.pl start zmstats.pl", output is "Unable to connect to server using socket at /zoneminder/run/zmdc.sock", status is 255]
[zoneminder-service] 2023-02-22 14:15:11.506256361 INFO ZoneMinder is up! Proceeding to monitoring.

If I exec into the container and run zmpkg.pl start manually, it will then start.

@clueo8
Copy link

clueo8 commented Feb 24, 2023

I am noticing this too... Is the zmpkg.pl start missing from the /init when the container starts?

@tokenize47
Copy link
Author

tokenize47 commented Feb 24, 2023

I am noticing this too... Is the zmpkg.pl start missing from the /init when the container starts?

No, it's not missing. The error messages comes precisely from executing "zmpkg.pl start" in the s6 init

I've done alot of debug and I really can't understand why this happens.

@alexyao2015
Copy link
Member

Can you provide some more info such as os, docker compose files, env file, etc?

@clueo8
Copy link

clueo8 commented Feb 24, 2023

The only changes I made from the initial git clone was just the timezone and exposed port:

.env:
+TZ=America/New_York

docker-compose.yml:
+9086:80

Also, my base server is x86_64 Linux 6.1.13-1-lts... I use arch btw :)

Docker version 23.0.1, build a5ee5b1dfc
Docker Compose version 2.16.0

@alexyao2015
Copy link
Member

Honestly none of that info gives me enough information to reproduce what exactly you did and if that's unable to be done, there's no way of determining the cause other than pure speculation. As you can see, the image boots up just fine in CI and I believe many others use it without any issues. I would have to believe you must be doing something special or out of the ordinary to cause this issue.

@tokenize47
Copy link
Author

I think this is an issue related with Arch, as I'm running it as well. I tried running it on Debian and it worked.
I really don't understand what's causing this.

@kubax
Copy link

kubax commented Mar 4, 2023

+1

also on arch, and the problems seems to come from one of the updates of the last month(s). Zoneminder runned perfectly for months, then i recently installed long waited updates ( my internet was realy bad up until two days ago, so i didn't realy update often) and then it stoped working.

at least i have a work around, thanks to @tokenize47 because of the post on the zoneminder forum i found prior to this issue here.

@kubax
Copy link

kubax commented Mar 7, 2023

The problem seems to only happen with Docker 23.0.1.

Docker 20.10.23 seem to work fine. So i think it will be something that has changed from docker 20.10.23 to docker 23.0.1.

Downgrading to docker 20.10.23 and rebooting (somehow restarting the service is not enough) and zoneminder is running normaly.

@tokenize47
Copy link
Author

That's a nice clue! Then the problem is not with Arch itself but the fact that Arch uses always the latest software versions.

I guess this is an incompatibility with the s6 version with the new docker version. I'll do some research on this an come up with a PR if I find a solution.

@clueo8
Copy link

clueo8 commented Apr 15, 2023

Any updates on this?

@kubax
Copy link

kubax commented Jul 16, 2023

Problem persists with Docker 24.0.2

i have no clue how this problem could be solved.

@Simpler1
Copy link
Contributor

This could be the same problem as:
#50

Try upgrading from "docker-compose" to "docker compose".

@kubax
Copy link

kubax commented Jul 16, 2023

Thanks for the hint.

But I don't think it is related (at least in my case).

I deploy with portainer, to a 3 cluster docker swarm (although this stack is locked to my NAS because of the hard drives)

@kondas
Copy link

kondas commented Sep 28, 2023

Hi all, I think the issue is caused by insufficent linux capabilities - changing the user running 'zmpkg.pl start' from www-data to root allows the socket to open (in /etc/services.d/zoneminder/run).

@kubax
Copy link

kubax commented Sep 28, 2023

can confirm.

as a quick test i updated to docker 24.0.5 and replaced the file inside the container with one where www-run is replaced with root.

Zoneminder starts without problems now. so at least we now know why it allways starts stopped.

thx for the update @kondas

@gurka
Copy link

gurka commented Jul 14, 2024

This issue appeared for me a few days ago, when I upgraded from docker 26.x to docker 27.0.3.
I haven't tried the change from www-data to root yet as I don't want to it to run as root... will try to investigate what the root issue is.

@kreksoverzum
Copy link

Had fine working setup in docker on ubuntu 24.04.
But after moving to manjaro (arch based distro) i have slammed into the exactly same issue.
Docker version 27.2.1
Changing www-data to root in /etc/services.d/zoneminder/run helped

@gurka
Copy link

gurka commented Nov 30, 2024

https://github.com/ZoneMinder/zoneminder/blob/52c41d166b7537e81c3ce14b48e0add5aa09991c/scripts/zmdc.pl.in#L273

On Debian 12, without changing www-data to root as described in previous comments, POSIX::sysconf(&POSIX::_SC_OPEN_MAX) returns 1048576
On Debian 13, without changing www-data to root, POSIX::sysconf(&POSIX::_SC_OPEN_MAX) returns 1073741816
On Debian 13, with changing www-data to root, POSIX::sysconf(&POSIX::_SC_OPEN_MAX) returns 1024

I think that the problem is that it takes too long time for that loop to execute when the value is 1073741816, and that causes it to timeout and fail here: https://github.com/ZoneMinder/zoneminder/blob/52c41d166b7537e81c3ce14b48e0add5aa09991c/scripts/zmdc.pl.in#L202

What I don't understand is, where are those values being set? Why does www-data have such a large value while root only has 1024?

This could be related: moby/moby#44547

@connortechnology
Copy link

Interesting, great diagnosis. I am tempted to just use 1024 instead of SC_OPEN_MAX. We know we only have a few fds open. We are mainly concerned with STDIN/OUT/ERR.

@gurka
Copy link

gurka commented Nov 30, 2024

That might be enough to fix it, yeah. There are a few more places where it iterates over all possible FDs: https://github.com/search?q=repo%3AZoneMinder%2Fzoneminder+_SC_OPEN_MAX&type=code

I still would like to figure out why it returns 1024 when changing www-data to root in /etc/services.d/zoneminder/run. If I run sysctl fs.nr_open inside the container it returns 1073741816 regardless of if I run it as root or www-data...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

9 participants