create-server.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /**
  2. * Currently commenting out redis caching as there is no
  3. * working implementation for the benchmark suite.
  4. */
  5. var Hapi = require('hapi');
  6. var Vision = require('vision');
  7. var server = new Hapi.Server();
  8. server.connection({port: 8080});
  9. server.register(Vision, (err) => {
  10. if (err) {
  11. throw err;
  12. }
  13. server.views({
  14. engines: { html: require('handlebars') },
  15. path: __dirname + '/views/'
  16. });
  17. });
  18. var Promise = require('bluebird');
  19. var MongooseHandler;
  20. var SequelizeHandler;
  21. var SequelizePgHandler;
  22. // Slight start-up improvement loading handlers in parallel
  23. Promise.join(
  24. require('./handlers/mongoose'),
  25. require('./handlers/sequelize'),
  26. require('./handlers/sequelize-postgres'),
  27. function (mongo, mysql, pg) {
  28. MongooseHandler = mongo;
  29. SequelizeHandler = mysql;
  30. SequelizePgHandler = pg;
  31. })
  32. .catch(function (err) {
  33. console.log('There was a problem setting up the handlers');
  34. process.exit(1);
  35. });
  36. Route('/json', JsonSerialization);
  37. Route('/plaintext', Plaintext);
  38. Route('/mongoose/db', MongooseHandler.SingleQuery);
  39. Route('/mongoose/queries', MongooseHandler.MultipleQueries);
  40. Route('/mongoose/fortunes', MongooseHandler.Fortunes);
  41. Route('/mongoose/updates', MongooseHandler.Updates);
  42. Route('/sequelize/db', SequelizeHandler.SingleQuery);
  43. Route('/sequelize/queries', SequelizeHandler.MultipleQueries);
  44. Route('/sequelize/fortunes', SequelizeHandler.Fortunes);
  45. Route('/sequelize/updates', SequelizeHandler.Updates);
  46. Route('/sequelize-pg/db', SequelizePgHandler.SingleQuery);
  47. Route('/sequelize-pg/queries', SequelizePgHandler.MultipleQueries);
  48. Route('/sequelize-pg/fortunes', SequelizePgHandler.Fortunes);
  49. Route('/sequelize-pg/updates', SequelizePgHandler.Updates);
  50. function JsonSerialization(req, reply) {
  51. reply({ message: 'Hello, World!' })
  52. .header('Server', 'hapi');
  53. }
  54. function Plaintext(req, reply) {
  55. reply('Hello, World!')
  56. .header('Server', 'hapi')
  57. .header('Content-Type', 'text/plain');
  58. }
  59. // Makes routing simpler as tfb routes are all GET's
  60. // We also don't use the nifty route features that Hapi has
  61. // to offer such as attaching a validator
  62. function Route(path, handler) {
  63. server.route({ method: 'GET', path: path, handler: handler})
  64. }
  65. server.start(function (err) {
  66. console.log('Hapi worker started and listening on ' + server.info.uri + " "
  67. + new Date().toISOString(" "));
  68. });