| PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here! |
 |
|

09-08-2010, 17:48
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
SC_Trans Stop Problem per php-script
Hallo Boardies,
Ich möchte euch um eure Mithilfe bitten, da ich ein sehr merkwürdiges Problem habe, mit einem Script.
Ich habe ein Webinterface für den SC_Trans und habe 2 Server zu administrieren. Meinen, und noch von einem befreundeten Menschen.
Auf meinem Server ist OpenSuse in der Version 10.3 - 64 bit installiert, und auf dem anderen Server OpenSuse in der Version 11.1 - 64 bit Version.
Auf beiden Servern ist das Script installiert.
Auf beiden Servern ist Save-Mode aus.
Auf beiden Servern lässt sich das Script komplett starten, jedoch nur auf meinem! stoppen, während der andere Server dieses verweigert, heisst, er stoppt das nicht.
Server meiner : Server4You
Server Freund : Strato
Hier der Auszug des Scriptes:
PHP-Code:
$action = getRequestVar('action');
if ($action == "") { unset($action); }
if (isset($action)) { $hostname = $_SERVER['HTTP_HOST']; $path = dirname($_SERVER['PHP_SELF']);
if ($action == "stop") { //if($sc_proc_id != 0){ shell_exec($soundbase."/sc_trans stop"); //} //else { //echo "SC_TRANS_LINUX killed"; header('Location: http://'.$hostname.($path == '/' ? '' : $path).'/index.php'); //} } elseif($action == "restart") { shell_exec($soundbase."/sc_trans stop"); shell_exec($soundbase."/sc_trans start"); header('Location: http://'.$hostname.($path == '/' ? '' : $path).'/index.php'); } elseif($action == "reload") { $sc_proc_id = shell_exec("ps -A | grep sc_trans_linux | cut -c 0-6;"); shell_exec("kill -s USR1 ".$sc_proc_id); //header('Location: http://'.$hostname.($path == '/' ? '' : $path).'/index.php'); } elseif($action == "next") { $sc_proc_id = shell_exec("ps -A | grep sc_trans_linux | cut -c 0-6;"); shell_exec("kill -s WINCH ".$sc_proc_id); //header('Location: http://'.$hostname.($path == '/' ? '' : $path).'/index.php'); } elseif($action == "start") { $file = $soundbase."/sc_trans.conf"; $filehandle = fopen ($file, "r+"); $contents = fread($filehandle, filesize($file)); fclose($filehandle); $pos = strpos($contents, "LogFile=") ; $contents = substr($contents, $pos+8); $Logfile = strtok($contents, "\n"); if($sc_proc_id == 0){ shell_exec("rm ".$soundbase."/".$Logfile); shell_exec("touch ".$soundbase."/".$Logfile); shell_exec($soundbase."/sc_trans start"); } header('Location: http://'.$hostname.($path == '/' ? '' : $path).'/index.php'); } elseif($action == "config") { echo (' <SCRIPT LANGUAGE="javascript"> window.open ("editconf.php") </SCRIPT> '); header('Location: http://'.$hostname.($path == '/' ? '' : $path).'/index.php'); } }
Das steht in der Bash :
PHP-Code:
#!/bin/bash #!/usr/bin/php -q # To start the script automatically at bootup type the following command # update-rc.d sc_trans defaults 99
USER=rt MYDIR=`dirname $0`/
case $1 in start) #display to user that what is being started echo “Starting sc_trans_linux” #start the process and record record it’s pid cd $MYDIR ; screen -AmdS stream ./sc_trans_linux; sleep 2 ps -A | grep sc_trans_linux | cut -c 0-6 > /var/run/sctrans.pid #output failure or success #info on how to interact with the torrent #echo “To interact with the torrent client” #echo “screen -r torrent” if [[ $? -eq 0 ]]; then echo “The process started successfully” else echo “The process failed to start” fi ;;
stop) #First we want to kill the original servers, so we don't get errors. echo "Killing old shoutcast streams." for oldpid in `ps -A | grep sc_trans_linux | cut -c 0-6`; do kill -9 $oldpid done rm -f $pid ;;
*) # show the options echo “Usage: {start|stop}” exit 1 ;; esac exit 0
Beide Server haben die selben Rechte, und wie geschrieben auf meinem Server funktioniert das einwandfrei, auf dem anderen nicht.
Ich würde mich Freuen, wenn ihr mir helfen könntet
Geändert von gsc2010 (09-08-2010 um 18:32 Uhr)
|

09-08-2010, 18:10
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Hallo,
auf unterschiedlichen Servern kann es schon mal unterschiedliche Sicherheitsrichtlinien geben. Wie ist denn dein Error-Reporting eingestellt? Wenn keine Fehlermeldungen kommen, aufdrehen. Wenn schon welche kamen, bitte genauen Wortlaut posten.
Gruß,
Amica
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

09-08-2010, 18:28
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
Error-LOG
Kann den Error-Log erst morgen schreiben,da zur Zeit der Server abgefeuert ist, Dämliches Strato ...
Würde mich freuen, wenn Ihr mir helfen könntet.
Frage:
kann es auch am Script liegen, obwohl wenn Fehler drin wären, würde es bei mir nicht laufen
|

09-08-2010, 20:54
|
TobiaZ
 Moderator
