- Dart:Scalable Application Development
- Davy Mitchell Sergey Akopkokhyants Ivo Balbaert
- 255字
- 2021-07-09 18:56:23
Caching
The serving of content in the first iteration of the web server was rather inefficient—I hope you noticed! On every GET
request, the blog source file is read from the disk and is processed. To gain some efficiency, we can use a map added to the Blog
class as a field. Let's take a look at the following code snippet for more information:
BlogPost getBlogPost(int index) { if (!_cache.containsKey(index)) { _cache[index] = new BlogPost(postPaths[index], index); } return _cache[index]; }
The map object uses the blog index
as a key and the resultant blog post as the value. This cache is kept in the memory so that if the blog server application is stopped and restarted, new requests will not initially come from the cache.
Note
Caching of content in web applications is quite an art. For example, a cache could be put in place at the request level for both entire pages and images. The underlying operating system will also cache files in memory, making operations much faster on subsequent requests.
As ever, a memory cache is just one tool that may or may not improve a particular application. Benchmarking a performance and finding the bottleneck that needs caching is critical for a high-performance application.
The cache is something that must be remembered when the content is refreshed and when a new blog post is added. A simple strategy is to set the _cache
object to {}
(an empty map), relying on the first display of the post to fill the cache.
- Node.js+Webpack開發實戰
- MATLAB圖像處理超級學習手冊
- Easy Web Development with WaveMaker
- C#程序設計
- Teaching with Google Classroom
- Learning OpenCV 3 Computer Vision with Python(Second Edition)
- Julia for Data Science
- CRYENGINE Game Development Blueprints
- 深度學習程序設計實戰
- Java多線程并發體系實戰(微課視頻版)
- Elasticsearch搜索引擎構建入門與實戰
- 算法精解:C語言描述
- MySQL數據庫應用技術及實戰
- Java無難事:詳解Java編程核心思想與技術
- Instant OpenCV for iOS