/* * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * */ #include "qpid/broker/QueueCleaner.h" #include "qpid/broker/Broker.h" #include "qpid/broker/Queue.h" #include "qpid/sys/Timer.h" #include "qpid/sys/Time.h" #include #include namespace qpid { namespace broker { namespace { typedef boost::function0 FireFunction; class Task : public sys::TimerTask { public: Task(FireFunction f, sys::Duration duration); void fire(); private: FireFunction fireFunction; }; Task::Task(FireFunction f, qpid::sys::Duration d) : sys::TimerTask(d,"QueueCleaner"), fireFunction(f) {} void Task::fire() { fireFunction(); } } QueueCleaner::QueueCleaner(QueueRegistry& q, boost::shared_ptr p, sys::Timer* t) : queues(q), timer(t), purging(boost::bind(&QueueCleaner::purge, this, _1), p) { purging.start(); } QueueCleaner::~QueueCleaner() { purging.stop(); if (task) task->cancel(); } void QueueCleaner::start(qpid::sys::Duration p) { period = p; task = new Task(boost::bind(&QueueCleaner::fired, this), p); timer->add(task); } void QueueCleaner::setTimer(qpid::sys::Timer* timer) { this->timer = timer; } void QueueCleaner::fired() { QPID_LOG(debug, "QueueCleaner::fired: requesting purge"); queues.eachQueue(boost::bind(&PurgeSet::push, &purging, _1)); task->restart(); // Update task restart time to now()+interval timer->add(task); } QueueCleaner::QueuePtrs::const_iterator QueueCleaner::purge(const QueueCleaner::QueuePtrs& batch) { const sys::AbsTime tmoTime = sys::AbsTime(sys::AbsTime::now(), 1 * sys::TIME_SEC); int nPurged = 0; QueuePtrs::const_iterator batchItr = batch.begin(); for ( ; batchItr != batch.end() && sys::AbsTime::now() < tmoTime; ++batchItr) { task->restart(); // Update task restart time to now()+interval (*batchItr)->purgeExpired(period); nPurged++; } QPID_LOG(debug, "QueueCleaner::purge: purged " << nPurged << " of " << batch.size() << " queues"); task->restart(); // Update task restart time to now()+interval return batchItr; } }} // namespace qpid::broker