hello.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. var cluster = require('cluster')
  2. , numCPUs = require('os').cpus().length
  3. , http = require('http')
  4. , url = require('url');
  5. var h = require('./helper.js');
  6. //
  7. // Handlers, one for each db config
  8. //
  9. var MongodbRawHandler = require('./handlers/mongodb-raw');
  10. var MySQLRawHandler = require('./handlers/mysql-raw');
  11. // Mongoose is a popular Node/MongoDB driver
  12. var MongooseHandler = require('./handlers/mongoose')
  13. // Sequelize is a popular Node/SQL driver
  14. var SequelizeHandler = require('./handlers/sequelize')
  15. if (cluster.isMaster) {
  16. // Fork workers.
  17. for (var i = 0; i < numCPUs; i++) {
  18. cluster.fork();
  19. }
  20. cluster.on('exit', function (worker, code, signal) {
  21. console.log('worker ' + worker.pid + ' died');
  22. });
  23. } else {
  24. http.createServer(function (req, res) {
  25. var values = url.parse(req.url, true);
  26. var route = values.pathname;
  27. // Basic routes, no db required
  28. if (route === '/json') {
  29. return h.responses.jsonSerialization(req, res);
  30. } else if (route === '/plaintext') {
  31. return h.responses.plaintext(req, res);
  32. // No queries parameter required
  33. } else if (route === '/mongoose/db') {
  34. return MongooseHandler.SingleQuery(req, res);
  35. } else if (route === '/mongoose/fortunes') {
  36. return MongooseHandler.Fortunes(req, res);
  37. } else if (route === '/mongodb/db') {
  38. return MongodbRawHandler.SingleQuery(req, res);
  39. } else if (route === '/mongodb/fortunes') {
  40. return MongodbRawHandler.Fortunes(req, res);
  41. } else if (route === '/sequelize/db') {
  42. return SequelizeHandler.SingleQuery(req, res);
  43. } else if (route === '/sequelize/fortunes') {
  44. return SequelizeHandler.Fortunes(req, res);
  45. } else if (route === '/mysql/db') {
  46. return MySQLRawHandler.SingleQuery(req, res);
  47. } else if (route === '/mysql/fortunes') {
  48. return MySQLRawHandler.Fortunes(req, res);
  49. }
  50. else {
  51. var queries = isNaN(values.query.queries) ? 1 : parseInt(values.query.queries, 10);
  52. queries = Math.min(Math.max(queries, 1), 500);
  53. if (route === '/mongoose/queries') {
  54. return MongooseHandler.MultipleQueries(queries, req, res);
  55. } else if (route === '/mongoose/updates') {
  56. return MongooseHandler.Updates(queries, req, res);
  57. } else if (route === '/mongodb/queries') {
  58. return MongodbRawHandler.MultipleQueries(queries, req, res);
  59. } else if (route === '/mongodb/updates') {
  60. return MongodbRawHandler.Updates(queries, req, res);
  61. } else if (route === '/sequelize/queries') {
  62. return SequelizeHandler.MultipleQueries(queries, req, res);
  63. } else if (route === '/sequelize/updates') {
  64. return SequelizeHandler.Updates(queries, req, res);
  65. } else if (route === '/mysql/queries') {
  66. return MySQLRawHandler.MultipleQueries(queries, req, res);
  67. } else if (route === '/mysql/updates') {
  68. return MySQLRawHandler.Updates(queries, req, res);
  69. } else {
  70. return responses.routeNotImplemented(req, res);
  71. }
  72. }
  73. }).listen(8080, function() {
  74. console.log("NodeJS worker listening on port 8080");
  75. });
  76. }