Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add egg2 vs egg1 #14

Merged
merged 6 commits into from
Nov 17, 2017
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 6 additions & 5 deletions .autod.conf.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,17 +18,18 @@ module.exports = {
'eslint',
'eslint-config-egg',
'webstorm-disable-index',
'nunjucks',
'koa',
'koa-router',
],
semver: [
'koa@2',
'koa-router@7',
'koa@1',
'koa-router@5',
],
exclude: [
'./test/fixtures',
'./dist',
'./wrk',
],
keep: [
'egg',
'egg-core',
],
};
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,5 @@ stats.csv
node-*
tmp
package-lock.json
plot/all.csv

81 changes: 11 additions & 70 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ egg benchmark

## Commands

* `npm test` to run all the benchmarks and store the results in `stats.csv` (requires `wrk`)
* `npm test` to run all the benchmarks and store the results in `stats.csv` (requires `wrk`), also you can open `plot/index.html` to see the results
* `./plot.sh` to compare performance between the latest releases of Node.js v7.x, v8.x, rc, nightly and v8-canary (requires `wrk` and `nvm`), then open `plot/index.html` to see the results
* Requires AJAX privilege to load data from `plot/all.csv`, you can run `python -m SimpleHTTPServer` then visit `http://localhost:8000/plot/` (or use any other static server) if you don't want to tweak browser settings

Expand All @@ -27,83 +27,24 @@ egg benchmark

## Scripts

- koa1: `wrk http://127.0.0.1:7002/ -d 10 -c 50 -t 8`
- koa2: `wrk http://127.0.0.1:7004/ -d 10 -c 50 -t 8`
- egg: `wrk http://127.0.0.1:7001/ -d 10 -c 50 -t 8`
- koa1: `wrk http://127.0.0.1:7001/ -d 10 -c 50 -t 8`
- koa2: `wrk http://127.0.0.1:7002/ -d 10 -c 50 -t 8`
- egg1: `wrk http://127.0.0.1:7003/ -d 10 -c 50 -t 8`
- egg2: `wrk http://127.0.0.1:7004/ -d 10 -c 50 -t 8`

## Server

- CPU x4: Intel(R) Xeon(R) CPU E5-2650 v2 @ 2.60GHz
- Mem: 10G
- MacBook Pro (Retina, 15-inch, Late 2013)
- 2 GHz Intel Core i7 (only use 4 core for benchmark)

## Known issues

