0

ヘルプデスクが Oracle インスタンスを再起動できるようにするために、Oracle インスタンスを起動するシェル スクリプトを起動する小さな Python Web サーバーを実装しようとしています。

コードが完成し、インスタンスが開始されますが、問題があります。インスタンスは Web サーバーに接続されているため、インスタンスが停止されるまでブラウザーへのバッファーは閉じられずora_pmon_INSTANCE、Web サーバー ポートでリッスンするプロセスが存在します。

私はスクリプトを起動しようとしました:

process = os.system("/home/oracle/scripts/webservice/prueba.sh TFINAN")

process = subprocess.Popen(["/home/oracle/scripts/webservice/prueba.sh", "TFINAN"], shell=False, stdout=subprocess.PIPE)`

しかし、それは同じように起こります。

また、デーモンを使用してスクリプトを起動しようとしました(redhatのinitスクリプトのデーモン機能を使用)。スクリプトは、同じ結果で Oracle インスタンスを開始します。

これは私のコードです:

#!/usr/bin/python

from BaseHTTPServer import BaseHTTPRequestHandler, HTTPServer
from SocketServer import ThreadingMixIn
import threading
import argparse, urlparse
import re
import cgi, sys, time
import os, subprocess

class HTTPRequestHandler(BaseHTTPRequestHandler):

    def do_POST(self):
        self.send_response(403)
        self.send_header('Content-Type', 'text/html')
        self.end_headers()

        return

    def do_GET(self):
        ko = False
        respuesta = ""
        params = {}
        myProc = -1
        parsed_path = urlparse.urlparse(self.path)
        try:
            params = dict([p.split('=') for p in parsed_path[4].split('&')])
        except:
            params = {}

        elif None != re.search('/prueba/*', self.path):
            self.send_response(200)
            respuesta = "Hola Mundo! -->" + str( params['database'] )

        elif None != re.search('/startup/*', self.path):
            self.send_response(200)
            self.send_header('Content-Type', 'text/html')
            self.end_headers()
            cmd = """ <html>
                        <body><H2> Iniciando instancia oracle: """ + str( params["database"]) + '. Espere un momento, por favor ...</H2>'

            self.wfile.write(cmd)

            #process = os.system("/home/oracle/scripts/webservice/prueba.sh INSTANCE")
            process = subprocess.Popen(["/home/oracle/scripts/webservice/prueba.sh", "INSTANCE"], shell=False, stdout=subprocess.PIPE)
            # wait for the process to terminate
            out, err = process.communicate()
            errcode = process.returncode
            if errcode == 0:
                self.wfile.write("""<H1> Instancia iniciada correctamente
                                </H1>
                            </body> </html>""")
                self.wfile.close()
            else:
                respuestaok = "Error inicializando la instancia: " + str( params['database']) + " Intentelo de nuevo pasados unos minutos y si vuelve a fallar escale la incidencia al siguiente nivel de soporte"

        else:
            self.send_response(403, 'Bad Request: pagina no existe')
            respuesta = "Solicitud no autorizada"

        if respuesta != "":
            self.send_response(200)
            self.send_header('Content-Type', 'text/html')
            self.end_headers()
            self.wfile.write(respuesta)
            self.wfile.close()

        if ko:
            server.stop()           

        return


class ThreadedHTTPServer(ThreadingMixIn, HTTPServer):
    allow_reuse_address = True

    def shutdown(self):
        self.socket.close()
        sys.exit(0)

class SimpleHttpServer(object):
    def __init__(self, ip, port):
        self.server = ThreadedHTTPServer((ip,port), HTTPRequestHandler)

    def start(self):
        self.server_thread = threading.Thread(target=self.server.serve_forever)
        self.server_thread.daemon = True
        self.server_thread.start()

    def waitForThread(self):
        self.server_thread.join()

    def stop(self):
        self.server.shutdown()

if __name__=='__main__':
    parser = argparse.ArgumentParser(description='HTTP Server')
    parser.add_argument('port', type=int, help='Listening port for HTTP Server')
    parser.add_argument('ip', help='HTTP Server IP')
    args = parser.parse_args()

    server = SimpleHttpServer(args.ip, args.port)
    print 'HTTP Server Running...........'
    server.start()
    server.waitForThread()

どなたか助けていただけませんか?

4

1 に答える 1

0

あなたの問題は、HTTP サーバーとはあまり関係がありません。Python コードから Oracle デーモンを制御するには、一般的な問題があるようです。

最初に、必要なことを実行する単純な Python スクリプトを作成してみてください。

私の推測では、デーモン制御スクリプトからの出力の読み取りに問題があると思います。

コマンドからの出力の読み取りについては、 Popen.communicate()も参照してください 。他のオプションは、 subprocess.call() を呼び出すことです

Python からシステム コマンドを呼び出すための多くのチュートリアルがあります

純粋にPython関連の問題とは別に、許可に関する問題が発生する可能性があります-スクリプト/ HTTPサーバーを実行しているユーザーがOracle制御スクリプトを呼び出すことが許可されていない場合、別の問題があります(Linuxでそのユーザーをsudoers)。

スクリプトの呼び出しに関する問題を解決したら、HTTP サーバー内でスクリプトを簡単に動作させることができます。

于 2014-04-17T20:00:34.000 に答える