chrisfah
Goto Top

Cron mkdir und chmod Problem

Problem mit mkdir und chmod in einem cronjob: No such file or directory in /var/www/vhosts/domain.tld/httpdocs/cron_fcam03.php on line xx

Hallo,
wieder einmal brauch eich eure Hilfe !!!

Auf einem VServer (Hosteurope) unter Centos6 mit Plesk 11 werden von einer Kamera regelmäßig Bilder auf den Server gespeichert. Diese Bilder können sich Leute mit Berechtigung in einer Übersicht als Thumbnails anschauen.
Nun dauert aber das Erzeugen der Thumbnails einige Zeit, sodaß es durchaus bei Berechnung während der Anfrage zu längeren Wartezeiten oder timeouts kommen kann. Daher wollte ich ein Script per cron alle 10 Minuten laufen lassen.
Soweit so gut, manuell aufgerufen klappt das Script perfekt, leider als cronjob harkt es und ich weiss nicht mehr weiter:
Aufruf über "php /var/www/vhosts/domain.tld/httpdocs/cron_fcam03.php" (in Plesk 11 klappt das nur per Zugang zum Server via SSH: bin/bash) bekomme ich per Email(zum testen!) die Fehlermeldung:
PHP Warning:  mkdir(): No such file or directory in /var/www/vhosts/f-cam.at/httpdocs/cron_fcam03.php on line 38 PHP Warning:  chmod(): No such file or directory in /var/www/vhosts/f-cam.at/httpdocs/cron_fcam03.php on line 39 PHP Warning:  mkdir(): No such file or directory in /var/www/vhosts/f-cam.at/httpdocs/cron_fcam03.php on line 42 PHP Warning:  chmod(): No such file or directory in /var/www/vhosts/f-cam.at/httpdocs/cron_fcam03.php on line 43
Die Verzeichnisse stimmen aber, auch die Berechtigungen passen (0755). Scheint also, daß die Befehle mkdir und chmod nicht zugänglich sind.

Das PHP Script sieht so aus:
<?php
// CRONJOB BUILDING THUMBS EVERY 10 MINUTES

// set cam to be supported
$baustellen = array('fahrnercam03');  
$thumb_width = 200;
$thumb_height = 150;
$thumb_quality = 75;

date_default_timezone_set('Europe/Berlin');  
function create_thumb($source='', $destination='', $width=200, $height=150, $quality=75) {  
	// create thumbnail pic and store it in  destination file
	if (!$source) die ('<b>EROR CREATING THUMBNAIL:</b> No source file given.');  
	if (!$destination) die ('<b>EROR CREATING THUMBNAIL:</b> No destination path given.');  

	$size = getimagesize($source);	// get orig size and filetype 
	if ($size[2] == 1) $img = imagecreatefromgif($source);	// image is a gif
	if ($size[2] == 2) $img = imagecreatefromjpeg($source);	// image is a jpg
	$new_img = imagecreatetruecolor($width, $height);
	imagecopyresampled($new_img, $img, 0, 0, 0, 0, (int)$width, (int)$height, $size, $size[1]);
	imagedestroy($img);
	$result = imagejpeg($new_img, $destination, (int)$quality);
	imagedestroy($new_img);
	if ($result)  return true; 
	return false;
}

define ('DIR_FS', $_SERVER['DOCUMENT_ROOT'].'/'); // define base dir. It is the directory in which this file is located  
//$date = ($_GET['date']) ? trim($_GET['date']): date(Y-m-d) ;  
$date = '2013-04-08';  // zum testen  

$baustelle = $baustellen;
$camdir = DIR_FS.$baustelle.'/archiv/';  
$sourcedir = $camdir.$date;
$thumbsdir = $sourcedir.'/thumbs';  

// prüfe ob ordner FS/baustelle/archiv/datum existiert
if (!is_dir($sourcedir))  mkdir($sourcedir, 0755);
if (!is_writable($sourcedir)) chmod($sourcedir, 0755);

// prüfe ob ordner FS/baustelle/archiv/datum/thumbs existiert
if (!is_dir($thumbsdir))  mkdir($thumbsdir, 0755);
if (!is_writable($thumbsdir)) chmod($thumbsdir, 0755);

$pics = glob($sourcedir.'/'.'*.jpg'); // lese pics ein  

if ($pics) {
	foreach ($pics as $k => $orig_pic) {
		$pic = str_ireplace($sourcedir.'/', '', $orig_pic);  
		if (!file_exists($thumbsdir.'/'.$pic))  create_thumb($orig_pic, $thumbsdir.'/'.$pic, $thumb_width, $thumb_height, $thumb_quality);  
	}
}
?>
Wie gesagt, per Browser aufgerufen (domain.tld/cronjob.php) lauft es perfekt, als cronljob gibt es obige Fehlermeldung, und den Job macht keiner....

Hat jemand eine Idee woranes liegt?

Lg, Chris

Content-Key: 204660

Url: https://administrator.de/contentid/204660

Printed on: April 25, 2024 at 16:04 o'clock

Member: ChrisFah
ChrisFah Apr 09, 2013 at 00:56:32 (UTC)
Goto Top
Sorry für die vorschnelle Anfrage !!!!

Habe das Problem mit wget -q http://domain.tld/cronjob.php gelöst.

Lg, Chris
Member: kontext
kontext Apr 09, 2013 at 05:42:58 (UTC)
Goto Top
Zitat von @ChrisFah:
Habe das Problem mit wget -q http://domain.tld/cronjob.php gelöst.
Guten Morgen,

Dann bitte auch noch How can I mark a post as solved? nicht vergessen ...

Lg, Chris
Gruß
@zanko
Member: fnord2000
fnord2000 Apr 09, 2013 at 07:14:25 (UTC)
Goto Top
Auch wenn du dir bereits einen Workaround gebaut hast und das Problem nicht mehr aktuell ist, trotzdem noch meinen Senf dazu:

Ich glaube das Problem liegt in Zeile 28.
Du baust dir deine gesammten Dateinamen aus der Variable $_SERVER['DOCUMENT_ROOT'], das kann nur funktionieren, wenn die Variable auch gesetzt ist.
Beim Aufruf über den Webserver ist wird die Variable auf das Root-Verzeichniss gesetzt, aber nicht wenn du PHP direkt von der Kommandozeile, oder eben per Cron, aufrufst. (Woher soll der PHP-Interpreter auch wissen, wo der Webserver seine Dateien hat).

Verwende einfach fest definierte Pfade und es geht auch mit dem Cron.