I know about scaling, you need to create a cluster or the machines like separated servers for database, for database of chat, for storage of user content, etc. to sync themselves but I have never involved with large scale app.