mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-20 22:26:54 +01:00
in advance of using memcache, keep track (in memory) of those devids
for which no messages are pending, since that's a query that can be made by each device every minute.
This commit is contained in:
parent
42bbc946ae
commit
61009cefc7
2 changed files with 44 additions and 3 deletions
|
@ -877,6 +877,8 @@ DBMgr::StoreMessage( const char* const connName, int hid,
|
||||||
if ( DEVID_NONE == devID ) {
|
if ( DEVID_NONE == devID ) {
|
||||||
logf( XW_LOGERROR, "%s: warning: devid not found for connName=%s, "
|
logf( XW_LOGERROR, "%s: warning: devid not found for connName=%s, "
|
||||||
"hid=%d", __func__, connName, hid );
|
"hid=%d", __func__, connName, hid );
|
||||||
|
} else {
|
||||||
|
clearHasNoMessages( devID );
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t newLen;
|
size_t newLen;
|
||||||
|
@ -972,9 +974,15 @@ DBMgr::storedMessagesImpl( string test, vector<DBMgr::MsgInfo>& msgs )
|
||||||
void
|
void
|
||||||
DBMgr::GetStoredMessages( DevIDRelay relayID, vector<MsgInfo>& msgs )
|
DBMgr::GetStoredMessages( DevIDRelay relayID, vector<MsgInfo>& msgs )
|
||||||
{
|
{
|
||||||
string query;
|
if ( !hasNoMessages( relayID ) ) {
|
||||||
string_printf( query, "devid=%d", relayID );
|
string query;
|
||||||
storedMessagesImpl( query, msgs );
|
string_printf( query, "devid=%d", relayID );
|
||||||
|
storedMessagesImpl( query, msgs );
|
||||||
|
|
||||||
|
if ( 0 == msgs.size() ) {
|
||||||
|
setHasNoMessages( relayID );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1058,6 +1066,31 @@ DBMgr::getCountWhere( const char* table, string& test )
|
||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool DBMgr::hasNoMessages( DevIDRelay devid )
|
||||||
|
{
|
||||||
|
bool result;
|
||||||
|
{
|
||||||
|
MutexLock ml( &m_haveNoMessagesMutex );
|
||||||
|
result = m_haveNoMessages.find(devid) != m_haveNoMessages.end();
|
||||||
|
}
|
||||||
|
logf( XW_LOGINFO, "%s(devid=%d)=>%d", __func__, devid, result );
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
void DBMgr::setHasNoMessages( DevIDRelay devid )
|
||||||
|
{
|
||||||
|
logf( XW_LOGINFO, "%s(devid=%d)", __func__, devid );
|
||||||
|
MutexLock ml( &m_haveNoMessagesMutex );
|
||||||
|
m_haveNoMessages.insert( devid );
|
||||||
|
}
|
||||||
|
|
||||||
|
void DBMgr::clearHasNoMessages( DevIDRelay devid )
|
||||||
|
{
|
||||||
|
logf( XW_LOGINFO, "%s(devid=%d)", __func__, devid );
|
||||||
|
MutexLock ml( &m_haveNoMessagesMutex );
|
||||||
|
m_haveNoMessages.erase( devid );
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
formatParams( char* paramValues[], int nParams, const char* fmt, char* buf,
|
formatParams( char* paramValues[], int nParams, const char* fmt, char* buf,
|
||||||
int bufLen, ... )
|
int bufLen, ... )
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#define _DBMGR_H_
|
#define _DBMGR_H_
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <set>
|
||||||
|
|
||||||
#include "xwrelay.h"
|
#include "xwrelay.h"
|
||||||
#include "xwrelay_priv.h"
|
#include "xwrelay_priv.h"
|
||||||
|
@ -141,10 +142,17 @@ class DBMgr {
|
||||||
PGconn* getThreadConn( void );
|
PGconn* getThreadConn( void );
|
||||||
void clearThreadConn();
|
void clearThreadConn();
|
||||||
|
|
||||||
|
bool hasNoMessages( DevIDRelay devid );
|
||||||
|
void setHasNoMessages( DevIDRelay devid );
|
||||||
|
void clearHasNoMessages( DevIDRelay devid );
|
||||||
|
|
||||||
void conn_key_alloc();
|
void conn_key_alloc();
|
||||||
pthread_key_t m_conn_key;
|
pthread_key_t m_conn_key;
|
||||||
bool m_useB64;
|
bool m_useB64;
|
||||||
|
|
||||||
|
pthread_mutex_t m_haveNoMessagesMutex;
|
||||||
|
set<DevIDRelay> m_haveNoMessages;
|
||||||
|
|
||||||
}; /* DBMgr */
|
}; /* DBMgr */
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue