0

API RestFul をボトルと python で実行しました。すべて正常に動作します。API はシステムで実行されているデーモンです。コマンド ラインでデーモンを停止すると、サービスは非常にうまく停止し、すべてのポートと接続が閉じられますが、 API を介してサービスを閉じると、ポートは LISTEN 状態でキープ アライブになり、後で TIME_WAIT になります。ポートは解放されません。私は2日間読んだのですが、問題はボトルにソケットがあり、サーバーをうまく閉じられないためですが、彼の解決策を見つけることができます

API をサービスとして閉じるコードは、このように python によって起動されるサブプロセスです。

@get('/v1.0/services/<id_service>/restart')
def restart_service(id_service):
try:
    service = __find_a_specific_service(id_service)
    if(service == None or len(service) < 1):
        logging.warning("RESTful URI: /v1.0/services/<id_service>/restart " +    id_service +" , restart a specific service, service does not exists")
        response.status = utils.CODE_404
        return utils.convert_to_json(utils.FAILURE, utils.create_failed_resource(utils.WARNING, utils.SERVICES_API_SERVICE_NOT_EXIST))
    else:
        if id_service != "API":
            api.ServiceApi().restart(id_service)
        else:
            import subprocess                
            args='/var/lib/stackops-head/bin/apirestd stop; sleep 5; /var/lib/stackops-head/bin/apirestd start'
            subprocess.Popen(args, shell=True)
        logging.info("RESTful URI: /v1.0/services/<id_service>/restart " + id_service +" , restart a specific service, ready to construct json response...")
        return utils.convert_to_json(utils.SERVICE, None)
except Exception, e:
    logging.error("Services: Error during the process of restart a specific service. %r", e)
    raise HTTPError(code=utils.CODE_500, output=e.message, exception=e, traceback=None, head
4

2 に答える 2

1

外部からボトルプロセスを終了するには、SIGINTを送信します。

于 2012-09-25T23:17:14.270 に答える
0

アプリが終了または強制終了されると、ソケットを含むすべてのファイル記述子/ハンドルがOSによって閉じられます。

使用することもできます

sudo netstat -anp --tcp

Linuxでは、指定されたポートが一部のプロセスによって所有されているかどうかを確認します。または使用する

netstat -a -n -b -p tcp

同じことをするためにWindowsで。

TIME_WAITは、接続/ポートをしばらく維持するために、アプリではなくOSによって管理される通常の状態です。時々それは迷惑です。OSを保持する期間を調整することはできますが、安全ではありません。

于 2012-12-14T17:15:50.260 に答える