Deploy a real-time chat application
In this tutorial, you will deploy a serverless, real-time chat application that runs using Durable Objects.
This chat application uses a Durable Object to control each chat room. Users connect to the Object using WebSockets. Messages from one user are broadcast to all the other users. The chat history is also stored in durable storage. Real-time messages are relayed directly from one user to others without going through the storage layer.
All of the tutorials assume you have already completed the Get started guide, which gets you set up with a Cloudflare Workers account, C3 ↗, and Wrangler.
Open your terminal and clone the workers-chat-demo ↗ repository:
git clone https://github.com/cloudflare/workers-chat-demo.gitAfter you have cloned the repository, authenticate Wrangler by running:
npx wrangler loginWhen you are ready to deploy your application, run:
npx wrangler deployYour application will be deployed to your *.workers.dev subdomain.
To deploy your application to a custom domain within the Cloudflare dashboard, go to your Worker > Triggers > Add Custom Domain.
To deploy your application to a custom domain using Wrangler, open your project's Wrangler configuration file.
To configure a route in your Wrangler configuration file, add the following to your environment:
{  "routes": [    {      "pattern": "example.com/about",      "zone_id": "<YOUR_ZONE_ID>"    }  ]}[[routes]]pattern = "example.com/about"zone_id = "<YOUR_ZONE_ID>"If you have specified your zone ID in the environment of your Wrangler configuration file, you will not need to write it again in object form.
To configure a subdomain in your Wrangler configuration file, add the following to your environment:
{  "routes": [    {      "pattern": "subdomain.example.com",      "custom_domain": true    }  ]}[[routes]]pattern = "subdomain.example.com"custom_domain = trueTo test your live application:
- 
In the Cloudflare dashboard, go to the Workers & Pages page. Go to Workers & Pages
- 
Select your Worker > Triggers > Routes > Select the edge-chat-demo.<SUBDOMAIN>.workers.devroute.
- 
Enter a name in the your name field. 
- 
Choose whether to enter a public room or create a private room. 
- 
Send the link to other participants. You will be able to view room participants on the right side of the screen. 
To uninstall your chat application, modify your Wrangler file to remove the durable_objects bindings and add a deleted_classes migration:
{  "durable_objects": {    "bindings": []  },  "migrations": [    {      "tag": "v1",      "new_sqlite_classes": [        "ChatRoom",        "RateLimiter"      ]    },    {      "tag": "v2",      "deleted_classes": [        "ChatRoom",        "RateLimiter"      ]    }  ]}[durable_objects]bindings = []
# Indicate that you want the ChatRoom and RateLimiter classes to be callable as Durable Objects.[[migrations]]tag = "v1" # Should be unique for each entrynew_sqlite_classes = ["ChatRoom", "RateLimiter"]
[[migrations]]tag = "v2"deleted_classes = ["ChatRoom", "RateLimiter"]Then run npx wrangler deploy.
To delete your Worker:
- 
In the Cloudflare dashboard, go to the Workers & Pages page. Go to Workers & Pages
- 
In Overview, select your Worker. 
- 
Select Manage Service > Delete. For complete instructions on set up and deletion, refer to the README.mdin your cloned repository.
By completing this tutorial, you have deployed a real-time chat application with Durable Objects and Cloudflare Workers.
Continue building with other Cloudflare Workers tutorials below.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark