2023-07-31 14:34:36 +02:00
|
|
|
import { wait } from '@peertube/peertube-core-utils'
|
2022-06-17 10:49:37 +02:00
|
|
|
import {
|
|
|
|
createSingleServer,
|
|
|
|
doubleFollow,
|
|
|
|
killallServers,
|
|
|
|
PeerTubeServer,
|
|
|
|
setAccessTokensToServers,
|
|
|
|
waitJobs
|
2023-07-31 14:34:36 +02:00
|
|
|
} from '@peertube/peertube-server-commands'
|
2024-02-29 10:09:03 +01:00
|
|
|
import { isMainThread } from 'worker_threads'
|
|
|
|
import Piscina from 'piscina'
|
|
|
|
import { fileURLToPath } from 'url'
|
|
|
|
import { dirname, join } from 'path'
|
|
|
|
|
|
|
|
const THOUSAND_VIEWERS = 2
|
|
|
|
const TOTAL_THREADS = 20
|
2022-06-17 10:48:37 +02:00
|
|
|
|
|
|
|
let servers: PeerTubeServer[]
|
|
|
|
const viewers: { xForwardedFor: string }[] = []
|
|
|
|
let videoId: string
|
2024-02-29 10:09:03 +01:00
|
|
|
let pool: Piscina
|
|
|
|
|
|
|
|
if (isMainThread) {
|
|
|
|
run()
|
|
|
|
.then(() => process.exit(0))
|
|
|
|
.catch(err => console.error(err))
|
|
|
|
.finally(() => killallServers(servers))
|
|
|
|
}
|
2022-06-17 10:48:37 +02:00
|
|
|
|
2024-02-29 10:09:03 +01:00
|
|
|
// ---------------------------------------------------------------------------
|
2022-06-17 10:48:37 +02:00
|
|
|
|
|
|
|
async function run () {
|
|
|
|
await prepare()
|
|
|
|
|
|
|
|
while (true) {
|
|
|
|
await runViewers()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function prepare () {
|
2024-02-29 10:09:03 +01:00
|
|
|
pool = new Piscina({
|
|
|
|
filename: join(dirname(fileURLToPath(import.meta.url)), 'simulate-many-viewers-worker.js'),
|
|
|
|
minThreads: 20,
|
|
|
|
maxThreads: 20
|
|
|
|
})
|
|
|
|
|
2022-06-17 10:48:37 +02:00
|
|
|
console.log('Preparing servers...')
|
|
|
|
|
|
|
|
const config = {
|
|
|
|
log: {
|
2023-10-26 12:30:34 +02:00
|
|
|
level: 'info',
|
|
|
|
log_http_requests: false
|
2022-06-17 10:48:37 +02:00
|
|
|
},
|
|
|
|
rates_limit: {
|
|
|
|
api: {
|
|
|
|
max: 5_000_000
|
|
|
|
}
|
|
|
|
},
|
|
|
|
views: {
|
|
|
|
videos: {
|
|
|
|
local_buffer_update_interval: '30 minutes',
|
|
|
|
ip_view_expiration: '1 hour'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-17 14:34:37 +02:00
|
|
|
const env = { PRODUCTION_CONSTANTS: 'true' }
|
|
|
|
|
2022-06-17 10:48:37 +02:00
|
|
|
servers = await Promise.all([
|
2022-06-17 14:34:37 +02:00
|
|
|
createSingleServer(1, config, { env, nodeArgs: [ '--inspect' ] }),
|
|
|
|
createSingleServer(2, config, { env }),
|
|
|
|
createSingleServer(3, config, { env })
|
2022-06-17 10:48:37 +02:00
|
|
|
])
|
|
|
|
|
|
|
|
await setAccessTokensToServers(servers)
|
|
|
|
await doubleFollow(servers[0], servers[1])
|
|
|
|
await doubleFollow(servers[0], servers[2])
|
|
|
|
|
|
|
|
const { uuid } = await servers[0].videos.quickUpload({ name: 'video' })
|
|
|
|
videoId = uuid
|
|
|
|
|
|
|
|
await waitJobs(servers)
|
|
|
|
|
|
|
|
for (let i = 2; i < 252; i++) {
|
|
|
|
for (let j = 2; j < 6; j++) {
|
|
|
|
for (let k = 2; k < THOUSAND_VIEWERS + 2; k++) {
|
|
|
|
viewers.push({ xForwardedFor: `0.${k}.${j}.${i},127.0.0.1` })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log('Servers preparation finished.')
|
|
|
|
}
|
|
|
|
|
|
|
|
async function runViewers () {
|
|
|
|
console.log('Will run views of %d viewers.', viewers.length)
|
|
|
|
|
2022-06-17 10:49:37 +02:00
|
|
|
const before = new Date().getTime()
|
|
|
|
|
2024-02-29 10:09:03 +01:00
|
|
|
const promises: Promise<any>[] = []
|
|
|
|
|
|
|
|
for (let i = 0; i < TOTAL_THREADS; i++) {
|
|
|
|
const start = i * THOUSAND_VIEWERS * 1000 / TOTAL_THREADS
|
|
|
|
const end = (i + 1) * THOUSAND_VIEWERS * 1000 / TOTAL_THREADS
|
|
|
|
|
|
|
|
console.log(`Sending viewers ${start} to ${end}`)
|
|
|
|
|
|
|
|
promises.push(pool.run({ url: servers[0].url, viewers: viewers.slice(start, end), videoId }))
|
|
|
|
}
|
|
|
|
|
|
|
|
await Promise.all(promises)
|
2022-06-17 10:48:37 +02:00
|
|
|
|
2022-06-17 10:49:37 +02:00
|
|
|
console.log('Finished to run views in %d seconds.', (new Date().getTime() - before) / 1000)
|
|
|
|
|
2022-06-17 10:48:37 +02:00
|
|
|
await wait(5000)
|
|
|
|
}
|