- [ensure csrf token exists](https://github.com/eggjs/egg-security/blob/master/app/extend/context.js#L75): It's cause get and set cookie on every request.
![image](https://cloud.githubusercontent.com/assets/156269/22675417/8fd55b44-ed20-11e6-8ac8-77a791e558dd.png)

## egg versions benchmark

- [plots view](https://fengmk2.com/egg/benchmark/)

### Hello World

egg version | node version | QPS Generator | Async Await
--- | --- | --- | ---
1.1.0 | 7.9.0 | 11004 | 11200
1.0.0-rc.1 | 7.6.0 | 11069 | 11296
0.12.0 | 7.6.0 | 10899 | 11122
0.12.0 | 6.9.5 | 8880 | -
0.11.0 | 6.9.5 | 8889 | -
0.10.0 | 6.9.5 | 8470 | -
0.2.0 | 6.9.5 | 8917 | -

### nunjucks

egg version | node version | QPS Generator | Async Await
--- | --- | --- | ---
1.1.0 | 7.9.0 | 6092 | 6121
1.0.0-rc.1 | 7.6.0 | 6278 | 6350
0.12.0 | 7.6.0 | 7216 | 7371
0.12.0 | 6.9.5 | 5967 | -
0.11.0 | 6.9.5 | 6057 | -
0.10.0 | 6.9.5 | 5681 | -
0.2.0 | 6.9.5 | 6732 | -

### ejs

egg version | node version | QPS Generator | Async Await
--- | --- | --- | ---
1.1.0 | 7.9.0 | 6916 | 6985
1.0.0-rc.1 | 7.6.0 | 7333 | 7372

### passport

- egg-passport: 1.0.0

egg version | node version | QPS Generator | Async Await
--- | --- | --- | ---
1.1.0 | 7.9.0 | 10117 | 10556
1.0.0-rc.1 | 7.6.0 | 10039 | 10438
0.12.0 | 7.6.0 | 9981 | 10436
0.12.0 | 6.9.5 | 7943 | -

## Last Results

- node: 7.9.0
- koa1: 1.4.0
- koa2: 2.2.0
- egg: 1.1.0

Scene | QPS | Scene | QPS
--- | --- | --- | ---
koa1 Hello World | 18216 | koa2 Hello World | 21836
egg Hello World | 11004 | egg Hello World (Async Await) | 11200
egg Hello Passport | 10117 | egg Hello Passport (Async Await) | 10556
koa1 nunjucks | 11807 | koa2 nunjucks | 13583
egg nunjucks | 6092 | egg nunjucks (Async Await) | 6121
egg ejs | 6916 | egg ejs (Async Await) | 6985


### Last Details

`stats.csv`
![image](https://user-images.githubusercontent.com/985607/32883232-6910dc88-ca7c-11e7-9a17-3fa6dbb83d5c.png)
![image](https://user-images.githubusercontent.com/985607/32883253-7746f080-ca7c-11e7-8fe0-9d6440368ab1.png)
![image](https://user-images.githubusercontent.com/985607/32883268-805498a8-ca7c-11e7-9a04-4aa9bb764b6f.png)
![image](https://user-images.githubusercontent.com/985607/32883282-885fcca2-ca7c-11e7-8ac7-398cbf2027fa.png)
23 changes: 12 additions & 11 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,19 +4,20 @@
"description": "egg benchmark",
"private": true,
"dependencies": {
"egg": "^1.7.0",
"egg-alinode": "^1.1.0",
"egg-passport": "^1.0.0",
"egg-view-ejs": "^1.1.0",
"egg-view-nunjucks": "^2.1.3",
"koa": "^2.3.0",
"koa-router": "^7.2.1",
"egg": "next",
"egg-alinode": "^1.1.1",
"egg-passport": "^2.0.0",
"egg-view-ejs": "^2.0.0",
"egg-view-nunjucks": "^2.1.4",
"egg1": "^1.11.0",
"koa": "^1.4.1",
"koa-router": "^5.4.2",
"nunjucks": "^3.0.1"
},
"devDependencies": {
"autod": "^2.9.0",
"eslint": "^4.4.1",
"eslint-config-egg": "^5.0.0",
"autod": "^3.0.1",
"eslint": "^4.11.0",
"eslint-config-egg": "^5.1.1",
"webstorm-disable-index": "^1.2.0"
},
"engines": {
Expand All @@ -26,7 +27,7 @@
"test-simple": "simple/run.sh",
"test-simple-view": "simple_view/run.sh",
"test-simple-passport": "simple_passport/run.sh",
"test": "cat stats-header.csv > stats.csv && npm run test-simple && npm run test-simple-view && npm run test-simple-passport",
"test": "cat stats-header.csv > stats.csv && npm run test-simple && npm run test-simple-view && npm run test-simple-passport && cp stats.csv polt/all.csv",
"ci": "npm test",
"autod": "autod"
},
Expand Down
101 changes: 60 additions & 41 deletions plot/plot.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,12 @@ d3.csv('./all.csv', function(d) {
});

function draw(svg, data) {
const margin = { top: 20, right: 20, bottom: 30, left: 40 };
const margin = {
top: 20,
right: 20,
bottom: 30,
left: 40,
};
const width = +svg.attr('width') - margin.left - margin.right;
const height = +svg.attr('height') - margin.top - margin.bottom;
const canvas = svg.append('g')
Expand All @@ -38,13 +43,13 @@ function draw(svg, data) {

const z = d3.scaleOrdinal()
.range([
'#00bcd4', '#ffc107', '#8bc34a', '#ad8de4', '#f17e7e'
'#00bcd4', '#ffc107', '#8bc34a', '#ad8de4', '#f17e7e',
]);

const groupKeys = Array.from(new Set(data.map(d => d.name)));
const valueKeys = [
'req_per_sec',
// 'byte_per_sec'
// 'byte_per_sec'
];
const configKeys = Array.from(new Set(data.map(d => d.config)));
const barKeys = [];
Expand All @@ -64,28 +69,42 @@ function draw(svg, data) {
.selectAll('g')
.data(nested)
.enter()
.append('g');
.append('g');

function formatNest(d) {
const values = d.values;
const result = [];
for (const item of values) {
for (const v of valueKeys) {
result.push({
config: item.config,
name: item.name,
key: v,
value: item[v],
});
}
}
return result;
}

const bars = groups
.attr('transform', d => `translate(${groupX(d.key)}, 0)`)
.selectAll('rect')
.data(function(d) {
const values = d.values;
const result = [];
for (const item of values) {
for (const v of valueKeys) {
result.push({
config: item.config,
name: item.name,
key: v,
value: item[v],
});
}
}
return result;
})
.data(formatNest)
.enter()
.append('rect');

groups
// .attr('transform', d => `translate(${groupX(d.key)}, 0)`)
.selectAll('text')
.data(formatNest)
.enter()
.append('rect');
.append('text')
.text(d => d.value)
.attr('x', function(d) {
return barX(`${d.key}:${d.config}`) + (barX.bandwidth() - this.getComputedTextLength()) / 2;
})
.attr('y', d => y(d.value) - 10);

bars
.attr('x', d => barX(`${d.key}:${d.config}`))
Expand All @@ -96,21 +115,21 @@ function draw(svg, data) {
.attr('fill', d => z(d.config));

canvas.append('g')
.attr('class', 'axis')
.attr('transform', `translate(0, ${height})`)
.call(d3.axisBottom(groupX));
.attr('class', 'axis')
.attr('transform', `translate(0, ${height})`)
.call(d3.axisBottom(groupX));

canvas.append('g')
.attr('class', 'axis')
.call(d3.axisLeft(y).ticks(null, 's'))
.attr('class', 'axis')
.call(d3.axisLeft(y).ticks(null, 's'))
.append('text')
.attr('x', 2)
.attr('y', y(y.ticks().pop()) + 0.5)
.attr('dy', '0.32em')
.attr('fill', '#000')
.attr('font-weight', 'bold')
.attr('text-anchor', 'start')
.text('req/s');
.attr('x', 2)
.attr('y', y(y.ticks().pop()) + 0.5)
.attr('dy', '0.32em')
.attr('fill', '#000')
.attr('font-weight', 'bold')
.attr('text-anchor', 'start')
.text('req/s');

const legend = canvas.append('g')
.attr('font-family', 'sans-serif')
Expand All @@ -119,20 +138,20 @@ function draw(svg, data) {
.selectAll('g')
.data(configKeys.slice().reverse())
.enter()
.append('g');
.append('g');

legend
.attr('transform', (d, i) => `translate(0, ${i * 20})`);

legend.append('rect')
.attr('x', width - 19)
.attr('width', 19)
.attr('height', 19)
.attr('fill', z);
.attr('x', width - 19)
.attr('width', 19)
.attr('height', 19)
.attr('fill', z);

legend.append('text')
.attr('x', width - 24)
.attr('y', 9.5)
.attr('dy', '0.32em')
.text(d => d);
.attr('x', width - 24)
.attr('y', 9.5)
.attr('dy', '0.32em')
.text(d => d);
}
2 changes: 0 additions & 2 deletions simple/app.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,4 @@
module.exports = app => {
console.log('egg app core middlewares: %d, app middlewares: %d',
app.config.coreMiddlewares.length, app.config.appMiddlewares.length);
require('./koa1');
require('./koa2');
};
26 changes: 22 additions & 4 deletions simple/dispatch.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,31 @@
'use strict';

const egg = require('egg');
const egg1 = require('egg1');
const cluster = require('cluster');

let workers = Number(process.argv[2] || require('os').cpus().length);
if (workers > 4) {
workers = 4;
}

egg.startCluster({
workers,
baseDir: __dirname,
});
if (cluster.isMaster) {
egg1.startCluster({
workers,
baseDir: __dirname,
port: 7003,
framework: 'egg1',
});

egg.startCluster({
workers,
baseDir: __dirname,
port: 7004,
});
for (let i = 0; i < workers; i++) {
cluster.fork();
}
} else {
require('./koa1');
require('./koa2');
}
8 changes: 4 additions & 4 deletions simple/koa1.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
'use strict';

// koa 1 need those versions
const koa = require('egg-core/node_modules/koa');
const router = require('egg-core/node_modules/koa-router')();
const koa = require('koa');
const router = require('koa-router')();

const app = koa();
let n = 15;
Expand All @@ -19,5 +19,5 @@ router.get('/', function* () {
this.body = 'Hello World, koa1\n';
});

console.log('koa1 app listen on 7002');
app.listen(7002);
console.log('koa1 app listen on 7001');
app.listen(7001);
Loading