Skip to content

Commit

Permalink
docs: gitlab python flask use case in english
Browse files Browse the repository at this point in the history
Signed-off-by: Tiexin Guo <guotiexin@gmail.com>
  • Loading branch information
IronCore864 committed Jan 4, 2023
1 parent 4efa862 commit 5cdb138
Showing 1 changed file with 316 additions and 1 deletion.
317 changes: 316 additions & 1 deletion docs/use-cases/gitops-python-flask/4-gitlab-dtm-apps.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,318 @@
# GitLab + GitLab CI with DTM Apps

TODO
## 0 Goal

In this tutorial, we will try to achieve the following goals with DevStream:

1. Use Docker to install GitLab as a code warehouse (if GitLab is already installed on your server, you can skip this step);
2. Create a Python web application repository on GitLab, based on the [Flask](https://flask.palletsprojects.com/en/2.2.x/) framework;
3. Use GitHub CI to set up a basic CI pipeline for the warehouse we created;
4. Install [Argo CD](https://argo-cd.readthedocs.io/en/stable/) in _an existing Kubernetes cluster_ to implement GitOps;
5. Create an Argo CD application to deploy the web application generated in step 1.

> prerequisites:
>
> - [Docker](https://www.docker.com/) (GitLab uses Docker for installation)
> - Kubernetes cluster (Argo CD is installed in the Kubernetes cluster)
> If you want to follow along with this tutorial and try it yourself, but don't know how to get a Kubernetes cluster up and running locally, the following blog (also from DevStream) might help:
>
> - [Creating a Local Kubernetes Cluster from the Groud Up - a Tutorial of "Kind"](https://blog.devstream.io/posts/creating-a-local-k8s-cluster-with-kind/)
> - [Getting Started with minikube](https://blog.devstream.io/posts/getting-started-with-minikube/)
---

## 1 Overview

DevStream will use the following plugins to achieve the goals described in [Section 0](#):

1. [gitlab-ce-docker](../../plugins/gitlab-ce-docker.md): used to install GitLab in Docker;
2. [repo-scaffolding](../../plugins/repo-scaffolding.md): used to create a Python web application repository on GitLab;
3. [gitlab-ci](../../plugins/gitlab-ci.md): used to set up the basic CI pipeline for the warehouse we created;
4. [helm-installer](../../plugins/helm-installer/helm-installer.md): used to install Argo CD in a Kubernetes cluster;
5. [argocdapp](../../plugins/argocdapp.md): Used to create an Argo CD application to deploy the web application generated in step 1.

We will accomplish these goals in two steps:

1. Write a configuration file to complete the installation of tools, GitLab and Argo CD;
2. Write a configuration file to complete the creation of subsequent pipelines and code warehouses, and deploy them to Argo CD.

> Note: In fact, the installation and configuration of DevOps tools can be completed in the same configuration file, but GitLab is special, requiring the user to manually create a token after the installation is complete, so we split the tool installation separately.
---

## 2 Getting Started: Download DevStream (`dtm`)

Create a test directory for this tutorial:

```bash
mkdir test
cd test/
```

In the newly created directory, execute:

```shell
sh -c "$(curl -fsSL https://download.devstream.io/download.sh)
```
This script will download the corresponding `dtm` binary file according to your operating system and save it to the current directory. Then, give it executable permissions.
> Optional: You can move `dtm` to a directory in your $PATH environment variable. For example: `mv dtm /usr/local/bin/`. In this way, you can run `dtm` directly without prefixing it with `./`.
>
> For more installation methods, see [Install dtm](../../install.md).
## 2 Install GitLab And Argo CD
### 2.1 Prepare Config
Create file `config-tools.yaml`. Modify `vars` to your values:
```yaml title="config-tools.yaml"
config:
state:
backend: local
options:
stateFile: devstream-1.state
vars:
gitlabHostname: gitlab.example.com
gitlabSSHPort: 30022
gitlabHttpPort: 80
gitlabHttpsPort: 30443
tools:
- name: gitlab-ce-docker
instanceID: default
dependsOn: []
options:
hostname: [[ gitlabHostname ]]
gitlabHome: /srv/gitlab
sshPort: [[ gitlabSSHPort ]]
httpPort: [[ gitlabHttpPort ]]
httpsPort: [[ gitlabHttpsPort ]]
rmDataAfterDelete: false
imageTag: "rc"
- name: helm-installer
instanceID: argocd
```
And modify the `/etc/hosts` file of the server to add the domain name resolution of `gitlab.example.com`. If your server ip is 44.33.22.11, you can configure it like this:
```text title="/etc/hosts"
44.33.22.11 gitlab.example.com
```
### 2.2 Init
Run the following command to download the plugins required to install GitLab and Argo CD:
```shell
dtm init -f config-tools.yaml -y
```
### 2.3 Apply
Run the following command to install GitLab and Argo CD:
```shell
dtm apply -f config-tools.yaml -y
```
You'll see similar outputs to:
<script id="asciicast-wxdTxqwycg12UurbRqZpMvSym" src="https://asciinema.org/a/wxdTxqwycg12UurbRqZpMvSym.js" async autoplay=true></script>
### 2.4 Check Installation Results
#### 2.4.1 Access GitLab
You can configure the `44.33.22.11 gitlab.example.com` static domain name resolution record in your PC, and then access GitLab through `http://gitlab.example.com` in the browser (if the browser reports:
<figure markdown>
![GitLab Login](./gitlab-apps/gitlab-login.png){ width="1000" }
<figcaption>GitLab Login</figcaption>
</figure>
Run the following command to get GitLab's root password:
```shell title="get GitLab root Password"
docker exec -it gitlab bash
gitlab-rake "gitlab:password:reset"
```
<script id="asciicast-547097" src="https://asciinema.org/a/547097.js" async></script>
Login with root/YOUR_PASSWORD. We will use GitLab token later, so let's create one now:
<figure markdown>
![GitLab token](./gitlab-apps/gitlab-token.png){ width="1000" }
<figcaption>Generate GitLab token</figcaption>
</figure>
#### 2.4.2 Check Argo CD
We can see that Argo CD is installed into the `argocd` namespace of the Kubernetes cluster:
```bash
[root@ip-10-18-13-200 devstream]# kubectl get ns
NAME STATUS AGE
argocd Active 36s
default Active 6d4h
kube-node-lease Active 6d4h
kube-public Active 6d4h
kube-system Active 6d4h
[root@ip-10-18-13-200 devstream]# kubectl get pods -n argocd
NAME READY STATUS RESTARTS AGE
argocd-application-controller-0 1/1 Running 0 49s
argocd-applicationset-controller-7f4577c5fd-8z926 1/1 Running 0 49s
argocd-dex-server-7cdb45c7c9-nspgz 1/1 Running 0 49s
argocd-notifications-controller-65b77fb646-phdwh 1/1 Running 0 49s
argocd-redis-577c6c8f5c-nf5xm 1/1 Running 0 49s
argocd-repo-server-7bd9fd899c-7f6cp 1/1 Running 0 49s
argocd-server-6686bbcf68-fms5w 1/1 Running 0 49s
```
---
## 3 Create and Deploy the App
### 3.1 Prepare Config
Create file `config-apps.yaml`. Modify `vars` to your values (pay extra attention to `dockerhubUser`):
```yaml title="config-apps.yaml"
config:
state:
backend: local
options:
stateFile: devstream-2.state
vars:
appName: myapp
gitlabURL: http://gitlab.example.com
defaultBranch: main
dockerhubUser: DOCKERHUB_USER
apps:
- name: [[ appName ]]
spec:
language: python
framework: flask
repo:
url: [[ gitlabURL ]]/root/[[ appName ]].git
branch: [[ defaultBranch ]]
token: [[ env GITLAB_TOKEN ]] # use "GITLAB_TOKEN" env var
repoTemplate:
url: https://github.com/devstream-io/dtm-repo-scaffolding-python-flask.git
ci:
- type: template
templateName: ci-pipeline
cd:
- type: argocdapp
pipelineTemplates:
- name: ci-pipeline
type: gitlab-ci
options:
imageRepo:
user: [[ dockerhubUser ]]
password: [[ env DOCKERHUB_TOKEN ]] # use "DOCKERHUB_TOKEN" env var
```
You may have noticed that the above configuration has something like `[[ env XXX ]]`, which means that we reference the "XXX" environment variable to fill the configuration. So we also need to set the following two environment variables:
```bash
export GITLAB_TOKEN="YOUR_GITLAB_TOKEN_HERE"
export DOCKERHUB_TOKEN="YOUR_DOCKERHUB_TOKEN_HERE"
```
> Note:
>
> If you don't know how to create a DockerHub token, you can refer to: [Manage access tokens](https://docs.docker.com/docker-hub/access-tokens/)
### 3.2 Init
Similarly, we need to download the required plugins from the config file. Run:
```bash
dtm init -f config-apps.yaml
```
### 3.3 Apply
Run:
```bash
dtm apply -f config-apps.yaml -y
```
And you'll get similar outputs to:
<script id="asciicast-547096" src="https://asciinema.org/a/547096.js" async></script>
### 3.4 Check Results
#### 3.4.1 Check the Repo Created in GitLab
<figure markdown>
![Flask repo](./gitlab-apps/repo-scaffolding.png){ width="1000" }
<figcaption>Flask repo</figcaption>
</figure>
#### 3.4.2 GitLab CI Workflow
Access `http://gitlab.example.com` in your browser, and click `CI/CD`, then `Pipelines`:
<figure markdown>
![GitLab CI Overview](./gitlab-apps/gitlabci-1.png){ width="1000" }
<figcaption>GitLab CI Overview</figcaption>
</figure>
#### 3.4.3 ArgoCD-Based Continuous Deployment
The CI workflow has already built a Docker image and pushed it to Dockerhub and Argo CD created by DevStream has deployed it:
```bash
[root@ip-10-18-13-200 devstream]# kubectl get deployment -n default
NAME READY UP-TO-DATE AVAILABLE AGE
myapp 1/1 1 1 101s
[root@ip-10-18-13-200 devstream]# kubectl get pods -n default
NAME READY STATUS RESTARTS AGE
myapp-b65774f56-8cmjc 1/1 Running 0 106s
[root@ip-10-18-13-200 devstream]# kubectl get services -n default
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 12d
myapp ClusterIP 10.101.148.66 <none> 8080/TCP 110s
```
We can access this application through port forwarding:
```bash
kubectl port-forward -n default svc/myapp 8080:8080
```
Visit `localhost:8080` in your browser, and you can see that the application returns a "Hello, World!". You're done!
---
## 4 Clean-Up
### 4.1 Delete the Web App
Run
```bash
dtm delete -f config-apps.yaml -y
```
### 4.2 Delete GitLab and Argo CD
Run
```bash
dtm delete -f config-tools.yaml -y
```
### 4.3 Delete Other Files
```bash
cd ../
rm -rf test/
rm -rf ~/.devstream/
```

0 comments on commit 5cdb138

Please sign in to comment.