165 lines
4.3 KiB
JavaScript
165 lines
4.3 KiB
JavaScript
'use strict'
|
|
|
|
const IPFS = require('ipfs')
|
|
const IPFSRepo = require('ipfs-repo')
|
|
const DatastoreLevel = require('datastore-level')
|
|
const OrbitDB = require('../src/OrbitDB')
|
|
const startIpfs = require('../test/utils/start-ipfs')
|
|
const pMapSeries = require('p-map-series')
|
|
|
|
// Metrics
|
|
let metrics1 = {
|
|
totalQueries: 0,
|
|
seconds: 0,
|
|
queriesPerSecond: 0,
|
|
lastTenSeconds: 0,
|
|
}
|
|
|
|
let metrics2 = {
|
|
totalQueries: 0,
|
|
seconds: 0,
|
|
queriesPerSecond: 0,
|
|
lastTenSeconds: 0,
|
|
}
|
|
|
|
const ipfsConf = {
|
|
Addresses: {
|
|
API: '/ip4/127.0.0.1/tcp/0',
|
|
Swarm: ['/ip4/0.0.0.0/tcp/0'],
|
|
Gateway: '/ip4/0.0.0.0/tcp/0'
|
|
},
|
|
Bootstrap: [],
|
|
Discovery: {
|
|
MDNS: {
|
|
Enabled: true,
|
|
Interval: 1
|
|
},
|
|
},
|
|
}
|
|
|
|
const repoConf = {
|
|
storageBackends: {
|
|
blocks: DatastoreLevel,
|
|
},
|
|
}
|
|
|
|
const defaultConfig = Object.assign({}, {
|
|
start: true,
|
|
EXPERIMENTAL: {
|
|
pubsub: true,
|
|
sharding: false,
|
|
dht: false,
|
|
},
|
|
config: ipfsConf
|
|
})
|
|
|
|
const conf1 = Object.assign({}, defaultConfig, {
|
|
repo: new IPFSRepo('./orbitdb/benchmarks/replication/client1/ipfs', repoConf)
|
|
})
|
|
|
|
const conf2 = Object.assign({}, defaultConfig, {
|
|
repo: new IPFSRepo('./orbitdb/benchmarks/replication/client2/ipfs', repoConf)
|
|
})
|
|
|
|
// Write loop
|
|
const queryLoop = async (db) => {
|
|
if (metrics1.totalQueries < updateCount) {
|
|
try {
|
|
await db.add(metrics1.totalQueries)
|
|
} catch (e) {
|
|
console.error("!!", e)
|
|
}
|
|
metrics1.totalQueries ++
|
|
metrics1.lastTenSeconds ++
|
|
metrics1.queriesPerSecond ++
|
|
setImmediate(() => queryLoop(db))
|
|
}
|
|
}
|
|
|
|
// Metrics output function
|
|
const outputMetrics = (name, db, metrics) => {
|
|
metrics.seconds ++
|
|
console.log(`[${name}] ${metrics.queriesPerSecond} queries per second, ${metrics.totalQueries} queries in ${metrics.seconds} seconds (Oplog: ${db._oplog.length})`)
|
|
metrics.queriesPerSecond = 0
|
|
|
|
if(metrics.seconds % 10 === 0) {
|
|
console.log(`[${name}] --> Average of ${metrics.lastTenSeconds/10} q/s in the last 10 seconds`)
|
|
metrics.lastTenSeconds = 0
|
|
}
|
|
}
|
|
|
|
const database = 'benchmark-replication'
|
|
const updateCount = 2000
|
|
|
|
// Start
|
|
console.log("Starting IPFS daemons...")
|
|
|
|
pMapSeries([conf1, conf2], d => startIpfs(d))
|
|
.then(async ([ipfs1, ipfs2]) => {
|
|
try {
|
|
await ipfs2.swarm.connect(ipfs1._peerInfo.multiaddrs._multiaddrs[0].toString())
|
|
await ipfs1.swarm.connect(ipfs2._peerInfo.multiaddrs._multiaddrs[0].toString())
|
|
|
|
// Create the databases
|
|
const orbit1 = new OrbitDB(ipfs1, './orbitdb/benchmarks/replication/client1')
|
|
const orbit2 = new OrbitDB(ipfs2, './orbitdb/benchmarks/replication/client2')
|
|
const db1 = await orbit1.eventlog(database, { overwrite: true })
|
|
const db2 = await orbit2.eventlog(db1.address.toString())
|
|
|
|
let db1Connected = false
|
|
let db2Connected = false
|
|
|
|
console.log('Waiting for peers to connect...')
|
|
|
|
db1.events.on('peer', () => {
|
|
db1Connected = true
|
|
console.log('Peer 1 connected')
|
|
})
|
|
|
|
db2.events.on('peer', () => {
|
|
db2Connected = true
|
|
console.log('Peer 2 connected')
|
|
})
|
|
|
|
const startInterval = setInterval(() => {
|
|
if (db1Connected && db2Connected) {
|
|
clearInterval(startInterval)
|
|
// Start the write loop
|
|
queryLoop(db1)
|
|
|
|
// Metrics output for the writer, once/sec
|
|
const writeInterval = setInterval(() => {
|
|
outputMetrics("WRITE", db1, metrics1)
|
|
if (metrics1.totalQueries === updateCount) {
|
|
clearInterval(writeInterval)
|
|
}
|
|
}, 1000)
|
|
|
|
// Metrics output for the reader
|
|
let prevCount = 0
|
|
setInterval(() => {
|
|
try {
|
|
const result = db2.iterator({ limit: -1 }).collect()
|
|
metrics2.totalQueries = result.length
|
|
metrics2.queriesPerSecond = metrics2.totalQueries - prevCount
|
|
metrics2.lastTenSeconds += metrics2.queriesPerSecond
|
|
prevCount = metrics2.totalQueries
|
|
|
|
outputMetrics("READ", db2, metrics2)
|
|
|
|
if (db2._oplog.length === updateCount) {
|
|
console.log("Finished")
|
|
process.exit(0)
|
|
}
|
|
} catch (e) {
|
|
console.error("!", e)
|
|
}
|
|
}, 1000)
|
|
}
|
|
}, 100)
|
|
} catch (e) {
|
|
console.log(e)
|
|
process.exit(1)
|
|
}
|
|
})
|