2009-10-27 15:58:27 -04:00
|
|
|
//background.cpp
|
|
|
|
|
|
|
|
|
|
/* Copyright 2009 10gen Inc.
|
|
|
|
|
*
|
|
|
|
|
* Licensed 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.
|
|
|
|
|
*/
|
2008-10-29 16:48:03 -05:00
|
|
|
|
2010-04-27 15:27:52 -04:00
|
|
|
#include "pch.h"
|
2008-10-29 16:48:03 -05:00
|
|
|
#include "goodies.h"
|
|
|
|
|
#include "background.h"
|
2010-05-06 17:25:50 -04:00
|
|
|
#include <list>
|
2008-10-29 16:48:03 -05:00
|
|
|
|
2009-01-14 17:09:51 -05:00
|
|
|
namespace mongo {
|
|
|
|
|
|
2010-08-13 14:47:47 -04:00
|
|
|
// BackgroundJob *BackgroundJob::grab = 0;
|
|
|
|
|
// mongo::mutex BackgroundJob::mutex("BackgroundJob");
|
2008-10-29 16:48:03 -05:00
|
|
|
|
2009-01-15 10:17:11 -05:00
|
|
|
void BackgroundJob::thr() {
|
2010-08-13 14:47:47 -04:00
|
|
|
assert( state == NotStarted );
|
|
|
|
|
state = Running;
|
2010-05-18 12:17:43 -04:00
|
|
|
|
2010-08-13 14:47:47 -04:00
|
|
|
if( nameThread ) {
|
|
|
|
|
string nm = name();
|
2010-05-18 12:17:43 -04:00
|
|
|
setThreadName(nm.c_str());
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-06 17:25:50 -04:00
|
|
|
try {
|
2010-08-13 14:47:47 -04:00
|
|
|
run();
|
2010-05-06 17:25:50 -04:00
|
|
|
}
|
2010-07-28 16:03:32 -04:00
|
|
|
catch ( std::exception& e ){
|
2010-08-13 14:47:47 -04:00
|
|
|
log( LL_ERROR ) << "backgroundjob " << name() << "error: " << e.what() << endl;
|
2010-07-28 16:03:32 -04:00
|
|
|
}
|
2010-05-06 17:25:50 -04:00
|
|
|
catch(...) {
|
2010-08-13 14:47:47 -04:00
|
|
|
log( LL_ERROR ) << "uncaught exception in BackgroundJob " << name() << endl;
|
2010-05-06 17:25:50 -04:00
|
|
|
}
|
2010-08-13 14:47:47 -04:00
|
|
|
state = Done;
|
|
|
|
|
bool delSelf = deleteSelf;
|
2010-08-13 15:30:00 -04:00
|
|
|
//ending();
|
2010-05-19 09:02:27 -04:00
|
|
|
if( delSelf )
|
2010-08-13 14:47:47 -04:00
|
|
|
delete this;
|
2009-01-15 10:17:11 -05:00
|
|
|
}
|
2008-10-29 16:48:03 -05:00
|
|
|
|
2009-01-15 10:17:11 -05:00
|
|
|
BackgroundJob& BackgroundJob::go() {
|
2010-08-13 14:47:47 -04:00
|
|
|
boost::thread t( boost::bind(&BackgroundJob::thr, this) );
|
2009-01-15 10:17:11 -05:00
|
|
|
return *this;
|
|
|
|
|
}
|
2008-10-29 16:48:03 -05:00
|
|
|
|
2010-05-06 17:25:50 -04:00
|
|
|
bool BackgroundJob::wait(int msMax, unsigned maxsleep) {
|
2010-08-13 15:34:58 -04:00
|
|
|
unsigned ms = 1;
|
2009-12-03 17:25:22 -05:00
|
|
|
Date_t start = jsTime();
|
2009-01-15 10:17:11 -05:00
|
|
|
while ( state != Done ) {
|
|
|
|
|
sleepmillis(ms);
|
2010-05-06 17:25:50 -04:00
|
|
|
if( ms*2<maxsleep ) ms*=2;
|
2009-01-15 10:17:11 -05:00
|
|
|
if ( msMax && ( int( jsTime() - start ) > msMax) )
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
2008-10-29 16:48:03 -05:00
|
|
|
}
|
2009-01-14 17:09:51 -05:00
|
|
|
|
2010-05-07 15:35:16 -04:00
|
|
|
void BackgroundJob::go(list<BackgroundJob*>& L) {
|
|
|
|
|
for( list<BackgroundJob*>::iterator i = L.begin(); i != L.end(); i++ )
|
|
|
|
|
(*i)->go();
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-06 17:25:50 -04:00
|
|
|
/* wait for several jobs to finish. */
|
|
|
|
|
void BackgroundJob::wait(list<BackgroundJob*>& L, unsigned maxsleep) {
|
2010-08-13 15:34:58 -04:00
|
|
|
unsigned ms = 1;
|
2010-05-06 17:25:50 -04:00
|
|
|
{
|
|
|
|
|
x:
|
|
|
|
|
sleepmillis(ms);
|
|
|
|
|
if( ms*2<maxsleep ) ms*=2;
|
|
|
|
|
for( list<BackgroundJob*>::iterator i = L.begin(); i != L.end(); i++ ) {
|
2010-08-13 14:47:47 -04:00
|
|
|
//assert( (*i)->state != NotStarted );
|
2010-05-06 17:25:50 -04:00
|
|
|
if( (*i)->state != Done )
|
|
|
|
|
goto x;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2010-08-02 14:04:33 -04:00
|
|
|
|
2009-01-14 17:09:51 -05:00
|
|
|
} // namespace mongo
|