├── .gitignore ├── Dockerfile ├── cli.js ├── create ├── create.js ├── createIndex.js ├── createMany.js └── createManyIndex.js ├── docker-compose.dev.yml ├── docker-compose.yml ├── find ├── idIndex.js ├── read.js └── textIndex.js ├── find2 ├── idIndex.js ├── mongo-create.js ├── mongoose-create.js └── textIndex.js ├── findOne ├── read.js ├── readID.js └── textIndex.js ├── index.js ├── join └── join.js ├── package-lock.json ├── package.json └── run.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:14-alpine 2 | WORKDIR /home/comparisons 3 | COPY package.json package.json 4 | RUN npm i 5 | WORKDIR /home/comparisons/suites 6 | COPY . . 7 | -------------------------------------------------------------------------------- /cli.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | const args = process.argv.slice(2) 3 | const run = require('./index.js') 4 | run(args) -------------------------------------------------------------------------------- /create/create.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | var mongodbCollectionName='testrecord1' 4 | var mongooseCollectionName='testrecord2' 5 | 6 | var mongoose = require('mongoose') 7 | const MongoClient = require('mongodb').MongoClient; 8 | var record = { 9 | name: 'bugwheels', 10 | interest: 'Not Many', 11 | job: 'Useless' 12 | } 13 | Promise.all([ 14 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 15 | MongoClient.connect('mongodb://talknonymous.local:27017') 16 | ]).then((clients) => { 17 | var db = mongoose.connection; 18 | var Schema = mongoose.Schema; 19 | var recordSchema = new Schema({ 20 | name: String, 21 | interest: String, 22 | job: String 23 | }); 24 | var recordModel = mongoose.model(mongooseCollectionName, recordSchema); 25 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection(mongodbCollectionName) 26 | suite 27 | .add('Mongoose', { 28 | defer: true, 29 | fn: function(def) { 30 | new recordModel(record).save(() => { 31 | def.resolve() 32 | }) 33 | } 34 | }) 35 | .add('MongoDB', { 36 | defer: true, 37 | fn: function(def) { 38 | nativeCollection.insert(record, (e, r) => { 39 | def.resolve(); 40 | // console.log(r) 41 | }) 42 | } 43 | }) 44 | .on('cycle', function(event) { 45 | console.log(String(event.target)); 46 | }) 47 | .on('complete', function() { 48 | nativeCollection.drop(); 49 | db.dropCollection(mongooseCollectionName); 50 | console.log('Fastest is ' + this.filter('fastest').map('name')); 51 | }) 52 | .run({ 'async': true }); 53 | 54 | 55 | }) 56 | -------------------------------------------------------------------------------- /create/createIndex.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | var mongodbCollectionName='testrecord1' 4 | var mongooseCollectionName='testrecord2' 5 | 6 | var mongoose = require('mongoose') 7 | const MongoClient = require('mongodb').MongoClient; 8 | var record = { 9 | name: 'bugwheels', 10 | interest: 'Not Many', 11 | job: 'Useless' 12 | } 13 | Promise.all([ 14 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 15 | MongoClient.connect('mongodb://talknonymous.local:27017') 16 | ]).then((clients) => { 17 | var db = mongoose.connection; 18 | var Schema = mongoose.Schema; 19 | var recordSchema = new Schema({ 20 | name: String, 21 | interest: String, 22 | job: String 23 | }); 24 | recordSchema.path('name').index({text: true}) 25 | var recordModel = mongoose.model(mongooseCollectionName, recordSchema); 26 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection(mongodbCollectionName) 27 | suite 28 | .add('Mongoose', { 29 | defer: true, 30 | fn: function(def) { 31 | new recordModel(record).save(() => { 32 | def.resolve() 33 | }) 34 | } 35 | }) 36 | .add('MongoDB', { 37 | defer: true, 38 | fn: function(def) { 39 | nativeCollection.insert(record, (e, r) => { 40 | def.resolve(); 41 | // console.log(r) 42 | }) 43 | } 44 | }) 45 | .on('cycle', function(event) { 46 | console.log(String(event.target)); 47 | }) 48 | .on('complete', function() { 49 | nativeCollection.drop(); 50 | db.dropCollection(mongooseCollectionName); 51 | console.log('Fastest is ' + this.filter('fastest').map('name')); 52 | }) 53 | .run({ 'async': true }); 54 | 55 | 56 | }) 57 | -------------------------------------------------------------------------------- /create/createMany.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | var collectionMongoose = 'testrecord1'; 7 | var collectionMongodb = 'testrecord2'; 8 | Promise.all([ 9 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 10 | MongoClient.connect('mongodb://talknonymous.local:27017') 11 | ]).then((clients) => { 12 | var db = mongoose.connection; 13 | var Schema = mongoose.Schema; 14 | var recordSchema = new Schema({ 15 | name: String, 16 | interest: String, 17 | job: String 18 | }); 19 | var recordModel = mongoose.model(collectionMongoose, recordSchema); 20 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection(collectionMongodb) 21 | suite 22 | .add('Mongoose', { 23 | defer: true, 24 | fn: function(def) { 25 | var records = []; 26 | for (var i = 0; i < 100; i++) { 27 | records.push({ 28 | name: 'bugwheels' + i, 29 | interest: 'Not Many', 30 | job: 'Useless' 31 | }) 32 | } 33 | recordModel.insertMany(records,() => { 34 | def.resolve() 35 | }) 36 | } 37 | }) 38 | .add('MongoDB', { 39 | defer: true, 40 | fn: function(def) { 41 | var records = []; 42 | for (var i = 0; i < 100; i++) { 43 | records.push({ 44 | name: 'bugwheels' + i, 45 | interest: 'Not Many', 46 | job: 'Useless' 47 | }) 48 | } 49 | nativeCollection.insertMany(records, (e, r) => { 50 | def.resolve(); 51 | // console.log(r) 52 | }) 53 | } 54 | }) 55 | .on('cycle', function(event) { 56 | console.log(String(event.target)); 57 | }) 58 | .on('complete', function() { 59 | console.log('Fastest is ' + this.filter('fastest').map('name')); 60 | // nativeCollection.drop() 61 | // db.dropCollection(collectionMongoose) 62 | }) 63 | .run({ 'async': true }); 64 | 65 | 66 | }) 67 | -------------------------------------------------------------------------------- /create/createManyIndex.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | var collectionMongoose = 'testrecord1'; 7 | var collectionMongodb = 'testrecord2'; 8 | Promise.all([ 9 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 10 | MongoClient.connect('mongodb://talknonymous.local:27017') 11 | ]).then((clients) => { 12 | var db = mongoose.connection; 13 | var Schema = mongoose.Schema; 14 | var recordSchema = new Schema({ 15 | name: String, 16 | interest: String, 17 | job: String 18 | }); 19 | recordSchema.path('name').index({text: true}) 20 | var recordModel = mongoose.model(collectionMongoose, recordSchema); 21 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection(collectionMongodb) 22 | suite 23 | .add('Mongoose', { 24 | defer: true, 25 | fn: function(def) { 26 | var records = []; 27 | for (var i = 0; i < 100; i++) { 28 | records.push({ 29 | name: 'bugwheels' + i, 30 | interest: 'Not Many', 31 | job: 'Useless' 32 | }) 33 | } 34 | recordModel.insertMany(records,() => { 35 | def.resolve() 36 | }) 37 | } 38 | }) 39 | .add('MongoDB', { 40 | defer: true, 41 | fn: function(def) { 42 | var records = []; 43 | for (var i = 0; i < 100; i++) { 44 | records.push({ 45 | name: 'bugwheels' + i, 46 | interest: 'Not Many', 47 | job: 'Useless' 48 | }) 49 | } 50 | nativeCollection.insertMany(records, (e, r) => { 51 | def.resolve(); 52 | // console.log(r) 53 | }) 54 | } 55 | }) 56 | .on('cycle', function(event) { 57 | console.log(String(event.target)); 58 | }) 59 | .on('complete', function() { 60 | console.log('Fastest is ' + this.filter('fastest').map('name')); 61 | nativeCollection.drop() 62 | db.dropCollection(collectionMongoose) 63 | }) 64 | .run({ 'async': true }); 65 | 66 | 67 | }) 68 | -------------------------------------------------------------------------------- /docker-compose.dev.yml: -------------------------------------------------------------------------------- 1 | version: '3.1' 2 | services: 3 | task-1: 4 | build: 5 | context: . 6 | dockerfile: ./Dockerfile 7 | volumes: 8 | - .:/home/comparisons/suites 9 | task-2: 10 | build: 11 | context: . 12 | dockerfile: ./Dockerfile 13 | volumes: 14 | - .:/home/comparisons/suites 15 | -------------------------------------------------------------------------------- /docker-compose.yml: -------------------------------------------------------------------------------- 1 | version: '3.1' 2 | services: 3 | task-1: 4 | command: "node /home/comparisons/suites/find2/mongo-create.js" 5 | # command: "tail -F anything" 6 | labels: 7 | name: "MONGODB WRITE" 8 | image: bugwheels94/comparisons:mongo-vs-mongoose 9 | environment: 10 | - OPERATIONS 11 | depends_on: 12 | - mongo 13 | task-2: 14 | command: "node /home/comparisons/suites/find2/mongoose-create.js" 15 | # command: "tail -F anything" 16 | labels: 17 | name: "MONGOOSE WRITE" 18 | environment: 19 | - OPERATIONS 20 | image: bugwheels94/comparisons:mongo-vs-mongoose 21 | depends_on: 22 | - mongo 23 | mongo: 24 | image: "mvertes/alpine-mongo" 25 | -------------------------------------------------------------------------------- /find/idIndex.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String, 16 | subrecord: { type: Schema.Types.ObjectId, ref: 'subrecords' } 17 | }); 18 | var subRecordSchema = new Schema({ 19 | name: String, 20 | interest: String, 21 | job: String 22 | }); 23 | var subrecordModel = mongoose.model('subrecords', subRecordSchema); 24 | var recordModel = mongoose.model('records', recordSchema); 25 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 26 | suite 27 | .add('Mongoose', { 28 | defer: true, 29 | fn: function(def) { 30 | recordModel.find({_id: "5a9cf6860acccf5de0cf948a"}).exec().then(function (e) { 31 | def.resolve(); 32 | }); 33 | } 34 | }) 35 | .add('MongoDB', { 36 | defer: true, 37 | fn: function(def) { 38 | nativeCollection.find({_id: "5a9cf6860acccf5de0cf948a"}).toArray((r) => { 39 | def.resolve(); 40 | // console.log(r) 41 | }) 42 | } 43 | }) 44 | .on('cycle', function(event) { 45 | console.log(String(event.target)); 46 | }) 47 | .on('complete', function() { 48 | console.log('Fastest is ' + this.filter('fastest').map('name')); 49 | }) 50 | .run({ 'async': true }); 51 | 52 | 53 | }) 54 | -------------------------------------------------------------------------------- /find/read.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | var mongoose = require('mongoose') 4 | const MongoClient = require('mongodb').MongoClient; 5 | Promise.all([ 6 | mongoose.connect('mongodb://mongo:27017/mongoose-vs-mongodb'), 7 | MongoClient.connect('mongodb://mongo:27017') 8 | ]).then((clients) => { 9 | var db = mongoose.connection; 10 | var Schema = mongoose.Schema; 11 | var recordSchema = new Schema({ 12 | name: String, 13 | interest: String, 14 | job: String 15 | }); 16 | var recordModel = mongoose.model('records', recordSchema); 17 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 18 | suite 19 | .add('Mongoose', { 20 | defer: true, 21 | fn: function(def) { 22 | recordModel.find({name: "buwheels500000"}).exec().then(function (e) { 23 | def.resolve(); 24 | }); 25 | } 26 | }) 27 | .add('MongoDB', { 28 | defer: true, 29 | fn: function(def) { 30 | nativeCollection.find({name: 'buwheels500000'}).forEach((e, r) => { 31 | def.resolve(); 32 | // console.log(r)0 33 | }) 34 | } 35 | }) 36 | .on('cycle', function(event) { 37 | console.log(String(event.target)); 38 | }) 39 | .on('complete', function() { 40 | console.log('Fastest is ' + this.filter('fastest').map('name')); 41 | }) 42 | .run({ 'async': true }); 43 | 44 | 45 | }) 46 | -------------------------------------------------------------------------------- /find/textIndex.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String 16 | }); 17 | recordSchema.path('name').index({text: true}) 18 | var recordModel = mongoose.model('records', recordSchema); 19 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 20 | suite 21 | .add('Mongoose', { 22 | defer: true, 23 | fn: function(def) { 24 | recordModel.find({$text :{ $search: "bugwheels90544"}}).exec().then(function (e) { 25 | def.resolve(); 26 | }); 27 | } 28 | }) 29 | .add('MongoDB', { 30 | defer: true, 31 | fn: function(def) { 32 | nativeCollection.find({name: {$text :{ $search: 'bugwheels90544'}}}).toArray((r) => { 33 | def.resolve(); 34 | // console.log(r) 35 | }) 36 | } 37 | }) 38 | .on('cycle', function(event) { 39 | console.log(String(event.target)); 40 | }) 41 | .on('complete', function() { 42 | console.log('Fastest is ' + this.filter('fastest').map('name')); 43 | }) 44 | .run({ 'async': true }); 45 | 46 | 47 | }) 48 | -------------------------------------------------------------------------------- /find2/idIndex.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String, 16 | subrecord: { type: Schema.Types.ObjectId, ref: 'subrecords' } 17 | }); 18 | var subRecordSchema = new Schema({ 19 | name: String, 20 | interest: String, 21 | job: String 22 | }); 23 | var subrecordModel = mongoose.model('subrecords', subRecordSchema); 24 | var recordModel = mongoose.model('records', recordSchema); 25 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 26 | suite 27 | .add('Mongoose', { 28 | defer: true, 29 | fn: function(def) { 30 | recordModel.find({_id: "5a9cf6860acccf5de0cf948a"}).exec().then(function (e) { 31 | def.resolve(); 32 | }); 33 | } 34 | }) 35 | .add('MongoDB', { 36 | defer: true, 37 | fn: function(def) { 38 | nativeCollection.find({_id: "5a9cf6860acccf5de0cf948a"}).toArray((r) => { 39 | def.resolve(); 40 | // console.log(r) 41 | }) 42 | } 43 | }) 44 | .on('cycle', function(event) { 45 | console.log(String(event.target)); 46 | }) 47 | .on('complete', function() { 48 | console.log('Fastest is ' + this.filter('fastest').map('name')); 49 | }) 50 | .run({ 'async': true }); 51 | 52 | 53 | }) 54 | -------------------------------------------------------------------------------- /find2/mongo-create.js: -------------------------------------------------------------------------------- 1 | const ops = Number(process.env.OPERATIONS) 2 | const MongoClient = require('mongodb').MongoClient; 3 | const promise = []; 4 | MongoClient.connect('mongodb://mongo:27017', {useUnifiedTopology: true}) 5 | .then((client) => { 6 | 7 | var nativeCollection = client.db('mongoose-vs-mongodb').collection('records') 8 | for (let i = 0; i < ops; i++) 9 | promise.push(nativeCollection.insertOne({ 10 | name: 'bugwheels', 11 | interest: 'Not Many', 12 | job: 'Useless' 13 | })) 14 | Promise.all(promise).then(() => { 15 | client.close() 16 | console.log("Done"); 17 | }) 18 | }) 19 | -------------------------------------------------------------------------------- /find2/mongoose-create.js: -------------------------------------------------------------------------------- 1 | const ops = Number(process.env.OPERATIONS) 2 | var mongooseCollectionName='testrecord2' 3 | var mongoose = require('mongoose') 4 | var record = { 5 | name: 'bugwheels', 6 | interest: 'Not Many', 7 | job: 'Useless' 8 | } 9 | mongoose.connect('mongodb://mongo:27017/mongoose-vs-mongodb', { useNewUrlParser: true, useUnifiedTopology: true }) 10 | .then((client) => { 11 | var db = mongoose.connection; 12 | var Schema = mongoose.Schema; 13 | var recordSchema = new Schema({ 14 | name: String, 15 | interest: String, 16 | job: String 17 | }); 18 | var recordModel = mongoose.model(mongooseCollectionName, recordSchema); 19 | const promise = [] 20 | for (let i = 0; i < ops; i++) 21 | promise.push(new recordModel(record).save()) 22 | Promise.all(promise).then(() => { 23 | db.close() 24 | console.log("Mongoose Done"); 25 | }) 26 | 27 | 28 | }) 29 | -------------------------------------------------------------------------------- /find2/textIndex.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String 16 | }); 17 | recordSchema.path('name').index({text: true}) 18 | var recordModel = mongoose.model('records', recordSchema); 19 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 20 | suite 21 | .add('Mongoose', { 22 | defer: true, 23 | fn: function(def) { 24 | recordModel.find({$text :{ $search: "bugwheels90544"}}).exec().then(function (e) { 25 | def.resolve(); 26 | }); 27 | } 28 | }) 29 | .add('MongoDB', { 30 | defer: true, 31 | fn: function(def) { 32 | nativeCollection.find({name: {$text :{ $search: 'bugwheels90544'}}}).toArray((r) => { 33 | def.resolve(); 34 | // console.log(r) 35 | }) 36 | } 37 | }) 38 | .on('cycle', function(event) { 39 | console.log(String(event.target)); 40 | }) 41 | .on('complete', function() { 42 | console.log('Fastest is ' + this.filter('fastest').map('name')); 43 | }) 44 | .run({ 'async': true }); 45 | 46 | 47 | }) 48 | -------------------------------------------------------------------------------- /findOne/read.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String 16 | }); 17 | var recordModel = mongoose.model('records', recordSchema); 18 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 19 | suite 20 | .add('Mongoose', { 21 | defer: true, 22 | fn: function(def) { 23 | recordModel.findOne({name: "bugwheels90544"}).exec().then(function (e) { 24 | def.resolve(); 25 | }); 26 | } 27 | }) 28 | .add('MongoDB', { 29 | defer: true, 30 | fn: function(def) { 31 | nativeCollection.findOne({name: 'bugwheels90544'}, null, (e, r) => { 32 | def.resolve(); 33 | // console.log(r) 34 | }) 35 | } 36 | }) 37 | .on('cycle', function(event) { 38 | console.log(String(event.target)); 39 | }) 40 | .on('complete', function() { 41 | console.log('Fastest is ' + this.filter('fastest').map('name')); 42 | }) 43 | .run({ 'async': true }); 44 | 45 | 46 | }) 47 | -------------------------------------------------------------------------------- /findOne/readID.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String 16 | }); 17 | var recordModel = mongoose.model('records', recordSchema); 18 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 19 | suite 20 | .add('Mongoose', { 21 | defer: true, 22 | fn: function(def) { 23 | recordModel.findOne({_id: "5a9cf6860acccf5de0cf948a"}).exec().then(function (e) { 24 | def.resolve(); 25 | }); 26 | } 27 | }) 28 | .add('MongoDB', { 29 | defer: true, 30 | fn: function(def) { 31 | nativeCollection.findOne({_id: "5a9cf6860acccf5de0cf948a"}, (e, r) => { 32 | def.resolve(); 33 | // console.log(r) 34 | }) 35 | } 36 | }) 37 | .on('cycle', function(event) { 38 | console.log(String(event.target)); 39 | }) 40 | .on('complete', function() { 41 | console.log('Fastest is ' + this.filter('fastest').map('name')); 42 | }) 43 | .run({ 'async': true }); 44 | 45 | 46 | }) 47 | -------------------------------------------------------------------------------- /findOne/textIndex.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String 16 | }); 17 | recordSchema.path('name').index({text: true}) 18 | var recordModel = mongoose.model('records', recordSchema); 19 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 20 | suite 21 | .add('Mongoose', { 22 | defer: true, 23 | fn: function(def) { 24 | recordModel.findOne({$text :{ $search: "buwheels500000"}}).exec().then(function (e) { 25 | def.resolve(); 26 | }); 27 | } 28 | }) 29 | .add('MongoDB', { 30 | defer: true, 31 | fn: function(def) { 32 | nativeCollection.findOne({name: {$text :{ $search: 'bugwheels500000'}}}, null, (e, r) => { 33 | def.resolve(); 34 | // console.log(r) 35 | }) 36 | } 37 | }) 38 | .on('cycle', function(event) { 39 | console.log(String(event.target)); 40 | }) 41 | .on('complete', function() { 42 | console.log('Fastest is ' + this.filter('fastest').map('name')); 43 | }) 44 | .run({ 'async': true }); 45 | 46 | 47 | }) 48 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bugwheels94/mongoose-vs-mongodb/a4651eabeb0a8363b36cbae268da66bed902cb93/index.js -------------------------------------------------------------------------------- /join/join.js: -------------------------------------------------------------------------------- 1 | var Benchmark = require('benchmark'); 2 | var suite = new Benchmark.Suite; 3 | 4 | var mongoose = require('mongoose') 5 | const MongoClient = require('mongodb').MongoClient; 6 | Promise.all([ 7 | mongoose.connect('mongodb://talknonymous.local:27017/mongoose-vs-mongodb'), 8 | MongoClient.connect('mongodb://talknonymous.local:27017') 9 | ]).then((clients) => { 10 | var db = mongoose.connection; 11 | var Schema = mongoose.Schema; 12 | var recordSchema = new Schema({ 13 | name: String, 14 | interest: String, 15 | job: String, 16 | subrecord: { type: Schema.Types.ObjectId, ref: 'subrecords' } 17 | }); 18 | var subRecordSchema = new Schema({ 19 | name: String, 20 | interest: String, 21 | job: String 22 | }); 23 | var subrecordModel = mongoose.model('subrecords', subRecordSchema); 24 | var recordModel = mongoose.model('records', recordSchema); 25 | var nativeCollection = clients[1].db('mongoose-vs-mongodb').collection('records') 26 | var s = [{ 27 | $match: { 28 | 'name': 'buwheelsx0' 29 | } 30 | },{ 31 | $lookup: { 32 | from: "subrecords", 33 | localField: "subrecord", 34 | foreignField: "_id", 35 | as: "newsub" 36 | } 37 | }] 38 | suite 39 | .add('MongoDB', { 40 | defer: true, 41 | fn: function(def) { 42 | nativeCollection.aggregate(s, {raw: true, cursor: {batchSize: 1}}, () => { 43 | def.resolve(); 44 | }) 45 | } 46 | }) 47 | .add('Mongoose', { 48 | defer: true, 49 | fn: function(def) { 50 | process.nextTick(() => { 51 | recordModel.findOne({ 52 | 'name': 'buwheelsx0' 53 | // _id: "5a9b1a4f118a592378305c36" 54 | }).populate('subrecord').exec().then(function (e) { 55 | def.resolve(); 56 | }); 57 | }) 58 | } 59 | }) 60 | .on('cycle', function(event) { 61 | console.log(String(event.target)); 62 | }) 63 | .on('complete', function() { 64 | console.log('Fastest is ' + this.filter('fastest').map('name')); 65 | }) 66 | .run({ 'async': true }); 67 | 68 | 69 | }) 70 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "mongoose-vs-mongodb", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "bl": { 8 | "version": "2.2.1", 9 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 10 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 11 | "requires": { 12 | "readable-stream": "^2.3.5", 13 | "safe-buffer": "^5.1.1" 14 | } 15 | }, 16 | "bluebird": { 17 | "version": "3.5.1", 18 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 19 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 20 | }, 21 | "bson": { 22 | "version": "1.1.6", 23 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.6.tgz", 24 | "integrity": "sha512-EvVNVeGo4tHxwi8L6bPj3y3itEvStdwvvlojVxxbyYfoaxJ6keLgrTuKdyfEAszFK+H3olzBuafE0yoh0D1gdg==" 25 | }, 26 | "core-util-is": { 27 | "version": "1.0.2", 28 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 29 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 30 | }, 31 | "debug": { 32 | "version": "3.1.0", 33 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 34 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 35 | "requires": { 36 | "ms": "2.0.0" 37 | }, 38 | "dependencies": { 39 | "ms": { 40 | "version": "2.0.0", 41 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 42 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 43 | } 44 | } 45 | }, 46 | "denque": { 47 | "version": "1.4.1", 48 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.4.1.tgz", 49 | "integrity": "sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ==" 50 | }, 51 | "inherits": { 52 | "version": "2.0.4", 53 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 54 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 55 | }, 56 | "isarray": { 57 | "version": "1.0.0", 58 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 59 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 60 | }, 61 | "kareem": { 62 | "version": "2.3.1", 63 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.1.tgz", 64 | "integrity": "sha512-l3hLhffs9zqoDe8zjmb/mAN4B8VT3L56EUvKNqLFVs9YlFA+zx7ke1DO8STAdDyYNkeSo1nKmjuvQeI12So8Xw==" 65 | }, 66 | "memory-pager": { 67 | "version": "1.5.0", 68 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 69 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 70 | "optional": true 71 | }, 72 | "mongodb": { 73 | "version": "3.6.1", 74 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.6.1.tgz", 75 | "integrity": "sha512-uH76Zzr5wPptnjEKJRQnwTsomtFOU/kQEU8a9hKHr2M7y9qVk7Q4Pkv0EQVp88742z9+RwvsdTw6dRjDZCNu1g==", 76 | "requires": { 77 | "bl": "^2.2.0", 78 | "bson": "^1.1.4", 79 | "denque": "^1.4.1", 80 | "require_optional": "^1.0.1", 81 | "safe-buffer": "^5.1.2", 82 | "saslprep": "^1.0.0" 83 | }, 84 | "dependencies": { 85 | "bson": { 86 | "version": "1.1.5", 87 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.5.tgz", 88 | "integrity": "sha512-kDuEzldR21lHciPQAIulLs1LZlCXdLziXI6Mb/TDkwXhb//UORJNPXgcRs2CuO4H0DcMkpfT3/ySsP3unoZjBg==" 89 | } 90 | } 91 | }, 92 | "mongoose": { 93 | "version": "5.7.5", 94 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.7.5.tgz", 95 | "integrity": "sha512-BZ4FxtnbTurc/wcm/hLltLdI4IDxo4nsE0D9q58YymTdZwreNzwO62CcjVtaHhmr8HmJtOInp2W/T12FZaMf8g==", 96 | "requires": { 97 | "bson": "~1.1.1", 98 | "kareem": "2.3.1", 99 | "mongodb": "3.3.2", 100 | "mongoose-legacy-pluralize": "1.0.2", 101 | "mpath": "0.6.0", 102 | "mquery": "3.2.2", 103 | "ms": "2.1.2", 104 | "regexp-clone": "1.0.0", 105 | "safe-buffer": "5.1.2", 106 | "sift": "7.0.1", 107 | "sliced": "1.0.1" 108 | }, 109 | "dependencies": { 110 | "mongodb": { 111 | "version": "3.3.2", 112 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.3.2.tgz", 113 | "integrity": "sha512-fqJt3iywelk4yKu/lfwQg163Bjpo5zDKhXiohycvon4iQHbrfflSAz9AIlRE6496Pm/dQKQK5bMigdVo2s6gBg==", 114 | "requires": { 115 | "bson": "^1.1.1", 116 | "require_optional": "^1.0.1", 117 | "safe-buffer": "^5.1.2" 118 | } 119 | }, 120 | "safe-buffer": { 121 | "version": "5.1.2", 122 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 123 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 124 | } 125 | } 126 | }, 127 | "mongoose-legacy-pluralize": { 128 | "version": "1.0.2", 129 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 130 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 131 | }, 132 | "mpath": { 133 | "version": "0.6.0", 134 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.6.0.tgz", 135 | "integrity": "sha512-i75qh79MJ5Xo/sbhxrDrPSEG0H/mr1kcZXJ8dH6URU5jD/knFxCVqVC/gVSW7GIXL/9hHWlT9haLbCXWOll3qw==" 136 | }, 137 | "mquery": { 138 | "version": "3.2.2", 139 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.2.tgz", 140 | "integrity": "sha512-XB52992COp0KP230I3qloVUbkLUxJIu328HBP2t2EsxSFtf4W1HPSOBWOXf1bqxK4Xbb66lfMJ+Bpfd9/yZE1Q==", 141 | "requires": { 142 | "bluebird": "3.5.1", 143 | "debug": "3.1.0", 144 | "regexp-clone": "^1.0.0", 145 | "safe-buffer": "5.1.2", 146 | "sliced": "1.0.1" 147 | }, 148 | "dependencies": { 149 | "safe-buffer": { 150 | "version": "5.1.2", 151 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 152 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 153 | } 154 | } 155 | }, 156 | "ms": { 157 | "version": "2.1.2", 158 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 159 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 160 | }, 161 | "process-nextick-args": { 162 | "version": "2.0.1", 163 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 164 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 165 | }, 166 | "readable-stream": { 167 | "version": "2.3.7", 168 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 169 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 170 | "requires": { 171 | "core-util-is": "~1.0.0", 172 | "inherits": "~2.0.3", 173 | "isarray": "~1.0.0", 174 | "process-nextick-args": "~2.0.0", 175 | "safe-buffer": "~5.1.1", 176 | "string_decoder": "~1.1.1", 177 | "util-deprecate": "~1.0.1" 178 | }, 179 | "dependencies": { 180 | "safe-buffer": { 181 | "version": "5.1.2", 182 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 183 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 184 | } 185 | } 186 | }, 187 | "regexp-clone": { 188 | "version": "1.0.0", 189 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 190 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 191 | }, 192 | "require_optional": { 193 | "version": "1.0.1", 194 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 195 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 196 | "requires": { 197 | "resolve-from": "^2.0.0", 198 | "semver": "^5.1.0" 199 | } 200 | }, 201 | "resolve-from": { 202 | "version": "2.0.0", 203 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 204 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 205 | }, 206 | "safe-buffer": { 207 | "version": "5.2.1", 208 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 209 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 210 | }, 211 | "saslprep": { 212 | "version": "1.0.3", 213 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 214 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 215 | "optional": true, 216 | "requires": { 217 | "sparse-bitfield": "^3.0.3" 218 | } 219 | }, 220 | "semver": { 221 | "version": "5.7.1", 222 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 223 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 224 | }, 225 | "sift": { 226 | "version": "7.0.1", 227 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 228 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 229 | }, 230 | "sliced": { 231 | "version": "1.0.1", 232 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 233 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 234 | }, 235 | "sparse-bitfield": { 236 | "version": "3.0.3", 237 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 238 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 239 | "optional": true, 240 | "requires": { 241 | "memory-pager": "^1.0.2" 242 | } 243 | }, 244 | "string_decoder": { 245 | "version": "1.1.1", 246 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 247 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 248 | "requires": { 249 | "safe-buffer": "~5.1.0" 250 | }, 251 | "dependencies": { 252 | "safe-buffer": { 253 | "version": "5.1.2", 254 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 255 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 256 | } 257 | } 258 | }, 259 | "util-deprecate": { 260 | "version": "1.0.2", 261 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 262 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 263 | } 264 | } 265 | } 266 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "mongoose-vs-mongodb", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "mongoose": "^5.7.5", 13 | "mongodb": "latest" 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /run.js: -------------------------------------------------------------------------------- 1 | const util = require('util'); 2 | const exec = require('child_process').exec; 3 | const results = []; 4 | const OPERATIONS = process.env.OPERATIONS || 10000; 5 | var args = process.argv.slice(2) 6 | const parsedArgs = args.reduce((acc, current) => { 7 | switch(current) { 8 | case 'dev': return { ...acc, dev: true} 9 | case 'nocleanup': return { ...acc, nocleanup: true} 10 | case 'verbose': return { ...acc, verbose: true} 11 | } 12 | return acc 13 | }, {}) 14 | function myExec({ cmd, nolog = false, env } ) { 15 | const child = exec(cmd, { env: env || {}}); 16 | var scriptOutput = "", scriptError = ''; 17 | child.stdout.on('data', function (data) { 18 | scriptOutput += data.toString(); 19 | parsedArgs.verbose && !nolog && console.log(data); 20 | }); 21 | child.stderr.on('data', function (data) { 22 | scriptError += data.toString(); 23 | parsedArgs.verbose && !nolog && console.log(data); 24 | }); 25 | return new Promise(function (resolve, reject) { 26 | child.addListener("error", (error) => { 27 | reject(error) 28 | }); 29 | child.addListener("exit", (code) => { 30 | if (code) reject(scriptError) 31 | resolve(scriptOutput); 32 | }) 33 | }); 34 | } 35 | async function ls(name) { 36 | try { 37 | await myExec({ cmd: `docker-compose -f docker-compose.yml ${parsedArgs.dev ? '-f docker-compose.dev.yml' : ''} up ${name}`, env: { OPERATIONS } }); 38 | const id = await pollStatus(name); 39 | let stdout = await myExec({ cmd: `docker inspect ${id}`, nolog: true }); 40 | const info = JSON.parse(stdout)[0]; 41 | results.push({ 42 | started: info.State.StartedAt, finished: info.State.FinishedAt, 43 | name: info.Config.Labels.name, operations: OPERATIONS, 44 | time_taken: (new Date(info.State.FinishedAt)).getTime() - (new Date(info.State.StartedAt)).getTime() 45 | }) 46 | console.log("Time Taken by ", info.Config.Labels.name, (new Date(new Date(info.State.FinishedAt)).getTime() - (new Date(info.State.StartedAt)).getTime())) 47 | return await myExec({ cmd: `docker-compose stop && docker-compose rm -f` }); 48 | } catch(e) { 49 | if (!(e.startsWith('No such service:') || parsedArgs.verbose)) console.log(e); 50 | return 'Done'; 51 | } 52 | } 53 | async function run() { 54 | for(let i = 1; i < 10; i++) { 55 | let result = await ls(`task-${i}`); 56 | if (result === 'Done') break; 57 | } 58 | if (!parsedArgs.nocleanup) { 59 | console.log("Cleaning Up...") 60 | await myExec({cmd: `docker-compose down`}); // remove network 61 | } 62 | console.log(results.map(result => ({ 63 | ...result, 64 | operations_per_second: result.operations / (result.time_taken / 1000) 65 | }))) 66 | } 67 | run() 68 | 69 | async function pollStatus(name) { 70 | return new Promise((rs, rj) => { 71 | const interval = setInterval(async () => { 72 | const stdout = await myExec({ cmd: `docker ps -qaf name=${name} -f status=exited`, nolog: true}); 73 | if (stdout) { 74 | clearInterval(interval); 75 | rs(stdout.trim()) 76 | } 77 | }, 5000); 78 | }) 79 | } --------------------------------------------------------------------------------