A new Rules of Durable Objects guide is now available, providing opinionated best practices for building effective Durable Objects applications. This guide covers design patterns, storage strategies, concurrency, and common anti-patterns to avoid.
Key guidance includes:
- Design around your “atom” of coordination — Create one Durable Object per logical unit (chat room, game session, user) instead of a global singleton that becomes a bottleneck.
- Use SQLite storage with RPC methods — SQLite-backed Durable Objects with typed RPC methods provide the best developer experience and performance.
- Understand input and output gates — Learn how Cloudflare’s runtime prevents data races by default, how write coalescing works, and when to use
blockConcurrencyWhile(). - Leverage Hibernatable WebSockets — Reduce costs for real-time applications by allowing Durable Objects to sleep while maintaining WebSocket connections.
The testing documentation has also been updated with modern patterns using @cloudflare/vitest-pool-workers, including examples for testing SQLite storage, alarms, and direct instance access:
JavaScript
import { env, runDurableObjectAlarm } from "cloudflare:test";import { it, expect } from "vitest";it("can test Durable Objects with isolated storage", async () => {const stub = env.COUNTER.getByName("test");// Call RPC methods directly on the stubawait stub.increment();expect(await stub.getCount()).toBe(1);// Trigger alarms immediately without waitingawait runDurableObjectAlarm(stub);});TypeScript
import { env, runDurableObjectAlarm } from "cloudflare:test";import { it, expect } from "vitest";it("can test Durable Objects with isolated storage", async () => {const stub = env.COUNTER.getByName("test");// Call RPC methods directly on the stubawait stub.increment();expect(await stub.getCount()).toBe(1);// Trigger alarms immediately without waitingawait runDurableObjectAlarm(stub);});
Source: Cloudflare
Latest Posts
- Dynamics 365 Contact Center- Set least active assignment as default in messaging queues [MC1215836]
![Dynamics 365 Contact Center- Set least active assignment as default in messaging queues [MC1215836] 2 pexels nietjuh 25358209](data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==)
- (Updated) Legacy SharePoint Online Content Delivery Network (CDN) domain to be retired—review configurations [MC1184996]
![(Updated) Legacy SharePoint Online Content Delivery Network (CDN) domain to be retired—review configurations [MC1184996] 3 pexels goumbik 1414130](data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==)
- (Updated) Microsoft 365 Copilot: RSVP to meetings directly in Copilot chat [MC1192258]
![(Updated) Microsoft 365 Copilot: RSVP to meetings directly in Copilot chat [MC1192258] 4 pexels eye4dtail 134525](data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==)
- Amazon DocumentDB (with MongoDB compatibility) is Now Available in the Asia Pacific (Jakarta) Region


![Dynamics 365 Contact Center- Set least active assignment as default in messaging queues [MC1215836] 2 pexels nietjuh 25358209](https://mwpro.co.uk/wp-content/uploads/2024/08/pexels-nietjuh-25358209-150x150.webp)
![(Updated) Legacy SharePoint Online Content Delivery Network (CDN) domain to be retired—review configurations [MC1184996] 3 pexels goumbik 1414130](https://mwpro.co.uk/wp-content/uploads/2024/08/pexels-goumbik-1414130-150x150.webp)
![(Updated) Microsoft 365 Copilot: RSVP to meetings directly in Copilot chat [MC1192258] 4 pexels eye4dtail 134525](https://mwpro.co.uk/wp-content/uploads/2024/08/pexels-eye4dtail-134525-150x150.webp)

