More deployment instructions in README.md
This commit is contained in:
72
README.md
72
README.md
@@ -1,11 +1,77 @@
|
|||||||
# Blender Cloud
|
# Blender Cloud
|
||||||
|
|
||||||
Welcome to the [Blender Cloud](https://cloud.blender.org) code repo!
|
Welcome to the [Blender Cloud](https://cloud.blender.org) code repo!
|
||||||
Blender Cloud runs on the [Pillar](https://pillarframework.org) framework.
|
Blender Cloud runs on the [Pillar](https://pillarframework.org) framework.
|
||||||
|
|
||||||
## Quick setup
|
## Quick setup
|
||||||
Set up a node with:
|
Set up a node with these commands. Note that that script is already outdated...
|
||||||
|
|
||||||
```
|
```
|
||||||
bash <(curl -s https://gist.githubusercontent.com/fsiddi/a6e355a9b08cc1697955f6ce4f679633/raw/6715a2ab92a441abce96c1fc1edfd4eb685bd390/setup.sh)
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
mkdir -p /data/git
|
||||||
|
mkdir -p /data/storage
|
||||||
|
mkdir -p /data/config
|
||||||
|
mkdir -p /data/certs
|
||||||
|
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get -y install python-pip
|
||||||
|
pip install docker-compose
|
||||||
|
|
||||||
|
cd /data/git
|
||||||
|
git clone git://git.blender.org/pillar-python-sdk.git
|
||||||
|
git clone git://git.blender.org/pillar-server.git pillar
|
||||||
|
git clone git://git.blender.org/attract.git
|
||||||
|
git clone git://git.blender.org/blender-cloud.git
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Deploying to production server
|
||||||
|
|
||||||
|
First of all, add those aliases to the `[alias]` section of your `~/.gitconfig`
|
||||||
|
|
||||||
|
```
|
||||||
|
prod = "!git checkout production && git fetch origin production && gitk --all"
|
||||||
|
ff = "merge --ff-only"
|
||||||
|
pp = "!git push && if [ -e deploy.sh ]; then ./deploy.sh; fi && git checkout master"
|
||||||
|
```
|
||||||
|
|
||||||
|
The following commands should be executed for each subproject; specifically for
|
||||||
|
Pillar and Attract:
|
||||||
|
|
||||||
|
```
|
||||||
|
cd $projectdir
|
||||||
|
|
||||||
|
# Ensure there are no local, uncommitted changes.
|
||||||
|
git status
|
||||||
|
git stash # if you still have local stuff.
|
||||||
|
|
||||||
|
# pull from master, run unittests, push your changes to master.
|
||||||
|
git pull
|
||||||
|
py.test
|
||||||
|
git push
|
||||||
|
|
||||||
|
# Switch to production branch, and investigate the situation.
|
||||||
|
git prod
|
||||||
|
|
||||||
|
# Fast-forward the production branch to the master branch.
|
||||||
|
git ff master
|
||||||
|
|
||||||
|
# Run tests again
|
||||||
|
py.test
|
||||||
|
|
||||||
|
# Push the production branch and run dummy deploy script.
|
||||||
|
git pp # pp = "Push to Production"
|
||||||
|
|
||||||
|
# The above alias waits for [ENTER] until all deploys are done.
|
||||||
|
# Let it wait, perform the other commands in another terminal.
|
||||||
|
```
|
||||||
|
|
||||||
|
Now follow the above receipe on the Blender Cloud project as well.
|
||||||
|
Contrary to the subprojects, `git pp` will actually perform the deploy
|
||||||
|
for real.
|
||||||
|
|
||||||
|
Now you can press `[ENTER]` in the Pillar and Attract terminals that
|
||||||
|
were still waiting for it.
|
||||||
|
|
||||||
|
After everything is done, your (sub)projects should all be back on
|
||||||
|
the master branch.
|
||||||
|
Reference in New Issue
Block a user