mirror of
https://github.com/EnterpriseDB/repmgr.git
synced 2026-03-23 15:16:29 +00:00
Compare commits
10 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
069f9ff2ed | ||
|
|
b8ade8e908 | ||
|
|
c0abb3be31 | ||
|
|
fed5c77653 | ||
|
|
8429b43edf | ||
|
|
7e55ce737d | ||
|
|
98c7635fb5 | ||
|
|
90ecb2b107 | ||
|
|
50b9022a41 | ||
|
|
150ccc0662 |
10
README.rst
10
README.rst
@@ -625,18 +625,18 @@ Now restore to the original configuration by stopping
|
|||||||
primary server, then bringing up "node2" as a standby with a valid
|
primary server, then bringing up "node2" as a standby with a valid
|
||||||
``recovery.conf`` file.
|
``recovery.conf`` file.
|
||||||
|
|
||||||
Stop the "node2" server::
|
Stop the "node2" server and type the following on "node1" server::
|
||||||
|
|
||||||
repmgr -f /var/lib/pgsql/repmgr/repmgr.conf standby promote
|
repmgr -f /var/lib/pgsql/repmgr/repmgr.conf standby promote
|
||||||
|
|
||||||
Now the original primary, "node1" is acting again as primary.
|
Now the original primary, "node1", is acting again as primary.
|
||||||
|
|
||||||
Start the "node2" server and type this on "node1"::
|
Start the "node2" server and type this on "node2"::
|
||||||
|
|
||||||
repmgr standby clone --force -h node2 -p 5432 -U postgres -R postgres --verbose
|
repmgr standby clone --force -h node2 -p 5432 -U postgres -R postgres --verbose
|
||||||
|
|
||||||
Verify the roles have reversed by attempting to insert a record on "node"
|
Verify the roles have reversed by attempting to insert a record on "node1"
|
||||||
and on "node1".
|
and on "node2".
|
||||||
|
|
||||||
The servers are now again acting as primary on "node1" and standby on "node2".
|
The servers are now again acting as primary on "node1" and standby on "node2".
|
||||||
|
|
||||||
|
|||||||
18
debian/repmgr.repmgrd.default
vendored
18
debian/repmgr.repmgrd.default
vendored
@@ -1,14 +1,18 @@
|
|||||||
#!/bin/sh
|
|
||||||
# default settings for repmgrd. This file is source by /bin/sh from
|
# default settings for repmgrd. This file is source by /bin/sh from
|
||||||
# /etc/init.d/repmgrd
|
# /etc/init.d/repmgrd
|
||||||
|
|
||||||
# Options for repmgrd
|
# disable repmgrd by default so it won't get started upon installation
|
||||||
REPMGRD_OPTS=""
|
# valid values: yes/no
|
||||||
|
REPMGRD_ENABLED=no
|
||||||
|
|
||||||
|
# Options for repmgrd (required)
|
||||||
|
#REPMGRD_OPTS="--config_file /path/to/repmgr.conf"
|
||||||
|
|
||||||
|
# User to run repmgrd as
|
||||||
|
#REPMGRD_USER=postgres
|
||||||
|
|
||||||
# repmgrd binary
|
# repmgrd binary
|
||||||
REPMGR_BIN="/usr/bin/repmgr"
|
#REPMGR_BIN=/usr/bin/repmgr
|
||||||
|
|
||||||
# pid file
|
# pid file
|
||||||
REPMGR_PIDFILE="/var/run/repmgrd.pid"
|
#REPMGR_PIDFILE=/var/run/repmgrd.pid
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
115
debian/repmgr.repmgrd.init
vendored
115
debian/repmgr.repmgrd.init
vendored
@@ -1,48 +1,101 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
### BEGIN INIT INFO
|
### BEGIN INIT INFO
|
||||||
# Provides: repmgrd
|
# Provides: repmgrd
|
||||||
# Required-Start: $local_fs $remote_fs $network $syslog $postgresql
|
# Required-Start: $local_fs $remote_fs $network $syslog postgresql
|
||||||
# Required-Stop: $local_fs $remote_fs $network $syslog $postgresql
|
# Required-Stop: $local_fs $remote_fs $network $syslog postgresql
|
||||||
# Should-Start: $syslog $postgresql
|
# Should-Start: $syslog postgresql
|
||||||
# Should-Start: $syslog $postgresql
|
|
||||||
# Default-Start: 2 3 4 5
|
# Default-Start: 2 3 4 5
|
||||||
# Default-Stop: 0 1 6
|
# Default-Stop: 0 1 6
|
||||||
# Short-Description: Start/stop repmgrd
|
# Short-Description: Start/stop repmgrd
|
||||||
|
# Description: Enable repmgrd replication management and monitoring daemon for PostgreSQL
|
||||||
### END INIT INFO
|
### END INIT INFO
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
if test -f /etc/default/repmgrd; then
|
DESC="PostgreSQL replication management and monitoring daemon"
|
||||||
. /etc/default/repmgrd
|
NAME=repmgrd
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$REPMGRD_BIN" ]; then
|
REPMGRD_ENABLED=no
|
||||||
REPMGRD_BIN="/usr/bin/repmgrd"
|
REPMGRD_OPTS=
|
||||||
fi
|
REPMGRD_USER=postgres
|
||||||
|
REPMGRD_BIN=/usr/bin/repmgrd
|
||||||
|
REPMGRD_PIDFILE=/var/run/repmgrd.pid
|
||||||
|
|
||||||
if [ -z "$REPMGRD_PIDFILE" ]; then
|
# Read configuration variable file if it is present
|
||||||
REPMGRD_PIDFILE="/var/run/repmgrd.pid"
|
[ -r /etc/default/$NAME ] && . /etc/default/$NAME
|
||||||
fi
|
|
||||||
|
|
||||||
test -x $REPMGRD_BIN || exit 0
|
test -x $REPMGRD_BIN || exit 0
|
||||||
|
|
||||||
case "$1" in
|
case "$REPMGRD_ENABLED" in
|
||||||
start)
|
[Yy]*)
|
||||||
start-stop-daemon --start --quiet --make-pidfile --pidfile $REPMGRD_PIDFILE --exec $REPMGRD_BIN $REPMGRD_OPTS
|
break
|
||||||
;;
|
;;
|
||||||
|
|
||||||
stop)
|
|
||||||
start-stop-daemon --stop --oknodo --quiet --pidfile $REPMGRD_PIDFILE
|
|
||||||
;;
|
|
||||||
|
|
||||||
restart)
|
|
||||||
$0 stop && $0 start || exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
*)
|
||||||
echo "Usage: $0 {start|stop|restart}"
|
exit 0
|
||||||
exit 1
|
;;
|
||||||
;;
|
esac
|
||||||
|
|
||||||
|
# Define LSB log_* functions.
|
||||||
|
. /lib/lsb/init-functions
|
||||||
|
|
||||||
|
if [ -z "$REPMGRD_OPTS" ]
|
||||||
|
then
|
||||||
|
log_warning_msg "Not starting $NAME, REPMGRD_OPTS not set in /etc/default/$NAME"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
do_start()
|
||||||
|
{
|
||||||
|
# Return
|
||||||
|
# 0 if daemon has been started
|
||||||
|
# 1 if daemon was already running
|
||||||
|
# other if daemon could not be started or a failure occured
|
||||||
|
start-stop-daemon --start --quiet --chuid $REPMGRD_USER --make-pidfile --pidfile $REPMGRD_PIDFILE --exec $REPMGRD_BIN -- $REPMGRD_OPTS
|
||||||
|
}
|
||||||
|
|
||||||
|
do_stop()
|
||||||
|
{
|
||||||
|
# Return
|
||||||
|
# 0 if daemon has been stopped
|
||||||
|
# 1 if daemon was already stopped
|
||||||
|
# other if daemon could not be stopped or a failure occurred
|
||||||
|
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $REPMGRD_PIDFILE --exec $REPMGRD_BIN
|
||||||
|
}
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
start)
|
||||||
|
log_daemon_msg "Starting $DESC" "$NAME"
|
||||||
|
do_start
|
||||||
|
case "$?" in
|
||||||
|
0) log_end_msg 0 ;;
|
||||||
|
1) log_progress_msg "already started"
|
||||||
|
log_end_msg 0 ;;
|
||||||
|
*) log_end_msg 1 ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
;;
|
||||||
|
stop)
|
||||||
|
log_daemon_msg "Stopping $DESC" "$NAME"
|
||||||
|
do_stop
|
||||||
|
case "$?" in
|
||||||
|
0) log_end_msg 0 ;;
|
||||||
|
1) log_progress_msg "already stopped"
|
||||||
|
log_end_msg 0 ;;
|
||||||
|
*) log_end_msg 1 ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
;;
|
||||||
|
restart|force-reload)
|
||||||
|
$0 stop
|
||||||
|
$0 start
|
||||||
|
;;
|
||||||
|
status)
|
||||||
|
status_of_proc -p $PIDFILE $DAEMON $NAME && exit 0 || exit $?
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload|status}" >&2
|
||||||
|
exit 3
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
|||||||
9
log.c
9
log.c
@@ -144,7 +144,14 @@ bool logger_init(t_configuration_options *opts, const char* ident, const char* l
|
|||||||
|
|
||||||
if (*opts->logfile)
|
if (*opts->logfile)
|
||||||
{
|
{
|
||||||
freopen(opts->logfile, "a", stderr);
|
FILE *fd;
|
||||||
|
fd = freopen(opts->logfile, "a", stderr);
|
||||||
|
|
||||||
|
if (fd == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "error reopening stderr to '%s': %s",
|
||||||
|
opts->logfile, strerror(errno));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
1
repmgr.c
1
repmgr.c
@@ -1494,6 +1494,7 @@ do_standby_follow(void)
|
|||||||
*/
|
*/
|
||||||
strncpy(runtime_options.host, PQhost(master_conn), MAXLEN);
|
strncpy(runtime_options.host, PQhost(master_conn), MAXLEN);
|
||||||
strncpy(runtime_options.masterport, PQport(master_conn), MAXLEN);
|
strncpy(runtime_options.masterport, PQport(master_conn), MAXLEN);
|
||||||
|
strncpy(runtime_options.username, PQuser(master_conn), MAXLEN);
|
||||||
PQfinish(master_conn);
|
PQfinish(master_conn);
|
||||||
|
|
||||||
log_info(_("%s Changing standby's master\n"),progname);
|
log_info(_("%s Changing standby's master\n"),progname);
|
||||||
|
|||||||
51
repmgrd.c
51
repmgrd.c
@@ -179,6 +179,7 @@ main(int argc, char **argv)
|
|||||||
int optindex;
|
int optindex;
|
||||||
int c, ret;
|
int c, ret;
|
||||||
bool daemonize = false;
|
bool daemonize = false;
|
||||||
|
FILE *fd;
|
||||||
|
|
||||||
char standby_version[MAXVERSIONSTR], *ret_ver;
|
char standby_version[MAXVERSIONSTR], *ret_ver;
|
||||||
|
|
||||||
@@ -248,8 +249,19 @@ main(int argc, char **argv)
|
|||||||
terminate(ERR_BAD_CONFIG);
|
terminate(ERR_BAD_CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
freopen("/dev/null", "r", stdin);
|
fd = freopen("/dev/null", "r", stdin);
|
||||||
freopen("/dev/null", "w", stdout);
|
if (fd == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "error reopening stdin to '/dev/null': %s",
|
||||||
|
strerror(errno));
|
||||||
|
}
|
||||||
|
|
||||||
|
fd = freopen("/dev/null", "w", stdout);
|
||||||
|
if (fd == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "error reopening stdout to '/dev/null': %s",
|
||||||
|
strerror(errno));
|
||||||
|
}
|
||||||
|
|
||||||
logger_init(&local_options, progname, local_options.loglevel, local_options.logfacility);
|
logger_init(&local_options, progname, local_options.loglevel, local_options.logfacility);
|
||||||
if (verbose)
|
if (verbose)
|
||||||
@@ -257,7 +269,13 @@ main(int argc, char **argv)
|
|||||||
|
|
||||||
if (log_type == REPMGR_SYSLOG)
|
if (log_type == REPMGR_SYSLOG)
|
||||||
{
|
{
|
||||||
freopen("/dev/null", "w", stderr);
|
fd = freopen("/dev/null", "w", stderr);
|
||||||
|
|
||||||
|
if (fd == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "error reopening stderr to '/dev/null': %s",
|
||||||
|
strerror(errno));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(repmgr_schema, MAXLEN, "%s%s", DEFAULT_REPMGR_SCHEMA_PREFIX, local_options.cluster_name);
|
snprintf(repmgr_schema, MAXLEN, "%s%s", DEFAULT_REPMGR_SCHEMA_PREFIX, local_options.cluster_name);
|
||||||
@@ -365,7 +383,14 @@ main(int argc, char **argv)
|
|||||||
|
|
||||||
if (*local_options.logfile)
|
if (*local_options.logfile)
|
||||||
{
|
{
|
||||||
freopen(local_options.logfile, "a", stderr);
|
FILE *fd;
|
||||||
|
fd = freopen(local_options.logfile, "a", stderr);
|
||||||
|
if (fd == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "error reopening stderr to '%s': %s",
|
||||||
|
local_options.logfile, strerror(errno));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
update_registration();
|
update_registration();
|
||||||
@@ -1341,6 +1366,7 @@ do_daemonize()
|
|||||||
{
|
{
|
||||||
char *ptr, path[MAXLEN];
|
char *ptr, path[MAXLEN];
|
||||||
pid_t pid = fork();
|
pid_t pid = fork();
|
||||||
|
int ret;
|
||||||
|
|
||||||
switch (pid)
|
switch (pid)
|
||||||
{
|
{
|
||||||
@@ -1389,7 +1415,12 @@ do_daemonize()
|
|||||||
*path = '/';
|
*path = '/';
|
||||||
}
|
}
|
||||||
|
|
||||||
chdir(path);
|
ret = chdir(path);
|
||||||
|
if (ret != 0)
|
||||||
|
{
|
||||||
|
log_err("Error changing directory to '%s': %s", path,
|
||||||
|
strerror(errno));
|
||||||
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@@ -1405,6 +1436,7 @@ check_and_create_pid_file(const char *pid_file)
|
|||||||
FILE *fd;
|
FILE *fd;
|
||||||
char buff[MAXLEN];
|
char buff[MAXLEN];
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
|
size_t nread;
|
||||||
|
|
||||||
if (stat(pid_file, &st) != -1)
|
if (stat(pid_file, &st) != -1)
|
||||||
{
|
{
|
||||||
@@ -1418,7 +1450,14 @@ check_and_create_pid_file(const char *pid_file)
|
|||||||
exit(ERR_BAD_CONFIG);
|
exit(ERR_BAD_CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
fread(buff, MAXLEN - 1, 1, fd);
|
nread = fread(buff, MAXLEN - 1, 1, fd);
|
||||||
|
|
||||||
|
if (nread == 0 && ferror(fd))
|
||||||
|
{
|
||||||
|
log_err("Error reading PID file '%s', giving up...\n", pid_file);
|
||||||
|
exit(ERR_BAD_CONFIG);
|
||||||
|
}
|
||||||
|
|
||||||
fclose(fd);
|
fclose(fd);
|
||||||
|
|
||||||
pid = atoi(buff);
|
pid = atoi(buff);
|
||||||
|
|||||||
Reference in New Issue
Block a user