However, the domain quaily.com doesn't point directly to the Hugo-deployed worker, but rather to a worker responsible for traffic distribution - let's

Breaking Down Quaily's Technical Architecture: A No-Frills Approach

submited by
Style Pass
2025-01-15 14:00:09

However, the domain quaily.com doesn't point directly to the Hugo-deployed worker, but rather to a worker responsible for traffic distribution - let's call it quaily-router.

Although quaily-router is implemented using cloudflare worker, it could be replaced with traditional methods like nginx if needed; R2 is S3-compatible. So there's no Cloudflare lock-in

As shown in the diagram above, articles and article lists aren't SPAs or backend-rendered results, but rather static HTML pages.

The benefit of this approach is minimal latency from request to content display - quaily-router just needs to read from R2 and return the content. Average latency is under 100ms, 3-5 times faster than typical content sites.

Dynamic content on articles and article lists (like subscription forms) is implemented by mounting Vue SPAs onto the HTML. While these contents take extra time to load, they don't affect humans or search engines reading the article content and lists before loading completes.

The frontend interacts with the backend through RESTful APIs, with endpoints at api.quail.ink pointing to a load balancer. The load balancer uses AWS's default configuration but can be switched to nginx anytime without lock-in.

Leave a Comment