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