{"id":91,"date":"2019-08-22T14:30:00","date_gmt":"2019-08-22T14:30:00","guid":{"rendered":"https:\/\/denisarucaj.com\/?p=91"},"modified":"2023-09-04T15:15:54","modified_gmt":"2023-09-04T15:15:54","slug":"evaluate-scalable-and-high-performance-node-js-application-designs","status":"publish","type":"post","link":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/","title":{"rendered":"Evaluate scalable and high-performance Node.js Application Designs"},"content":{"rendered":"\n<p class=\"has-medium-font-size\"><mark style=\"background-color:rgba(0, 0, 0, 0)\" class=\"has-inline-color has-very-dark-gray-color\"><\/mark>The goal of this paper was to measure the impact of<br>different application architectures and designs on the scalability of a<br>simple Node.js application. Different scalable<br>application architectures are researched. Furthermore, it is analyzed the <br>impact of different components in a system in terms of performance and <br>scalability. You will find the application of the REST services built with Node.js. <br>The main service was deployed on different instance configurations. For<br>example, a single machine instance or multiple host machines were set<br>using docker and nginx load balancer. Generally, the<br>performance metrics considered for our experiments evaluation are<br>latency and throughput. Other metrics were observed like elastic<br>scalability and error rate.<br><\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<div data-wp-interactive=\"core\/file\" class=\"wp-block-file aligncenter has-very-light-gray-background-color has-background\"><object data-wp-bind--hidden=\"!state.hasPdfPreview\" hidden class=\"wp-block-file__embed\" data=\"https:\/\/denisarucaj.com\/wp-content\/uploads\/2023\/08\/Scalable-and-High-Performance-Nodejs-App.pdf\" type=\"application\/pdf\" style=\"width:100%;height:600px\" aria-label=\"Embed of Scalable-and-High-Performance-Nodejs-App.\"><\/object><a id=\"wp-block-file--media-7aaa88d1-1558-455e-b083-01f66eccc040\" href=\"https:\/\/denisarucaj.com\/wp-content\/uploads\/2023\/08\/Scalable-and-High-Performance-Nodejs-App.pdf\" style=\"color: #000000\">Scalable-and-High-Performance-Nodejs-App<\/a><a href=\"https:\/\/denisarucaj.com\/wp-content\/uploads\/2023\/08\/Scalable-and-High-Performance-Nodejs-App.pdf\" class=\"wp-block-file__button wp-element-button\" download aria-describedby=\"wp-block-file--media-7aaa88d1-1558-455e-b083-01f66eccc040\" style=\"padding: 10px; color: black; background-color: darkgrey;font-weight: bold;\">Download<\/a><\/div>\n","protected":false},"excerpt":{"rendered":"<p>The goal of this paper was to measure the impact of<br \/>\ndifferent application architectures and designs on the scalability of a<br \/>\nsimple Node.js application.<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[9,12,14,11,10,8],"class_list":["post-91","post","type-post","status-publish","format-standard","hentry","category-uncategorized","tag-api","tag-architecturedesign","tag-benchmarking","tag-docker","tag-nodejs","tag-restapi"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v24.9 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Evaluate scalable and high-performance Node.js Application Designs - Denisa Ru\u00e7aj<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Evaluate scalable and high-performance Node.js Application Designs - Denisa Ru\u00e7aj\" \/>\n<meta property=\"og:description\" content=\"The goal of this paper was to measure the impact of different application architectures and designs on the scalability of a simple Node.js application.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/\" \/>\n<meta property=\"og:site_name\" content=\"Denisa Ru\u00e7aj\" \/>\n<meta property=\"article:published_time\" content=\"2019-08-22T14:30:00+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2023-09-04T15:15:54+00:00\" \/>\n<meta name=\"author\" content=\"denisa\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"denisa\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 minute\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/\"},\"author\":{\"name\":\"denisa\",\"@id\":\"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e\"},\"headline\":\"Evaluate scalable and high-performance Node.js Application Designs\",\"datePublished\":\"2019-08-22T14:30:00+00:00\",\"dateModified\":\"2023-09-04T15:15:54+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/\"},\"wordCount\":114,\"publisher\":{\"@id\":\"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e\"},\"keywords\":[\"api\",\"architecturedesign\",\"benchmarking\",\"docker\",\"nodejs\",\"restapi\"],\"inLanguage\":\"en-US\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/\",\"url\":\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/\",\"name\":\"Evaluate scalable and high-performance Node.js Application Designs - Denisa Ru\u00e7aj\",\"isPartOf\":{\"@id\":\"https:\/\/denisarucaj.com\/#website\"},\"datePublished\":\"2019-08-22T14:30:00+00:00\",\"dateModified\":\"2023-09-04T15:15:54+00:00\",\"breadcrumb\":{\"@id\":\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/denisarucaj.com\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Evaluate scalable and high-performance Node.js Application Designs\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/denisarucaj.com\/#website\",\"url\":\"https:\/\/denisarucaj.com\/\",\"name\":\"Denisa Ru\u00e7aj\",\"description\":\"Welcome to my space\",\"publisher\":{\"@id\":\"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/denisarucaj.com\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":[\"Person\",\"Organization\"],\"@id\":\"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e\",\"name\":\"denisa\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/denisarucaj.com\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/denisarucaj.com\/wp-content\/uploads\/2024\/05\/29-Denisa-Rucaj-BW.jpg\",\"contentUrl\":\"https:\/\/denisarucaj.com\/wp-content\/uploads\/2024\/05\/29-Denisa-Rucaj-BW.jpg\",\"width\":2160,\"height\":2160,\"caption\":\"denisa\"},\"logo\":{\"@id\":\"https:\/\/denisarucaj.com\/#\/schema\/person\/image\/\"},\"description\":\"Senior Solution Engineer with diverse skills in Software Engineering and Data Science. Working in the Advertising Technology industry.\",\"sameAs\":[\"http:\/\/denisarucaj.com\",\"https:\/\/www.linkedin.com\/in\/denisa-rucaj\"],\"url\":\"https:\/\/denisarucaj.com\/index.php\/author\/denisa\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Evaluate scalable and high-performance Node.js Application Designs - Denisa Ru\u00e7aj","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/","og_locale":"en_US","og_type":"article","og_title":"Evaluate scalable and high-performance Node.js Application Designs - Denisa Ru\u00e7aj","og_description":"The goal of this paper was to measure the impact of different application architectures and designs on the scalability of a simple Node.js application.","og_url":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/","og_site_name":"Denisa Ru\u00e7aj","article_published_time":"2019-08-22T14:30:00+00:00","article_modified_time":"2023-09-04T15:15:54+00:00","author":"denisa","twitter_card":"summary_large_image","twitter_misc":{"Written by":"denisa","Est. reading time":"1 minute"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/#article","isPartOf":{"@id":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/"},"author":{"name":"denisa","@id":"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e"},"headline":"Evaluate scalable and high-performance Node.js Application Designs","datePublished":"2019-08-22T14:30:00+00:00","dateModified":"2023-09-04T15:15:54+00:00","mainEntityOfPage":{"@id":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/"},"wordCount":114,"publisher":{"@id":"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e"},"keywords":["api","architecturedesign","benchmarking","docker","nodejs","restapi"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/","url":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/","name":"Evaluate scalable and high-performance Node.js Application Designs - Denisa Ru\u00e7aj","isPartOf":{"@id":"https:\/\/denisarucaj.com\/#website"},"datePublished":"2019-08-22T14:30:00+00:00","dateModified":"2023-09-04T15:15:54+00:00","breadcrumb":{"@id":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/denisarucaj.com\/index.php\/2019\/08\/22\/evaluate-scalable-and-high-performance-node-js-application-designs\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/denisarucaj.com\/"},{"@type":"ListItem","position":2,"name":"Evaluate scalable and high-performance Node.js Application Designs"}]},{"@type":"WebSite","@id":"https:\/\/denisarucaj.com\/#website","url":"https:\/\/denisarucaj.com\/","name":"Denisa Ru\u00e7aj","description":"Welcome to my space","publisher":{"@id":"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/denisarucaj.com\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":["Person","Organization"],"@id":"https:\/\/denisarucaj.com\/#\/schema\/person\/85f435e69c5fc1b4529f3d13d922ba8e","name":"denisa","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/denisarucaj.com\/#\/schema\/person\/image\/","url":"https:\/\/denisarucaj.com\/wp-content\/uploads\/2024\/05\/29-Denisa-Rucaj-BW.jpg","contentUrl":"https:\/\/denisarucaj.com\/wp-content\/uploads\/2024\/05\/29-Denisa-Rucaj-BW.jpg","width":2160,"height":2160,"caption":"denisa"},"logo":{"@id":"https:\/\/denisarucaj.com\/#\/schema\/person\/image\/"},"description":"Senior Solution Engineer with diverse skills in Software Engineering and Data Science. Working in the Advertising Technology industry.","sameAs":["http:\/\/denisarucaj.com","https:\/\/www.linkedin.com\/in\/denisa-rucaj"],"url":"https:\/\/denisarucaj.com\/index.php\/author\/denisa\/"}]}},"_links":{"self":[{"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/posts\/91","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/comments?post=91"}],"version-history":[{"count":11,"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/posts\/91\/revisions"}],"predecessor-version":[{"id":145,"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/posts\/91\/revisions\/145"}],"wp:attachment":[{"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/media?parent=91"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/categories?post=91"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/denisarucaj.com\/index.php\/wp-json\/wp\/v2\/tags?post=91"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}