Multiple Django sites with shared codebase and DB

前端 未结 1 589
南笙
南笙 2020-12-16 03:52

I have created a Django proyect with 20 sites (one different domain per site) for 20 different countries. The sites share everything: codebase, database, urls, templates, et

1条回答
  •  醉梦人生
    2020-12-16 04:26

    So, I recently did something similar, and found that the strategy below is the best option. I'm going to assume that you are familiar with git branching at this point, as well as Heroku remotes. If you aren't, you should read this first: https://devcenter.heroku.com/articles/git#multiple-remotes-and-environments

    The main strategy I'm taking is to have a single codebase (a single Git repo) with:

    • A master branch that contains all your shared code: templates, views, URLs.
    • Many site branches, based on master, which contain all site-specific customizations: css, images, settings files (if they are vastly different).

    The way this works is like so:

    First, make sure you're on the master branch.

    Second, create a new git branch for one of your domains, eg: git checkout -b somedomain.com.

    Third, customize your somedomain.com branch so that it looks the way you want.

    Next, deploy somedomain.com live to Heroku, by running heroku create somedomain.com --remote somedomain.com.

    Now, push your somedomain.com branch code to your new Heroku application: git push somedomain.com somedomain.com:master. This will deploy your code on Heroku.

    Now that you've got your somedomain.com branch deployed with its own Heroku application, you can do all normal Heroku stuff by adding --remote somedomain.com to your normal Heroku commands, eg:

    • heroku pg:info --remote somedomain.com
    • heroku addons:add memcache:5mb --remote somedomain.com
    • etc.

    So, now you've basically got two branches: a master branch, and a somedomain.com branch.

    Go back to your master branch, and make another new branch for your next domain: git checkout master; git checkout -b anotherdomain.com. Then customize it to your liking (css, site-specific stuff), and deploy the same way we did above.

    Now I'm sure you can see where this is going by now. We've got one git branch for each of our custom domains, and each domain has it's own Heroku app. The benefit (obviously) is that each of these project customizations are based off the master branch, which means that you can easily make updates to all sites at once.

    Let's say you update one of your views in your master branch--how can you deploy it to all your custom sites at once? Easily!

    Just run:

    • git checkout somedomain.com
    • git merge master
    • git push somedomain.com somedomain.com:master # deploy the changes

    And repeat for each of your domains. In my environment, I wrote a script that does this, but it's easy enough to do manually if you'd like.

    Anyhow, hopefully that helps.

    0 讨论(0)
提交回复
热议问题