!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache. PHP/5.6.40 

uname -a: Linux cpanel06wh.bkk1.cloud.z.com 2.6.32-954.3.5.lve1.4.80.el6.x86_64 #1 SMP Thu Sep 24
01:42:00 EDT 2020 x86_64
 

uid=851(cp949260) gid=853(cp949260) groups=853(cp949260) 

Safe-mode: OFF (not secure)

/opt/passenger-5.3.7-4.el6.cloudlinux/src/agent/Core/ApplicationPool/Pool/   drwxr-xr-x
Free 221.52 GB of 981.82 GB (22.56%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     GarbageCollection.cpp (5.79 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*
 *  Phusion Passenger - https://www.phusionpassenger.com/
 *  Copyright (c) 2011-2017 Phusion Holding B.V.
 *
 *  "Passenger", "Phusion Passenger" and "Union Station" are registered
 *  trademarks of Phusion Holding B.V.
 *
 *  Permission is hereby granted, free of charge, to any person obtaining a copy
 *  of this software and associated documentation files (the "Software"), to deal
 *  in the Software without restriction, including without limitation the rights
 *  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 *  copies of the Software, and to permit persons to whom the Software is
 *  furnished to do so, subject to the following conditions:
 *
 *  The above copyright notice and this permission notice shall be included in
 *  all copies or substantial portions of the Software.
 *
 *  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 *  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 *  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 *  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 *  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 *  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 *  THE SOFTWARE.
 */
#include <Core/ApplicationPool/Pool.h>

/*************************************************************************
 *
 * Garbage collection functions for ApplicationPool2::Pool
 *
 *************************************************************************/

namespace Passenger {
namespace ApplicationPool2 {

using namespace std;
using namespace boost;


void
Pool::initializeGarbageCollection() {
    interruptableThreads.create_thread(
        boost::bind(garbageCollect, shared_from_this()),
        "Pool garbage collector",
        POOL_HELPER_THREAD_STACK_SIZE
    );
}

void
Pool::garbageCollect(PoolPtr self) {
    TRACE_POINT();
    {
        ScopedLock lock(self->syncher);
        self->garbageCollectionCond.timed_wait(lock,
            posix_time::seconds(5));
    }
    while (!this_thread::interruption_requested()) {
        try {
            UPDATE_TRACE_POINT();
            unsigned long long sleepTime = self->realGarbageCollect();
            UPDATE_TRACE_POINT();
            ScopedLock lock(self->syncher);
            self->garbageCollectionCond.timed_wait(lock,
                posix_time::microseconds(sleepTime));
        } catch (const thread_interrupted &) {
            break;
        } catch (const tracable_exception &e) {
            P_WARN("ERROR: " << e.what() << "\n  Backtrace:\n" << e.backtrace());
        }
    }
}

void
Pool::maybeUpdateNextGcRuntime(GarbageCollectorState &state, unsigned long candidate) {
    if (state.nextGcRunTime == 0 || candidate < state.nextGcRunTime) {
        state.nextGcRunTime = candidate;
    }
}

void
Pool::checkWhetherProcessCanBeGarbageCollected(GarbageCollectorState &state,
    const GroupPtr &group, const ProcessPtr &process, ProcessList &output)
{
    assert(maxIdleTime > 0);
    unsigned long long processGcTime = process->lastUsed + maxIdleTime;
    if (process->sessions == 0
     && state.now >= processGcTime)
    {
        if (output.capacity() == 0) {
            output.reserve(group->enabledCount);
        }
        output.push_back(process);
    } else {
        maybeUpdateNextGcRuntime(state, processGcTime);
    }
}

void
Pool::garbageCollectProcessesInGroup(GarbageCollectorState &state,
    const GroupPtr &group)
{
    ProcessList &processes = group->enabledProcesses;
    ProcessList processesToGc;
    ProcessList::iterator p_it, p_end = processes.end();

    for (p_it = processes.begin(); p_it != p_end; p_it++) {
        const ProcessPtr &process = *p_it;
        checkWhetherProcessCanBeGarbageCollected(state, group, process,
            processesToGc);
    }

    p_it  = processesToGc.begin();
    p_end = processesToGc.end();
    while (p_it != p_end
     && (unsigned long) group->getProcessCount() > group->options.minProcesses)
    {
        ProcessPtr process = *p_it;
        P_DEBUG("Garbage collect idle process: " << process->inspect() <<
            ", group=" << group->getName());
        group->detach(process, state.actions);
        p_it++;
    }
}

void
Pool::maybeCleanPreloader(GarbageCollectorState &state, const GroupPtr &group) {
    if (group->spawner->cleanable() && group->options.getMaxPreloaderIdleTime() != 0) {
        unsigned long long spawnerGcTime =
            group->spawner->lastUsed() +
            group->options.getMaxPreloaderIdleTime() * 1000000;
        if (state.now >= spawnerGcTime) {
            P_DEBUG("Garbage collect idle spawner: group=" << group->getName());
            group->cleanupSpawner(state.actions);
        } else {
            maybeUpdateNextGcRuntime(state, spawnerGcTime);
        }
    }
}

unsigned long long
Pool::realGarbageCollect() {
    TRACE_POINT();
    ScopedLock lock(syncher);
    GroupMap::ConstIterator g_it(groups);
    GarbageCollectorState state;
    state.now = SystemTime::getUsec();
    state.nextGcRunTime = 0;

    P_DEBUG("Garbage collection time...");
    verifyInvariants();

    // For all groups...
    while (*g_it != NULL) {
        const GroupPtr group = g_it.getValue();

        if (maxIdleTime > 0) {
            // ...detach processes that have been idle for more than maxIdleTime.
            garbageCollectProcessesInGroup(state, group);
        }

        group->verifyInvariants();

        // ...cleanup the spawner if it's been idle for more than preloaderIdleTime.
        maybeCleanPreloader(state, group);

        g_it.next();
    }

    verifyInvariants();
    lock.unlock();

    // Schedule next garbage collection run.
    unsigned long long sleepTime;
    if (state.nextGcRunTime == 0 || state.nextGcRunTime <= state.now) {
        if (maxIdleTime == 0) {
            sleepTime = 10 * 60 * 1000000;
        } else {
            sleepTime = maxIdleTime;
        }
    } else {
        sleepTime = state.nextGcRunTime - state.now;
    }
    P_DEBUG("Garbage collection done; next garbage collect in " <<
        std::fixed << std::setprecision(3) << (sleepTime / 1000000.0) << " sec");

    UPDATE_TRACE_POINT();
    runAllActions(state.actions);
    UPDATE_TRACE_POINT();
    state.actions.clear();
    return sleepTime;
}

void
Pool::wakeupGarbageCollector() {
    garbageCollectionCond.notify_all();
}


} // namespace ApplicationPool2
} // namespace Passenger

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by KaizenLouie | C99Shell Github | Generation time: 0.0783 ]--