Slow down retries on Electrs errors in the main mempool loop.
This commit is contained in:
parent
2ba7cd9ebd
commit
49f70ca28a
@ -11,7 +11,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/mempool', { json: true, timeout: 10000 }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/mempool', { json: true, timeout: 10000 }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getMempoolInfo error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
@ -32,7 +32,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/mempool/txids', { json: true, timeout: 10000, forever: true }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/mempool/txids', { json: true, timeout: 10000, forever: true }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getRawMempool error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
@ -50,7 +50,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/tx/' + txId, { json: true, timeout: 10000, forever: true }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/tx/' + txId, { json: true, timeout: 10000, forever: true }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getRawTransaction error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
@ -68,7 +68,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/blocks/tip/height', { json: true, timeout: 10000 }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/blocks/tip/height', { json: true, timeout: 10000 }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getBlockHeightTip error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
@ -82,7 +82,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/block/' + hash + '/txids', { json: true, timeout: 10000 }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/block/' + hash + '/txids', { json: true, timeout: 10000 }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getTxIdsForBlock error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
@ -100,7 +100,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/block-height/' + height, { json: true, timeout: 10000 }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/block-height/' + height, { json: true, timeout: 10000 }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getBlockHash error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
@ -114,7 +114,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/blocks/' + height, { json: true, timeout: 10000 }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/blocks/' + height, { json: true, timeout: 10000 }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getBlocksFromHeight error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
@ -128,7 +128,7 @@ class ElectrsApi {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request(config.ELECTRS_API_URL + '/block/' + hash, { json: true, timeout: 10000 }, (err, res, response) => {
|
request(config.ELECTRS_API_URL + '/block/' + hash, { json: true, timeout: 10000 }, (err, res, response) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
reject(err);
|
reject('getBlock error: ' + err.message || err);
|
||||||
} else if (res.statusCode !== 200) {
|
} else if (res.statusCode !== 200) {
|
||||||
reject(response);
|
reject(response);
|
||||||
} else {
|
} else {
|
||||||
|
@ -25,8 +25,7 @@ class Blocks {
|
|||||||
this.newBlockCallbacks.push(fn);
|
this.newBlockCallbacks.push(fn);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async updateBlocks() {
|
public async $updateBlocks() {
|
||||||
try {
|
|
||||||
const blockHeightTip = await bitcoinApi.getBlockHeightTip();
|
const blockHeightTip = await bitcoinApi.getBlockHeightTip();
|
||||||
|
|
||||||
if (this.blocks.length === 0) {
|
if (this.blocks.length === 0) {
|
||||||
@ -100,10 +99,6 @@ class Blocks {
|
|||||||
this.newBlockCallbacks.forEach((cb) => cb(block, txIds, transactions));
|
this.newBlockCallbacks.forEach((cb) => cb(block, txIds, transactions));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (err) {
|
|
||||||
logger.err('updateBlocks error' + err);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public getLastDifficultyAdjustmentTime(): number {
|
public getLastDifficultyAdjustmentTime(): number {
|
||||||
|
@ -47,12 +47,8 @@ class Mempool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public async updateMemPoolInfo() {
|
public async $updateMemPoolInfo() {
|
||||||
try {
|
|
||||||
this.mempoolInfo = await bitcoinApi.getMempoolInfo();
|
this.mempoolInfo = await bitcoinApi.getMempoolInfo();
|
||||||
} catch (e) {
|
|
||||||
logger.err('Error getMempoolInfo ' + e.message || e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public getMempoolInfo(): MempoolInfo | undefined {
|
public getMempoolInfo(): MempoolInfo | undefined {
|
||||||
@ -93,13 +89,12 @@ class Mempool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public async updateMempool() {
|
public async $updateMempool() {
|
||||||
logger.debug('Updating mempool');
|
logger.debug('Updating mempool');
|
||||||
const start = new Date().getTime();
|
const start = new Date().getTime();
|
||||||
let hasChange: boolean = false;
|
let hasChange: boolean = false;
|
||||||
const currentMempoolSize = Object.keys(this.mempoolCache).length;
|
const currentMempoolSize = Object.keys(this.mempoolCache).length;
|
||||||
let txCount = 0;
|
let txCount = 0;
|
||||||
try {
|
|
||||||
const transactions = await bitcoinApi.getRawMempool();
|
const transactions = await bitcoinApi.getRawMempool();
|
||||||
const diff = transactions.length - currentMempoolSize;
|
const diff = transactions.length - currentMempoolSize;
|
||||||
const newTransactions: TransactionExtended[] = [];
|
const newTransactions: TransactionExtended[] = [];
|
||||||
@ -184,9 +179,6 @@ class Mempool {
|
|||||||
const time = end - start;
|
const time = end - start;
|
||||||
logger.debug(`New mempool size: ${Object.keys(newMempool).length} Change: ${diff}`);
|
logger.debug(`New mempool size: ${Object.keys(newMempool).length} Change: ${diff}`);
|
||||||
logger.debug('Mempool updated in ' + time / 1000 + ' seconds');
|
logger.debug('Mempool updated in ' + time / 1000 + ' seconds');
|
||||||
} catch (err) {
|
|
||||||
logger.err('getRawMempool error. ' + err.message || err);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private updateTxPerSecond() {
|
private updateTxPerSecond() {
|
||||||
|
@ -27,6 +27,7 @@ class Server {
|
|||||||
private wss: WebSocket.Server | undefined;
|
private wss: WebSocket.Server | undefined;
|
||||||
private server: https.Server | http.Server | undefined;
|
private server: https.Server | http.Server | undefined;
|
||||||
private app: Express;
|
private app: Express;
|
||||||
|
private retryOnElectrsErrorAfterSeconds = 5;
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
this.app = express();
|
this.app = express();
|
||||||
@ -114,10 +115,18 @@ class Server {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async runMempoolIntervalFunctions() {
|
async runMempoolIntervalFunctions() {
|
||||||
await memPool.updateMemPoolInfo();
|
try {
|
||||||
await blocks.updateBlocks();
|
await memPool.$updateMemPoolInfo();
|
||||||
await memPool.updateMempool();
|
await blocks.$updateBlocks();
|
||||||
|
await memPool.$updateMempool();
|
||||||
setTimeout(this.runMempoolIntervalFunctions.bind(this), config.ELECTRS_POLL_RATE_MS);
|
setTimeout(this.runMempoolIntervalFunctions.bind(this), config.ELECTRS_POLL_RATE_MS);
|
||||||
|
this.retryOnElectrsErrorAfterSeconds = 5;
|
||||||
|
} catch (e) {
|
||||||
|
this.retryOnElectrsErrorAfterSeconds *= 2;
|
||||||
|
this.retryOnElectrsErrorAfterSeconds = Math.min(this.retryOnElectrsErrorAfterSeconds, 3600);
|
||||||
|
logger.warn(`runMempoolIntervalFunctions error: ${(e.message || e)}. Retrying in ${this.retryOnElectrsErrorAfterSeconds} sec.`);
|
||||||
|
setTimeout(this.runMempoolIntervalFunctions.bind(this), 1000 * this.retryOnElectrsErrorAfterSeconds);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
setUpWebsocketHandling() {
|
setUpWebsocketHandling() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user