#########################################################################################
#########################################################################################
A source code management platform is a central piece for all developers & CI/CD environments.
For this lab, I chose Gitea (https://gitea.io/), a lightweight SCR tool that I will install on the host RHEL4.
We will install Gitea as a Docker service, with Docker Compose.
First, once you are connected to RHEL4, retrieve locally this chapter:
cd
svn export https://github.com/YvosOnTheHub/LabNetApp.git/trunk/Kubernetes_v4/Addendum/Addenda12
cd Addenda12
If you have not yet read the Addenda08 about the Docker Hub management, it would be a good time to do so.
Also, if no action has been made with regards to the container images, you can find a shell script in this directory addenda12_pull_images.sh to pull images utilized in this scenario if needed. It uses 2 parameters, your Docker Hub login & password:
sh addenda12_pull_images.sh my_login my_password
Docker compose will start 2 containers, one for the MySQL Database used by Gitea, one for the frontend.
To connect to Gitea, you will need to use the following address: http://192.168.0.64:3000.
If you prefer to use a FQDN (http://gitea.demo.netapp.com:3000) instead of the IP, remove the 3 GITEA__server lines from the docker-compote.yml file & uncomment the ones related to the FQDN, after having updated the Domain (Alias: 192.168.0.64 = 'gitea'). Note that this whole page is described to work with the IP address.
$ docker-compose up -d
Creating network "gitea_gitea" with the default driver
Creating gitea_db_1
Creating gitea
This will also create a bunch of folders & files, including Gitea's own init file.
If you want to browse all the parameters, this file is located there: ~/gitea/gitea/gitea/conf/app.ini
The very first time you log into the Gitea UI, you will be asked to review the parameters.
For this demo, I would recommed creating an administrator account (demo/netapp123/[email protected]) which I will use for the rest of the lab.
& voilà, your repository is ready to be used!
In order to store your code, you will need to create a new repository. This can be achieved through the UI, or simply by calling a REST API:
$ curl -X POST "http://192.168.0.64:3000/api/v1/user/repos" -u demo:netapp123 -H "accept: application/json" -H "content-type: application/json" -d '{
"name":"test",
"description": "my first repo"
}'
Since we are going to use the command git to interact with this repository, let's configure it with the following parameters:
git config --global user.email lod.demo.netapp.com
git config --global user.name "lod"
git config --global credential.helper store
git config --global alias.adcom '!git add -A && git commit -m'
git config --global push.default simple
The credential parameter will store locally the username & password, while the alias parameter creates a command that takes into account new files & commits them locally. You then still need to push them to the Gitea repository. All these parameters are available in the ~/.gitconfig file.
Let's create a new folder with a small README file.
cd
mkdir testrepo
cd testrepo
echo "Hello You " >> README.md
The initial workflow with GIT is done in 3 steps (in this lab): initialization, add files, commit them locally.
$ git init
Initialized empty Git repository in /root/testrepo/.git/
$ git add .
$ git commit -m "initial commit"
[master (root-commit) 06b36b8] initial commit
1 file changed, 1 insertion(+)
create mode 100644 README.md
The next step consists in sending the data to the Gitea repo. As it is the first time you connect to Gitea with git, you will be asked to enter some credentials (demo/netapp.123). Those will be stored in the ~/.git-credentials file.
git remote add origin http://192.168.0.64:3000/demo/test.git
git push -u origin master
Connecting to Gitea's UI, you can see some content in your repository !
Let's modify the README file & go through the git process to update the repository (try out the git alias!).
You will notice that this time, the credentials were not requested.
echo "How are you ?" >> README.md
git adcom "first update of the README file"
git push
There you go, you are all set to use a Source Code Repository in the Lab on Demand.