Page 1 of 1
Debugging write problems
Posted: Mon Dec 10, 2018 7:39 am
by zmeggyesi
Hi,
After a recent upgrade to 1.32.2 (built from source, via packpack, on Raspbian), I've found that ZoneMinder is no longer storing detected images to an external drive.
Previously, on 1.31.1, storing worked perfectly well, and I can see the diagnostic images updating in real time, but event directories are not being created. Log shows no errors, nor any relevant warning.
Can anyone help me on how I can debug the issue?
Re: Debugging write problems
Posted: Tue Dec 11, 2018 5:52 am
by security_dude
Try updating to 1.32.3
Re: Debugging write problems
Posted: Tue Dec 11, 2018 2:23 pm
by zmeggyesi
Well, kind of the obvious thing to do, though not sure why writing would be broken in the first place...
Running the build will take some time, but once the server is back up, I'll see if it works.
If it doesn't, any ideas on how I could try to get to the bottom of it? It doesn't look like a *nix permissions issue, as the various directories on the external drive are all owned by the www-data user.
Re: Debugging write problems
Posted: Tue Dec 11, 2018 2:35 pm
by iconnor
Turn on debug and see what is happening?
Re: Debugging write problems
Posted: Tue Dec 11, 2018 2:41 pm
by zmeggyesi
Tried that - at debug level 9, with no module restrictions, nothing mentioned any failures. The external drive itself was only referenced when the analysis daemon launched, and never again.
Re: Debugging write problems
Posted: Wed Dec 12, 2018 8:24 am
by zmeggyesi
I've updated to 1.32.3, but writes were not fixed, although new log files now appeared. In particular, one of the analysis daemon logs had this line:
Code: Select all
12/12/18 07:10:03.278685 zma_m6[1224].ERR-zm_event.cpp/180 [Can't mkdir /8127: Permission denied]
which is both surprising and not: on the one hand, it's hardly surprising that a write to the root file system would be denied; but it
is surprising that ZM tries to write to the root FS in the first place.
In the storage configurations, I'm looking at a scheme of SHALLOW, a fully specified path of /mnt/external, so I'm guessing this is intended to be concatenated?
Re: Debugging write problems
Posted: Fri Dec 14, 2018 7:43 am
by zmeggyesi
Does anyone have any ideas on how I could debug this further? I'm kind of at a loss as to why ZM would be attempting to write to the root dir...
Re: Debugging write problems
Posted: Fri Dec 14, 2018 1:51 pm
by iconnor
First off, don't use shallow, it is there for legacy reasons,or some weird special case. Switch to medium which is what most people are using, and hence has the most testing.
I will go take a look at the shallow code and see if I can see a bug.
Re: Debugging write problems
Posted: Fri Dec 14, 2018 1:56 pm
by iconnor
Dang it yeah. Shallow is no good. Fixed in master now. Switch to Either Medium or Deep and you will be ok.
Re: Debugging write problems
Posted: Sat Dec 15, 2018 1:42 pm
by zmeggyesi
Just ran the build with your fix from master, and it seems to have worked, I'm seeing images come up in the right place.
There still seems to be something off in how filters handle paths during compression-upload, but I don't have anything specific on that front yet.
Re: Debugging write problems
Posted: Fri May 24, 2019 1:20 pm
by bbarnett
Just got hit with this.
I've recently upgraded from 1.25 to 1.32.3.. and had a lot of events / monitors using Shallow. I don't care too much about moving historical events from Shallow to Medium, except that some cameras do have a lot of historical data... and Medium is better for this.
So.. I wrote this bash script. Feel free to package it / provide it as a user script in src, or what not.. consider it released under "I'm immune to you suing me, but you can do whatever you want with it" license.
Code: Select all
#!/bin/bash
# NOTE: this script is hacky.. I slapped it together for my own use...
# it does check quite a few things.. but will destroy your house, ruin your
# bread maker, and scare your cat... if you use it without care!
# steps to not feel horrible regret
# DO cp -a your entire monitor dir first. EG...
#
# cd /where/i/keep/events/; cp -a <monitor_id> <tempdir>
# cd <tempdir>
# .. run script ..
# if all seems OK
# cd /where/i/keep/events/; mv <monitor_id> <monitor_id>.orig
# mv <tempdir> <monitor_id>
# DO SQL STUFF LISTED BELOW
# .. test .. can you view events? is all OK? then rm <monitor_id>.orig
#
# # # DO NOT FEEL HORRIBLE REGRET .. DO THE ABOVE! # # #
# after you run this successfully, you'll want to go into the DB, and modify these same
# events so that they are not Scheme=Shallow, but Medium...
# eg "update Events set Scheme='Medium' where Scheme='Shallow' and monitorid=<your monitor id>;"
# (why don't I do this in this script? because it's one SQL when done, and plus I'm lazy)
# Next.. this takes time. I don't care. I don't care if you care. I care about it working,
# or freaking out and aborting if it isn't. Because any other method means MORE time, if it
# doesn't have sufficient checking, and borks!
# Uh.. last next. Not tested on anything other than Debian, with a GNU userland..
# it'll surely break (date I think alone is different on MacOS?) elsewhere, but at
# least there is a lot of debug/testing available...
# oh.. right...
# If in the past, you moved/copied/messed with your event directories, for example
# you did a cp of <monitor_id> dir without -a, or -p / --preserve times_and_such,
# this this script will be angry, and refuse to work. And it'll be because you
# didn't do your work, now did you?
#
# Instead, you slacked off, didn't 'man cp', and think about saving such
# Important Things as Timestamps.. as if when things happened was utterly and
# completely unimportant Henry... uh, I mean.. not Henry but anyone else.
#
#
# DEBUG to start! Once happy, remove this..
debug=echo
# no debug
#debug=""
# chown command for zoneminder access
permcom="chown www-data:www-data"
# if you don't want to chown... I'll still touch your stuff
#permcom="touch"
function out() {
if [ "$debug" != "" ]; then
echo $lineout
fi
return
}
# mysql user
mysqluser=root
# your mysql pass (if required)
export MYSQL_PWD=""
# must be numeric value of monitor
monitor=6
testfile=001-capture.jpg
db=zm
query="Events where MonitorId=$monitor and Scheme='Shallow'";
count=$(echo "select count(id) from $query" | mysql -N $db)
if [ $? -ne 0 ]; then
echo "mysql seemed to bork.. perms problem? Exiting.."
exit 1
fi
echo "Detected $count events to work with..."
echo "select id, date(StartTime) from $query" | mysql -N $db -u$mysqluser | while read id startdate; do
echo "id=$id and startdate=$startdate"
if [ -d $id ] && [ -x $id ] && [ -w $id ] && [ -r $id ]; then
lineout="Found event dir $id... "; out
if [ -f "$id/$testfile" ]; then
filedate=$(date -r "$id/$testfile" +%Y-%m-%d)
if [ "$filedate" == "$startdate" ]; then
# extra check, mostly for debugging
if [ -e "$startdate" ] && [ ! -d "$startdate" ]; then
echo "$startdate exists and is a non-dir... can't mkdir here!"
exit 1
fi
#
if [ ! -e "$startdate" ]; then
echo "$startdate dir doesn't exist... creating.."
$debug mkdir "$startdate"
if [ $? -ne 0 ]; then
echo "Unable to mkdir $startdate, exiting..."
exit 1
fi
$debug $permcom "$startdate"
fi
$debug mv "$id" "$startdate/"
if [ $? -ne 0 ]; then
echo "Borked on mv $id $startdate/, exiting..."
exit 1
else
echo "mv succeeded!"
fi
else
echo "Dir date does not match ZM DB date.. moving on for safety sake.."
continue
fi
else
echo "Borked"
exit 1
fi
else
echo "Can't find or read/etc $id dir, moving on.."
continue
fi
done
Re: Debugging write problems
Posted: Fri May 24, 2019 1:25 pm
by bbarnett
I might add... lots of codebases have a <contrib> dir...
ZM doesn't seem to have one, but contrib dir / places to upload code can really help a project. So.. suggesting a 'contrib' dir, and if so, go ahead and throw this code there.