Browse Source

ckdb - complete the reload to the end of the log file

master
kanoi 10 years ago
parent
commit
6fb7879a7e
  1. 11
      src/ckdb.c
  2. 2
      src/ckdb.h

11
src/ckdb.c

@ -3883,7 +3883,7 @@ static bool reload_line(PGconn *conn, char *filename, uint64_t count, char *buf)
finished = true; finished = true;
ck_wunlock(&fpm_lock); ck_wunlock(&fpm_lock);
if (finished) { if (finished) {
LOGERR("%s() reload completed, ckpool queue match at line %"PRIu64, __func__, count); LOGERR("%s() reload ckpool queue match at line %"PRIu64, __func__, count);
return true; return true;
} }
@ -4101,7 +4101,12 @@ static bool reload_from(tv_t *start)
processing++; processing++;
count = 0; count = 0;
while (!everyone_die && !matched && /* Don't abort when matched since breakdown() will remove
* the matching message sequence numbers queued from ckpool
* Also since ckpool messages are not in order, we could be
* aborting early and not get the few slightly later out of
* order messages in the log file */
while (!everyone_die &&
logline(reload_buf, MAX_READ, fp, filename)) logline(reload_buf, MAX_READ, fp, filename))
matched = reload_line(conn, filename, ++count, reload_buf); matched = reload_line(conn, filename, ++count, reload_buf);
@ -4121,7 +4126,7 @@ static bool reload_from(tv_t *start)
} else } else
fclose(fp); fclose(fp);
free(filename); free(filename);
if (everyone_die || matched) if (everyone_die)
break; break;
reload_timestamp.tv_sec += ROLL_S; reload_timestamp.tv_sec += ROLL_S;
if (confirm_sharesummary && tv_newer(&confirm_finish, &reload_timestamp)) { if (confirm_sharesummary && tv_newer(&confirm_finish, &reload_timestamp)) {

2
src/ckdb.h

@ -55,7 +55,7 @@
#define DB_VLOCK "1" #define DB_VLOCK "1"
#define DB_VERSION "1.0.0" #define DB_VERSION "1.0.0"
#define CKDB_VERSION DB_VERSION"-1.071" #define CKDB_VERSION DB_VERSION"-1.072"
#define WHERE_FFL " - from %s %s() line %d" #define WHERE_FFL " - from %s %s() line %d"
#define WHERE_FFL_HERE __FILE__, __func__, __LINE__ #define WHERE_FFL_HERE __FILE__, __func__, __LINE__

Loading…
Cancel
Save