|
|
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.188
|
|
Zitat:
|
kann es auch am Script liegen, obwohl wenn Fehler drin wären, würde es bei mir nicht laufen
|
Naja, fehler heißt ja nicht gleich "Parseerror", also tuts oder tuts nicht. Fehler kann auch bedeuten: tuts unter bestimmten Umständen (nicht).
Debuging ist weiterhin angesagt, zur Not müssen wir bis morgen warten.
|

11-08-2010, 20:37
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
Error Report laut Apache
Nachdem ich nun 2 Tage selbst arbeiten war, kann ich erst heute den log senden... Das steht in der Apache - LOG - Datei:
PHP-Code:
rm: cannot remove `/srv/www/vhosts/domainname.de/subdomains/ autostream/httpdocs/webtrans/sc_trans_040/sc_trans.log': Operation not permitted cut: fields and positions are numbered from 1
|

11-08-2010, 20:53
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Warum machst du eigentlich alles so umständlich über Shell-Befehle und nutzt nicht einfach die Dateifunktionen von PHP?
PHP: unlink - Manual
PHP: Dateisystem - Manual
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

12-08-2010, 06:22
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
Wenn ich Dich richtig verstehe, kann ich einfach den Stop Befehl durch unlink auslösen, und der Auto-DJ würde stoppen ???
Könntest du mir da einen kleinen Anstoss geben ?
Ich würde es dann so machen:
Klick auf Stop und das Script "löscht" die $pid und würde stehen bleiben .
Habe ich das richtig verstanden ?
Und wen ja,
kannst du bitte einen Ansatz des Befehls mir als Anfang hier posten ?
Melde mich heute abend wieder, bin erst mal wieder arbeiten...
PS.:
Wenn das alles fertig ist, würde ich das Script hier sogar einstellen wollen...
Danke
|

12-08-2010, 08:53
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Zitat:
Zitat von gsc2010
Wenn ich Dich richtig verstehe, kann ich einfach den Stop Befehl durch unlink auslösen, und der Auto-DJ würde stoppen ???
|
Das glaube ich weniger, aber mit unlink() kannst du schon mal eine Datei löschen (statt mit rm), mit touch() einen Zeitstempel setzen und mit posix_kill() kannst du einem Prozess ein Signal schicken. Für ps auf der Shell dagegen kenne ich keine PHP-Funktion, die das ersetzen würde, auch das Starten und Stoppen kannst du so lassen.
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
Geändert von AmicaNoctis (12-08-2010 um 08:56 Uhr)
|

12-08-2010, 21:49
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
Käme ich mit dem nachfolgenden weiter ?
PHP-Code:
if($sc_proc_id == 0){
#shell_exec("rm ".$soundbase."/".$Logfile);
#shell_exec("touch ".$soundbase."/".$Logfile);
#### Stop-Befehl
shell_exec(posix_kill($pid, 9););
unlink(.$soundbase."/".$Logfile);
#### Ende
shell_exec($soundbase."/sc_trans start");
}
LG
Frank
|

12-08-2010, 22:23
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Falsch:
PHP-Code:
shell_exec(posix_kill($pid, 9);); // es ergibt keinen Sinn, die Rückgabe von posix_kill auf der Shell auszufüren // und es ist ein Semikolon zuviel
unlink(.$soundbase."/".$Logfile); // der Punkt am Anfang hat links keine Zeichenkette, die er verknüpfen könnte
Richtig (zumindest erstmal syntaktisch):
PHP-Code:
posix_kill($pid, 9); unlink($soundbase."/".$Logfile);
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
Geändert von AmicaNoctis (12-08-2010 um 22:25 Uhr)
|

12-08-2010, 22:27
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
PHP-Code:
posix_kill($pid, 9);
unlink($soundbase."/".$Logfile);
Braucht man beim ersten Befehl kein EXEC ???
|

12-08-2010, 22:29
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Zitat:
Zitat von gsc2010
Braucht man beim ersten Befehl kein EXEC ???
|
Nein, das wäre genauso als würde man
PHP-Code:
echo print_r($array);
schreiben
posix_kill
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

12-08-2010, 22:30
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
gebe gleich dazu Output, ob das geht
|

12-08-2010, 22:47
|
|
gsc2010
Registrierter Benutzer
|
|
Registriert seit: Jun 2010
Beiträge: 23
|
|
Also, das funktioniert nicht...
Ich stelle mir nun die ernsthafte Frage, warum das so unterschiedlich ist, bei den Distri´s ...
bei meinem "suse" Servder läuft das Script,ohne unlink und dem Posix BEfehl, und der andere macht gar nichts...
Also Stoppen...
Kann doch nicht sein oder
|

13-08-2010, 01:03
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Zitat:
Zitat von gsc2010
und der andere macht gar nichts...
|
Vermutlich gibt entweder PHP oder die Shell eine Fehlermeldung (fehlende Rechte) zurück, die du aber nicht ausliest. Darauf wurdest du aber in diesem Thread bereits hingewiesen.
Auf die wahrscheinlichste Ursache auch:
Zitat:
Zitat von AmicaNoctis
auf unterschiedlichen Servern kann es schon mal unterschiedliche Sicherheitsrichtlinien geben.
|
Stichwort: Safe Mode
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
|
| Themen-Optionen |
|
|
| Thema bewerten |
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
|
PHP News
|