Integrate readwritelock with Pro Code
This commit is contained in:
parent
9486f16857
commit
a4a886428f
@ -43,9 +43,11 @@ void AsyncWorkQueue::WorkerThreadMain()
|
|||||||
lock.unlock();
|
lock.unlock();
|
||||||
serverTL->gcEpoch = g_pserver->garbageCollector.startEpoch();
|
serverTL->gcEpoch = g_pserver->garbageCollector.startEpoch();
|
||||||
if (listLength(serverTL->clients_pending_asyncwrite)) {
|
if (listLength(serverTL->clients_pending_asyncwrite)) {
|
||||||
|
aeThreadOnline();
|
||||||
aeAcquireLock();
|
aeAcquireLock();
|
||||||
ProcessPendingAsyncWrites();
|
ProcessPendingAsyncWrites();
|
||||||
aeReleaseLock();
|
aeReleaseLock();
|
||||||
|
aeThreadOffline();
|
||||||
}
|
}
|
||||||
g_pserver->garbageCollector.endEpoch(serverTL->gcEpoch);
|
g_pserver->garbageCollector.endEpoch(serverTL->gcEpoch);
|
||||||
serverTL->gcEpoch.reset();
|
serverTL->gcEpoch.reset();
|
||||||
|
@ -1068,7 +1068,9 @@ void keysCommand(client *c) {
|
|||||||
blockClient(c, BLOCKED_ASYNC);
|
blockClient(c, BLOCKED_ASYNC);
|
||||||
redisDb *db = c->db;
|
redisDb *db = c->db;
|
||||||
g_pserver->asyncworkqueue->AddWorkFunction([el, c, db, patternCopy, snapshot]{
|
g_pserver->asyncworkqueue->AddWorkFunction([el, c, db, patternCopy, snapshot]{
|
||||||
|
aeThreadOnline();
|
||||||
keysCommandCore(c, snapshot, patternCopy);
|
keysCommandCore(c, snapshot, patternCopy);
|
||||||
|
aeThreadOffline();
|
||||||
sdsfree(patternCopy);
|
sdsfree(patternCopy);
|
||||||
aePostFunction(el, [c, db, snapshot]{
|
aePostFunction(el, [c, db, snapshot]{
|
||||||
aeReleaseLock(); // we need to lock with coordination of the client
|
aeReleaseLock(); // we need to lock with coordination of the client
|
||||||
|
@ -1552,6 +1552,7 @@ struct rdbSaveThreadArgs
|
|||||||
|
|
||||||
void *rdbSaveThread(void *vargs)
|
void *rdbSaveThread(void *vargs)
|
||||||
{
|
{
|
||||||
|
aeThreadOnline();
|
||||||
serverAssert(!g_pserver->rdbThreadVars.fDone);
|
serverAssert(!g_pserver->rdbThreadVars.fDone);
|
||||||
rdbSaveThreadArgs *args = reinterpret_cast<rdbSaveThreadArgs*>(vargs);
|
rdbSaveThreadArgs *args = reinterpret_cast<rdbSaveThreadArgs*>(vargs);
|
||||||
serverAssert(serverTL == nullptr);
|
serverAssert(serverTL == nullptr);
|
||||||
@ -1577,7 +1578,7 @@ void *rdbSaveThread(void *vargs)
|
|||||||
"%s: %zd MB of memory used by copy-on-write",
|
"%s: %zd MB of memory used by copy-on-write",
|
||||||
"RDB",cbDiff/(1024*1024));
|
"RDB",cbDiff/(1024*1024));
|
||||||
}
|
}
|
||||||
|
aeThreadOffline();
|
||||||
g_pserver->rdbThreadVars.fDone = true;
|
g_pserver->rdbThreadVars.fDone = true;
|
||||||
return (retval == C_OK) ? (void*)0 : (void*)1;
|
return (retval == C_OK) ? (void*)0 : (void*)1;
|
||||||
}
|
}
|
||||||
@ -3659,6 +3660,7 @@ void *rdbSaveToSlavesSocketsThread(void *vargs)
|
|||||||
serverTL = &vars;
|
serverTL = &vars;
|
||||||
vars.gcEpoch = g_pserver->garbageCollector.startEpoch();
|
vars.gcEpoch = g_pserver->garbageCollector.startEpoch();
|
||||||
|
|
||||||
|
aeThreadOnline();
|
||||||
rioInitWithFd(&rdb,args->rdb_pipe_write);
|
rioInitWithFd(&rdb,args->rdb_pipe_write);
|
||||||
|
|
||||||
retval = rdbSaveRioWithEOFMark(&rdb,args->rgpdb,NULL,&args->rsi);
|
retval = rdbSaveRioWithEOFMark(&rdb,args->rgpdb,NULL,&args->rsi);
|
||||||
@ -3684,7 +3686,7 @@ void *rdbSaveToSlavesSocketsThread(void *vargs)
|
|||||||
g_pserver->db[idb]->endSnapshotAsync(args->rgpdb[idb]);
|
g_pserver->db[idb]->endSnapshotAsync(args->rgpdb[idb]);
|
||||||
|
|
||||||
g_pserver->garbageCollector.endEpoch(vars.gcEpoch);
|
g_pserver->garbageCollector.endEpoch(vars.gcEpoch);
|
||||||
|
aeThreadOffline();
|
||||||
|
|
||||||
close(args->safe_to_exit_pipe);
|
close(args->safe_to_exit_pipe);
|
||||||
zfree(args);
|
zfree(args);
|
||||||
|
@ -1017,7 +1017,11 @@ static void benchmark(const char *title, const char *cmd, int len) {
|
|||||||
createMissingClients(c);
|
createMissingClients(c);
|
||||||
|
|
||||||
config.start = mstime();
|
config.start = mstime();
|
||||||
if (!config.num_threads) aeMain(config.el);
|
if (!config.num_threads) {
|
||||||
|
aeThreadOnline();
|
||||||
|
aeMain(config.el);
|
||||||
|
aeThreadOffline();
|
||||||
|
}
|
||||||
else startBenchmarkThreads();
|
else startBenchmarkThreads();
|
||||||
config.totlatency = mstime()-config.start;
|
config.totlatency = mstime()-config.start;
|
||||||
|
|
||||||
@ -1057,7 +1061,9 @@ static void freeBenchmarkThreads() {
|
|||||||
|
|
||||||
static void *execBenchmarkThread(void *ptr) {
|
static void *execBenchmarkThread(void *ptr) {
|
||||||
benchmarkThread *thread = (benchmarkThread *) ptr;
|
benchmarkThread *thread = (benchmarkThread *) ptr;
|
||||||
|
aeThreadOnline();
|
||||||
aeMain(thread->el);
|
aeMain(thread->el);
|
||||||
|
aeThreadOffline();
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1696,7 +1702,7 @@ int main(int argc, const char **argv) {
|
|||||||
int len;
|
int len;
|
||||||
|
|
||||||
client c;
|
client c;
|
||||||
|
aeThreadOnline();
|
||||||
storage_init(NULL, 0);
|
storage_init(NULL, 0);
|
||||||
|
|
||||||
srandom(time(NULL) ^ getpid());
|
srandom(time(NULL) ^ getpid());
|
||||||
@ -1749,6 +1755,7 @@ int main(int argc, const char **argv) {
|
|||||||
cliSecureInit();
|
cliSecureInit();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
aeThreadOffline();
|
||||||
|
|
||||||
if (config.cluster_mode) {
|
if (config.cluster_mode) {
|
||||||
// We only include the slot placeholder {tag} if cluster mode is enabled
|
// We only include the slot placeholder {tag} if cluster mode is enabled
|
||||||
|
@ -1196,7 +1196,7 @@ int rdbSaveSnapshotForReplication(struct rdbSaveInfo *rsi) {
|
|||||||
size_t cbData = 0;
|
size_t cbData = 0;
|
||||||
size_t cbLastUpdate = 0;
|
size_t cbLastUpdate = 0;
|
||||||
auto &replBuf = *spreplBuf;
|
auto &replBuf = *spreplBuf;
|
||||||
|
aeThreadOnline();
|
||||||
// Databases
|
// Databases
|
||||||
replBuf.addArrayLen(cserver.dbnum);
|
replBuf.addArrayLen(cserver.dbnum);
|
||||||
for (int idb = 0; idb < cserver.dbnum; ++idb) {
|
for (int idb = 0; idb < cserver.dbnum; ++idb) {
|
||||||
@ -1244,6 +1244,7 @@ int rdbSaveSnapshotForReplication(struct rdbSaveInfo *rsi) {
|
|||||||
replBuf.putSlavesOnline();
|
replBuf.putSlavesOnline();
|
||||||
aeReleaseLock();
|
aeReleaseLock();
|
||||||
}
|
}
|
||||||
|
aeThreadOffline();
|
||||||
});
|
});
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
|
@ -6855,6 +6855,7 @@ int redisFork(int purpose) {
|
|||||||
latencyAddSampleIfNeeded("fork-lock",(ustime()-startWriteLock)/1000);
|
latencyAddSampleIfNeeded("fork-lock",(ustime()-startWriteLock)/1000);
|
||||||
if ((childpid = fork()) == 0) {
|
if ((childpid = fork()) == 0) {
|
||||||
/* Child */
|
/* Child */
|
||||||
|
aeReleaseForkLock();
|
||||||
g_pserver->in_fork_child = purpose;
|
g_pserver->in_fork_child = purpose;
|
||||||
setOOMScoreAdj(CONFIG_OOM_BGCHILD);
|
setOOMScoreAdj(CONFIG_OOM_BGCHILD);
|
||||||
setupChildSignalHandlers();
|
setupChildSignalHandlers();
|
||||||
@ -7258,9 +7259,11 @@ void *workerThreadMain(void *parg)
|
|||||||
|
|
||||||
if (iel != IDX_EVENT_LOOP_MAIN)
|
if (iel != IDX_EVENT_LOOP_MAIN)
|
||||||
{
|
{
|
||||||
|
aeThreadOnline();
|
||||||
aeAcquireLock();
|
aeAcquireLock();
|
||||||
initNetworkingThread(iel, cserver.cthreads > 1);
|
initNetworkingThread(iel, cserver.cthreads > 1);
|
||||||
aeReleaseLock();
|
aeReleaseLock();
|
||||||
|
aeThreadOffline();
|
||||||
}
|
}
|
||||||
|
|
||||||
moduleAcquireGIL(true); // Normally afterSleep acquires this, but that won't be called on the first run
|
moduleAcquireGIL(true); // Normally afterSleep acquires this, but that won't be called on the first run
|
||||||
|
Loading…
x
Reference in New Issue
Block a user