PNG  IHDR;IDATxܻn0K )(pA 7LeG{ §㻢|ذaÆ 6lذaÆ 6lذaÆ 6lom$^yذag5bÆ 6lذaÆ 6lذa{ 6lذaÆ `}HFkm,mӪôô! x|'ܢ˟;E:9&ᶒ}{v]n&6 h_tڠ͵-ҫZ;Z$.Pkž)!o>}leQfJTu іچ\X=8Rن4`Vwl>nG^is"ms$ui?wbs[m6K4O.4%/bC%t Mז -lG6mrz2s%9s@-k9=)kB5\+͂Zsٲ Rn~GRC wIcIn7jJhۛNCS|j08yiHKֶۛkɈ+;SzL/F*\Ԕ#"5m2[S=gnaPeғL lذaÆ 6l^ḵaÆ 6lذaÆ 6lذa; _ذaÆ 6lذaÆ 6lذaÆ RIENDB`  4h^c@sddlZddlZddlZddlZddlZddlZddlZddlmZ ddl m Z ddl m Z ddl m Z ddl mZddlmZddlmZdd lmZmZdd lmZdd lmZdd lmZdd lmZdfdYZdefdYZdfdYZdefdYZdefdYZ defdYZ!de"fdYZ#e#Z#dZ$dS(iN(t asyncore_25(t ProcessStates(tSupervisorStates(tgetProcessStateDescription(tSTOPPED_STATES(tdecode_wait_status(tsigname(tProcessExceptiont BadCommand(tEventListenerStates(tevents(tRestartUnconditionally(t SocketManagert SubprocesscBseZdZdZdZdZdZdZdZ dZ dZ dZ e Ze Ze ZdZdZdZdZdZdZdZdZdZdZdZdZiejej 6ej!ej"6ej#ej$6ej%ej&6ej'ej(6ej)ej*6ej+ej,6ej-ej.6Z/e0dZ1d Z2d Z3d Z4d Z5d Z6dZ7dZ8dZ9dZ:dZ;dZ<dZ=dZ>dZ?dZ@dZAdZBdZCRS(sA class to manage a subprocess.icCs+||_i|_i|_tj|_dS(sDConstructor. Argument is a ProcessConfig instance. N(tconfigt dispatcherstpipesRtSTOPPEDtstate(tselfR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt__init__5s   cCs:x3|jjD]"}t|dr|jqqWdS(Nt removelogs(RtvaluesthasattrR(Rt dispatcher((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR?scCs:x3|jjD]"}t|dr|jqqWdS(Nt reopenlogs(RRRR(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRDscCsPxI|jjD]8}|jr/|jn|jr|jqqWdS(N(RRtreadablethandle_read_eventtwritablethandle_write_event(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pytdrainIs    cCs|j s|jr(ttjdn|jd}|dkrVttjdn|j|}|jrttjdn|j |7_ |j dS(NsProcess already closedtstdinsProcess has no stdin channels Process' stdin channel is closed( tpidtkillingtOSErrorterrnotEPIPERtNoneRtclosedt input_buffertflush(Rtcharststdin_fdR((s6/usr/lib/python2.7/site-packages/supervisor/process.pytwriteTs    c Cseytj|jj}Wn5tk rP}td|jjt|fnX|rd|d}n tdd|kr|}y|jjj|}WqBt k rd}qBXn|jj }d}d}xQ|D]I}t j j||}y|jjj|}Wnt k r!qXPqW|dkr<|}n|}|jjj|||||fS(sInternal: turn a program name into a file name, using $PATH, make sure it exists / is executable, raising a ProcessException if not scan't parse command %r: %siscommand is emptyt/N(tshlextsplitRtcommandt ValueErrorRtstrtoptionststatR"R%tget_pathtostpathtjointcheck_execv_args( Rt commandargstetprogramtfilenametstR6tfoundtdir((s6/usr/lib/python2.7/site-packages/supervisor/process.pytget_execv_argscs:          cCs|j}||krtS|jj|}|dk rY||||}tj|n|tjkrt j }|j d|_ ||j |_ n||_dS(Ni( RtFalset event_maptgetR%R tnotifyRtBACKOFFttimetbackofftdelay(Rt new_statetexpectedt old_statet event_classteventtnow((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt change_states    cGs\|j|krXt|j}djtt|}td|jj||fndS(Nt s%Assertion failed for %s: %s not in %s(RRR7tmaptAssertionErrorRtname(Rtstatest current_statetallowable_states((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt_assertInStates cCs'||_|jjjjd|dS(Ns spawnerr: %s(tspawnerrRR2tloggertinfo(Rtmsg((s6/usr/lib/python2.7/site-packages/supervisor/process.pytrecord_spawnerrs c Cs|jj}|jr9d|jj}|jj|dSt|_d|_ d|_ t|_ t|_ t j |_|jtjtjtjtj|jtjy|j\}}WnHtk r}|j|jd|jtj|jtjdSXy"|jj|\|_|_Wnttfk r}|jd}|t j!krqd|jj}n%d|jjt j"j#||f}|j||jtj|jtjdSXy|j$}Wntk r}|jd}|t j%krd|jj}n%d|jjt j"j#||f}|j||jtj|jtj|j&|j|j'|jdSX|dkr|j(|S|j)||SdS(sStart the subprocess. It must not be running already. Return the process id. If the fork() call fails, return None. sprocess %r already runningNistoo many open files to spawn %rs+unknown error making dispatchers for %r: %ss/Too many processes in process table to spawn %rs$unknown error during fork for %r: %s(*RR2R RSRYtwarnRAR!R%RXt exitstatust system_stoptadministrative_stopRFt laststartRWRtEXITEDtFATALRERROtSTARTINGR@RR\targstmake_dispatchersRRR"tIOErrorR#tEMFILEt errorcodeRCtforktEAGAINtclose_parent_pipestclose_child_pipest_spawn_as_parentt_spawn_as_child( RR2R[R<targvtwhattwhytcodeR ((s6/usr/lib/python2.7/site-packages/supervisor/process.pytspawnsf       " "  "   cCsx||_|jj}|j|j|jjd|jj|fd|_ t j |jj |_ ||j |<|S(Nsspawned: %r with pid %s(R RR2RmRRYRZRSR%RXRFt startsecsRHt pidhistory(RR R2((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRns     cCs|jj}|j|jdd|j|jdd|jjr`|j|jddn|j|jddx'td|jD]}|j|qWdS(Nt child_stdinit child_stdoutiit child_stderri(RR2tdup2Rtredirect_stderrtrangetminfdstclose_fd(RR2ti((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt_prepare_child_fds s  cCs|jj}z|j|j|j}|ri|jj}d||f}|jdd|dStjj }d|d<|jj }|dkr|jjj }n|r||d(tidRRSRt get_state(R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt__repr__Ys  cCs|jS(N(R(R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR_scCsktj}|j}|jjj}|jjjtjkr|tj kr|jj r|jj t krv|j q|j |jjkr|j qqq|tjkr|j r|jjr|j qq|tjkr|j|jjkr||jkr|j qqqn|tjkr||j|jjkrd|_d|_|jtj|jtjd|jj}|jd|jj|fqn|tjkr|j|jjkrg|jd}|jd|jj|fqgng|tjkrg|j|}|dkrg|jjjjd|jj|j f|j!t"j#qgndS(NisNentered RUNNING state, process has stayed up for > than %s seconds (startsecs)ssuccess: %s %ss7entered FATAL state, too many start retries too quicklysgave up: %s %sskilling %r (%s) with SIGKILL($RFRRR2RYtmoodRt RESTARTINGRRbt autorestartR RtR^RRRat autostartRERGt startretriesRHRdRuRWRORRZRSRRR]R RRtSIGKILL(RRNRRYR[t time_left((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt transitionbsL        # #   N(Dt__name__t __module__t__doc__R R%RRtlistener_stateRMRaRRRHRAR`R_R!RGRRR^RXRRRRRR+R@R tProcessStateBackoffEventRREtProcessStateFatalEventRctProcessStateUnknownEventRtProcessStateStoppedEventRtProcessStateExitedEventRbtProcessStateRunningEventRtProcessStateStartingEventRdtProcessStateStoppingEventRRBRRORWR\RtRnRRoRRRRRRRRRRRR(((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR sj    .           H G    J $ W    tFastCGISubprocesscBsDeZdZdZdZdZdZdZdZRS(s7Extends Subprocess class to handle FastCGI subprocessescCstj||d|_dS(N(R RR%t fcgi_sock(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRscCsn|jdkrtdnt|jdsUtd|jt|jfn|jjj|_dS(sU The FastCGI socket needs to be created by the parent before we fork s"No group set for FastCGISubprocesstsocket_managersNo SocketManager set for %s:%sN(RR%tNotImplementedErrorRR?Rt get_socketR(R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt before_spawns cCs5|jtj|}|dkr1d|_n|S(sR Overrides Subprocess.spawn() so we can hook in before it happens N(RR RtR%R(RR ((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRts    cCs d|_dS(sM Releases reference to FastCGI socket when process is reaped N(R%R(R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt after_finishscCs#tj|||}|j|S(sR Overrides Subprocess.finish() so we can hook in after it happens (R RR(RR Rtretval((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs cCs|jj}|jj}|j|d|j|jdd|jjrh|j|jddn|j|jddx'td|jD]}|j |qWdS(s Overrides Subprocess._prepare_child_fds() The FastCGI socket needs to be set to file descriptor 0 in the child iRxiiRyiN( RtfilenoRR2RzRR{R|R}R~(Rtsock_fdR2R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs  ( RRRRRRtRRR(((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs   tProcessGroupBasecBsYeZdZdZdZdZdZdZdZdZ dZ RS( cCsF||_i|_x-|jjD]}|j||j|j(t __class__RRRS(R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRscCs(x!|jjD]}|jqWdS(N(RRR(Rtprocess((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRscCs(x!|jjD]}|jqWdS(N(RRR(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRscCs|jj}|j|jxn|D]f}|j}|tjkrX|jq*|tjkrt|jq*|tj kr*|j q*q*WdS(N( RRtsorttreverseRRRRRdRER(RRtprocR((s6/usr/lib/python2.7/site-packages/supervisor/process.pytstop_alls      cCs2g|jjD]}|jtkr|^qS(s@ Processes which aren't in a state that is considered 'stopped' (RRRR(Rtx((s6/usr/lib/python2.7/site-packages/supervisor/process.pytget_unstopped_processesscCs4i}x'|jjD]}|j|jqW|S(N(RRRR(RRR((s6/usr/lib/python2.7/site-packages/supervisor/process.pytget_dispatchers scCsdS(N((R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyt before_removes( RRRRRRRRRRR(((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs        t ProcessGroupcBseZdZRS(cCs(x!|jjD]}|jqWdS(N(RRR(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs(RRR(((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRstFastCGIProcessGroupcBseZdZRS(cKstj|||jdt}||jd|jj|_y|jjWn2t k r}t d|jj |fnXdS(Nt socketManagerRYs&Could not create FastCGI socket %s: %s( RRRCR t socket_configR2RYRRt ExceptionR0R(RRtkwargstsockManagerKlassR:((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs (RRR(((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRstEventListenerPoolcBseeZdZdZdZdZdZedZdZ dZ dZ d Z RS( cCsBtj||g|_d|_d|_d|_|jdS(Nii(RRt event_buffertserialt last_dispatchtdispatch_throttlet _subscribe(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR&s     cCsA|j}|jj}||kr=|j|jdtndS(Nthead(RRRt _acceptEventRMR(RRMRtprocs((s6/usr/lib/python2.7/site-packages/supervisor/process.pythandle_rejected.s  cCs|jj}t}xH|D]@}|j|jtjkr|jtj kr\t }q\qqW|r|j rt j }||j |j krdSn|jndS(N(RRRARRRRRR tREADYRRRFRtdispatch(RRtdispatch_capableRRN((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR5s    cCs|jdS(N(t _unsubscribe(R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRFscCsaxK|jrM|jjd}|j|}|s|j|dtPqqWtj|_dS(NiR(Rtpopt_dispatchEventRRRFR(RRMtok((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR Is cCsCt|ds!tt|_nt|ds<i|_n|jj|jjspt||j|jj|jjj j d|j|jjt |j |jj ft |j |jj kr|j r|j jd}|jjj jd|jj|jfqn|r/|j jd|n|j j|dS(NRt pool_serialss6rebuffering event %s for pool %s (buf size=%d, max=%d)is4pool %s event buffer overflowed, discarding event %s(Rt new_serialt GlobalSerialRRthas_keyRRSR2RYRtlenRt buffer_sizeR Rtinserttappend(RRMRtdiscarded_event((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRUs&  c Cs|j|jj}x|jjD]}|jtjkrAq#n|jt j kr#t |}y;|j }|j }|j||||}|j|Wn2tk r}|jdtjkr#q#q#nXt j|_||_|jjjjd|j |jjftSq#WtS(Nisevent %s sent to listener %s(RRRSRRRRRRR RR1RRt_eventEnvelopeR+R"ReR#R$tBUSYRMR2RYRRRA( RRMt pool_serialRtpayloadt event_typeRtenvelopeRr((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR ps.       cCsptj|}t|}idd6|jjjd6|d6|jjd6|d6|d6|d6|d 6}d |S( Ns3.0tvertsidRt pool_nameRt event_nameRRsver:%(ver)s server:%(sid)s serial:%(serial)s pool:%(pool_name)s poolserial:%(pool_serial)s eventname:%(event_name)s len:%(len)s %(payload)s(R tgetEventNameByTypeRRR2t identifierRS(RRRRRR!t payload_lentD((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs   cCsDx'|jjD]}tj||jq Wtjtj|jdS(N(Rt pool_eventsR t subscribeRRR(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRscCsDx'|jjD]}tj||jq Wtjtj|jdS(N(RR&R t unsubscribeRRR(RR((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR s( RRRRRRR RARR RRR (((s6/usr/lib/python2.7/site-packages/supervisor/process.pyR%s        RcBseZdZRS(cCs d|_dS(Ni(R(R((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs(RRR(((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRscCs4|jtjkrd|_n|jd7_|jS(Nii(Rtsystmaxint(tinst((s6/usr/lib/python2.7/site-packages/supervisor/process.pyRs (%R5R)RFR#R-RRtsupervisor.medusaRRtsupervisor.statesRRRRtsupervisor.optionsRRRRtsupervisor.dispatchersR t supervisorR tsupervisor.datatypesR tsupervisor.socket_managerR R RRRRRtobjectRR(((s6/usr/lib/python2.7/site-packages/supervisor/process.pyts:       =6