2019-10-29 13:56:40 +01:00
# Playbooks
## deployment to a clean infrastructure
General remarks:
* GCP does not route any traffic to your services unless the service is "healthy". It might take a few minutes after startup before the services is classified as healthy. Until then you will only see some generic error message.
2020-01-22 19:04:13 +01:00
These are the steps to set up the build server on a clean infrastructure:
2019-10-29 13:56:40 +01:00
1. Configure the tools on your local machine:
```bash
./local_setup.sh
```
2020-01-22 19:04:13 +01:00
If you not running docker under your user, you might need to
`sudo gcloud auth login --no-launch-browser && gcloud auth configure-docker`
before running other commands under sudo.
2019-10-29 13:56:40 +01:00
1. Delete the old cluster, if it still exists:
```bash
cd kubernetes/cluster
./cluster_delete.sh
```
1. Create the cluster:
```bash
cd kubernetes/cluster
./cluster_create.sh
```
1. Create the disk storage, if it does not yet exist:
```bash
cd kubernetes/cluster
./disk_create.sh
```
1. SSH into the VM instance mounting the volume, find the mount point and then set
```bash
# go to the mount point of the volume
cd /var/lib/kubelet/plugins/kubernetes.io/gce-pd/mounts/jenkins-home
# change the permissions
sudo chmod a+rwx
```
1. Push the docker images to gcr.io:
```bash
cd containers
#for each subfolder:
./build_deploy.sh < foldername >
```
1. Deploy the stack:
```bash
cd kubernetes
./deploy.sh
```
1. Configure it
## creating basic authentication for reverse proxy
1. create auth file, based on [ingress-nginx documentation ](https://github.com/kubernetes/ingress-nginx/tree/master/docs/examples/auth/basic )
```bash
cd kubernetes/reverse-proxy
htpasswd -c auth < username >
# enter password at prompt
# add more users as required
kubectl create secret generic proxy-auth --from-file=auth --namespace=jenkins
```
2019-10-31 11:33:38 +01:00
## Creating docker containers on Windows
If you want to build/update/test docker container for Windows, you need to do this on a Windows machine. Here are the instructions to set up such a machine on GCP.
1. Pick a GCP Windows image with Desktop Support.
2019-12-13 18:30:08 +01:00
* pick a "persistent SSD" as boot Disk. This is much faster
* Add a "local scratch SSD" and use it as you workspace. This is much faster.
1. Format the local SSD partition and use it as workspace.
2019-12-18 16:07:34 +01:00
1. install [Chocolately ](https://chocolatey.org/docs/installation ):
```bat
@"%SystemRoot%\System32\WindowsPowerShell\v1.0\powershell.exe" -NoProfile -InputFormat None -ExecutionPolicy Bypass -Command "iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))" && SET "PATH=%PATH%;%ALLUSERSPROFILE%\chocolatey\bin"
```
2019-12-13 18:30:08 +01:00
1. Install git: `choco install -y git`
2019-12-18 16:07:34 +01:00
1. Install [Docker Enterprise ](https://docs.docker.com/ee/docker-ee/windows/docker-ee/ ) and reboot:
```powershell
Install-Module DockerMsftProvider -Force
Install-Package Docker -ProviderName DockerMsftProvider -Force
Restart-Computer
2019-12-13 18:30:08 +01:00
```
2019-12-18 16:07:34 +01:00
1. *optional:* install apps to help you work in the machine:
```powershell
2019-12-13 18:30:08 +01:00
choco install -y googlechrome vscode
```
1. Log out of the machine and log back in.
2019-12-16 15:26:05 +01:00
1. Repeat until success:
2019-12-13 18:30:08 +01:00
1. Start "Docker Desktop" and let it install it's dependencies.
Then reboot manually, when the error message pops up.
1. If you have trouble with the machine name: try to shorten it to 16 chars.
2019-12-16 15:26:05 +01:00
1. Configure the Docker credentials for GCP:
2019-12-18 16:07:34 +01:00
```powershell
2019-12-13 18:30:08 +01:00
gcloud components install docker-credential-gcr
docker-credential-gcr configure-docker
```
1. To build and run the current agent run:
2019-12-18 16:07:34 +01:00
```powershell
2019-12-13 18:30:08 +01:00
git clone https://github.com/google/llvm-premerge-checks
cd llvm-premerge-checks\containers
powershell .\build_run.ps1 agent-windows-jenkins
```
2019-12-16 15:42:29 +01:00
1. If you want to be able to push changes to github, you need to set up your github SSH keys and user name:
2019-12-18 16:07:34 +01:00
```powershell
2019-12-16 15:42:29 +01:00
ssh-keygen
git config --global user.name < your name >
git config --global user.email < your email >
```
2019-12-02 12:49:01 +01:00
2019-12-02 12:50:33 +01:00
To push push a new container run in `containers` :
2019-12-18 16:07:34 +01:00
```powershell
2019-12-02 12:50:33 +01:00
powershell .\build_deploy.ps1 < container-folder >
```
2019-12-02 12:49:01 +01:00
## Spawning a new windows agent
To spawn a new windows agent:
1. Go to the [GCP page ](https://pantheon.corp.google.com/compute/instances?project=llvm-premerge-checks&instancessize=50 ) and pick a new number for the agent.
1. Update the machine name in `kubernetes/windows_agent_create.sh` .
1. Run `kubernetes/windows_agent_create.sh`
1. Go to the [GCP page ](https://pantheon.corp.google.com/compute/instances?project=llvm-premerge-checks&instancessize=50 ) again
1. login to the new machine via RDP (you probably need to set the i).
1. In the RDP session: run these commands in the CMD window to start the docker container:
```cmd
powershell
2020-01-22 17:02:05 +01:00
Invoke-WebRequest -uri 'https://raw.githubusercontent.com/google/llvm-premerge-checks/master/scripts/windows_agent_bootstrap.ps1' -OutFile windows_agent_bootstrap.ps1
.\windows_agent_bootstrap.ps1
```
1. Wait for the machine to reboot, then login again and store the `gsutil` credentials in `build-agent-results_key` .
TODO: add documentation on how to create these.
1. run this script to start containers:
```cmd
2020-02-03 15:25:08 +01:00
powershell Invoke-WebRequest -uri 'https://raw.githubusercontent.com/google/llvm-premerge-checks/master/scripts/windows_agent_bootstrap.ps1' -OutFile windows_agent_bootstrap.ps1
2020-02-03 15:10:42 +01:00
2019-12-02 12:49:01 +01:00
.\windows_agent_bootstrap.ps1
```
2019-12-09 10:59:08 +01:00
## Testing scripts locally
2020-01-23 16:14:12 +01:00
Build and run agent docker image `sudo ./containers/build_run.sh agent-debian-testing-ssd /bin/bash` .
2019-12-09 12:09:53 +01:00
Within a container set environment variables similar to [pipeline ](https://github.com/google/llvm-premerge-checks/blob/master/Jenkins/Phabricator-pipeline/Jenkinsfile ).
2019-12-09 12:09:53 +01:00
Additionally set `WORKSPACE` , `PHID` and `DIFF_ID` parameters. Set `CONDUIT_TOKEN` with your personal one from `https://reviews.llvm.org/settings/user/<USERNAME>/page/apitokens/` .