Postgres-XC源码:Utilities for GTM standby global values
2014-12-27 07:33
381 查看
come from :Postgres-XC source code 1.04
* standby_utils.c
* Utilities for GTM standby global values
#include "gtm/gtm_c.h"
#include "gtm/standby_utils.h"
#include "gtm/gtm_lock.h"
/*
* Variables to interact with GTM active under GTM standby mode.
*/
bool GTM_StandbyMode = false;
char *GTM_ActiveAddress;
int GTM_ActivePort;
/* For thread safety, values above are protected by a lock */
static GTM_RWLock StandbyLock;
bool
Recovery_IsStandby(void)
{
bool res;
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_READ);
res = GTM_StandbyMode;
GTM_RWLockRelease(&StandbyLock);
return res;
}
void
Recovery_StandbySetStandby(bool standby)
{
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_WRITE);
GTM_StandbyMode = standby;
GTM_RWLockRelease(&StandbyLock);
}
void
Recovery_StandbySetConnInfo(const char *addr, int port)
{
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_WRITE);
GTM_ActiveAddress = strdup(addr);
GTM_ActivePort = port;
GTM_RWLockRelease(&StandbyLock);
}
int
Recovery_StandbyGetActivePort(void)
{
int res;
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_READ);
res = GTM_ActivePort;
GTM_RWLockRelease(&StandbyLock);
return res;
}
char *
Recovery_StandbyGetActiveAddress(void)
{
char *res;
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_READ);
res = GTM_ActiveAddress;
GTM_RWLockRelease(&StandbyLock);
return res;
}
void
Recovery_InitStandbyLock(void)
{
GTM_RWLockInit(&StandbyLock);
}
* standby_utils.c
* Utilities for GTM standby global values
#include "gtm/gtm_c.h"
#include "gtm/standby_utils.h"
#include "gtm/gtm_lock.h"
/*
* Variables to interact with GTM active under GTM standby mode.
*/
bool GTM_StandbyMode = false;
char *GTM_ActiveAddress;
int GTM_ActivePort;
/* For thread safety, values above are protected by a lock */
static GTM_RWLock StandbyLock;
bool
Recovery_IsStandby(void)
{
bool res;
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_READ);
res = GTM_StandbyMode;
GTM_RWLockRelease(&StandbyLock);
return res;
}
void
Recovery_StandbySetStandby(bool standby)
{
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_WRITE);
GTM_StandbyMode = standby;
GTM_RWLockRelease(&StandbyLock);
}
void
Recovery_StandbySetConnInfo(const char *addr, int port)
{
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_WRITE);
GTM_ActiveAddress = strdup(addr);
GTM_ActivePort = port;
GTM_RWLockRelease(&StandbyLock);
}
int
Recovery_StandbyGetActivePort(void)
{
int res;
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_READ);
res = GTM_ActivePort;
GTM_RWLockRelease(&StandbyLock);
return res;
}
char *
Recovery_StandbyGetActiveAddress(void)
{
char *res;
GTM_RWLockAcquire(&StandbyLock, GTM_LOCKMODE_READ);
res = GTM_ActiveAddress;
GTM_RWLockRelease(&StandbyLock);
return res;
}
void
Recovery_InitStandbyLock(void)
{
GTM_RWLockInit(&StandbyLock);
}
相关文章推荐
- Postgres-XC源码: GTM lock
- RMAN-08137: WARNING: archived log not deleted, needed for standby or upstream capture process
- Oracle 11g 新特性—— Active Database Duplication for A standby database
- Step-By-Step Guide To Create Physical Standby On Normal File System For ASM Primary using RMAN (文档 I
- 论文笔记:Improving Deep Visual Representation for Person Re-identification by Global and Local Image-language Association
- RFS[1]: No standby redo logfiles available for thread 1
- shining cento in book reading: handle out of memory problem for new operator -by register a global SetNewHandler
- RFS[18075]: No standby redo logfiles available for thread 1
- Primary & Standby with 2 HOST HA for PostgreSQL (auto failover failback)
- RMAN duplicate for standby失败解决过程
- OCM_Session8_1_Preparing the Primary Database for Standby Database Creation
- Script to Collect Data Guard Physical and Active Standby Diagnostic Info for 10g and above(+RAC)
- How To Open Physical Standby For Read Write Testing and Flashback
- RMAN-08137: WARNING: archived log not deleted, needed for standby or upstream capture process .
- 11g rman新特性 duplicate target database for standby from active database
- Step-By-Step Guide To Create Physical Standby On Normal File System For ASM Primary using RMAN
- Oracle 11gR2 Duplicate target database for standby
- postgres standby实现同步流复制
- RMAN-08137: WARNING: archived log not deleted, needed for standby or upstream capture process
- RMAN-08137: WARNING: archived log not deleted, needed for standby or upstream capture process