- 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.
- Google Flutter Mobile Development Quick Start Guide
- 數字媒體應用教程
- 深入實踐Spring Boot
- 深入理解Java7:核心技術與最佳實踐
- 鋒利的SQL(第2版)
- Learning Concurrency in Kotlin
- Apache Camel Developer's Cookbook
- QGIS 2 Cookbook
- Python計算機視覺和自然語言處理
- 遠方:兩位持續創業者的點滴思考
- AMP:Building Accelerated Mobile Pages
- Python預測分析與機器學習
- Modular Programming with JavaScript
- Scratch編程從入門到精通
- IBM DB2 9.7 Advanced Application Developer Cookbook