Azure DevOps Training Notes Sept 2024

Upgrade & Secure Your Future with DevOps, SRE, DevSecOps, MLOps!

We spend hours on Instagram and YouTube and waste money on coffee and fast food, but won’t spend 30 minutes a day learning skills to boost our careers.
Master in DevOps, SRE, DevSecOps & MLOps!

Learn from Guru Rajesh Kumar and double your salary in just one year.


Get Started Now!

Day 1

KIT - https://devopsschool.com/kit/master-in-devops-engineering.html


What is Docker?
=====================
	Tool | platform
	
	Container mgmt tool

	Container
		

	mgmt
		create - start - stop - restart - kill - pause - unp - remove
		=====================================================
		
		run
		----------------------
		pull - create - start - attached
		
	tool
		Save cost
		Save time
		Imp Quality

What you need to run 1 APP
============================
Apache

HARDWARE
	KERNAL
		DISK
		PROCESS
		NET
		USER
==============================================================
Docker Arch

	Docker Client --> Docker Server --> ContainerD --> kernel
	==============================	

		Docker Engine


	

Docker Workflow
https://www.devopsschool.com/blog/simple-docker-workflow-quick-start/

Container LifeCycle
create - start - stop - restart - kill - pause - unp - remove

Docker install
20.193.153.139
Docker Tutorials: How to Install Docker in Ubuntu?
rajesh Rajesh$1234567 https://devopsschool.com/path/
Standard DevOps Phases Lifecycle

Day 2 – Ansible _ part 1

What is Ansible?
==============================
	Config Mgmt
	For 
		SERVER(S)

	Whats there in SERVER
	OS
	HWD
	App
	file	C R U D
	dir	C R U D
	user	A E R
	group
	apt	 I R UP
	yum
	cmd	command/script
	bash	cmd/script

	Release
		Ansible - cmd - os - free
		Ansible Tower - PAID
		Ansible AWX  - FREE - GUI

	From Redhat

	using Python

Why Ansible?
	I WANT TO CHANGE 1000s of serverS parrelll

	Chef - Puppet  Efengine
	Udeploy Octopus Deploy

How it works?

Human --->>>>>>> ACS -----> ARS

		LINUX		ANY 
		python		Linux - python
				windows - ps3.0 + donet

		ansible		NR
		---------SSH ---- LINUX
		-------- WINRM --- WINDOWS

Component of Ansible (ACS)
	Ansible 
		- executables
		- Modules	- A code - in py - run in ARS - require param
				https://docs.ansible.com/ansible/2.9/modules/modules_by_category.html
		- plugins	- A code - in py - run in ACS
		- configfile	file

	Inventory
		LIST OF IP ADDRESS
			CMD
			FILE
			SCRIPT

	Playbook
		yaml 
		contains
			play
				Hosts: localhost | group of inventory
				Tasks:
					mod1 and its param
					mod2 and its param
					mod3 and its param
			
			play
				Hosts:
				Tasks:


			play
				Hosts:
				Tasks:

==========================================================================
Step 1 - Install Ansible	  DONE
https://www.devopsschool.com/blog/ansible-installation-and-configuration-guide/\

Step 2 - Ansible Adhoc Command - DONE
Step 3 - Ansible Inventory		DONE
Step 4 - Ansible Playbook
Step 5 - Ansible Roles
Step 6 - Ansible Vault

	
ACS
==============================	
20.193.137.161
ansible
GHSFGble$123456

===================================
What is your project
==================================
		- Write a code which would install/config  webserver in ubtunu\

Psucode
	========================================
	Step 1 - install apache2 in ub - apt-get install apache2 -y	=== apt - name=apache2 state=latest
	Step 2 - copy index.html to /var/www/html			copy ---- src=index.html dest:/var/www/html/index.html
	Step 3 - start apache 2 services -- - systemctl start apache2	service --- name=apache2 state=started

=================================================
ansible localhost -m apt -a"name=apache2 state=latest"
ansible localhost -m copy -a"src=index.html dest:/var/www/html/index.html"
ansible localhost -m service -a"name=apache2 state=started"


=================================================
ansible all -i 20.193.137.161, -m apt -a"name=apache2 state=latest" -u ansible -k
ansible all -i 20.193.137.161, -m copy -a"src=index.html dest=/var/www/html/index.html" -u ansible -k -b
ansible all -i 20.193.137.161, -m service -a"name=apache2 state=started" -u ansible -k -b


	LINUX				---- LINUX

					AUTH
						user - pass
						user - ket


					AUTH
						sudo with pass
						sudo without pass
						sudo with another user n pass


=================================================
ansible all -i inventory -m apt -a"name=apache2 state=latest" -u ansible -k -b
ansible all -i inventory -m copy -a"src=index.html dest=/var/www/html/index.html" -u ansible -k -b
ansible all -i inventory -m service -a"name=apache2 state=started" -u ansible -k -b

Day 2 – Ansible – Part 2


Inventory
	400
	
10.12.12.11
10.12.12.12
10.12.12.13
10.12.12.15
10.12.12.16

[web]
20.193.137.161
10.12.12.12
10.12.12.13

[db]
10.12.12.15
10.12.12.16

ansible web -i inventory -m apt -a"name=apache2 state=latest" -u ansible -k -b


- name: Install apache httpd  (state=present is optional)
  ansible.builtin.apt:
    name: apache2
    state: present

- name: Start service httpd, if not started
  ansible.builtin.service:
    name: apache2
    state: started


- name: Copy file with owner and permissions
  ansible.builtin.copy:
    src: index.html
    dest: /var/www/html/index.html

		

---
- name: Update web servers
  hosts: web

  tasks:
  - name: Install Apache in ubuntu
    ansible.builtin.apt:
      name: "apache2"
      state: latest
  - name: Copy index.html
    ansible.builtin.copy:
      src: index.html
      dest: /var/www/html/index.html
  - name: Starting a Apache Server
    ansible.builtin.service:
      name: "apache2"
      state: started
\

ansible-playbook -i inventory web.yaml -u ansible -k -b

========================================================================
CODING
	vars
	operators\
	cond
	loops
	functions
	class

What is ROLES?
		Dir structure
			dir
				tasks
				vars
				files
				template
				handlers
				library

- name: Print return information from the previous task
  ansible.builtin.debug:
    var: age

- name: Print return information from the previous task
  ansible.builtin.debug:
    var: name

- name: Print the gateway for each host when defined
  ansible.builtin.debug:
    msg: System {{ name }} has gateway {{ age }}


ansible-playbook -i inventory site.yaml -u ansible -k -b

---
- name: Update web servers
  hosts: web

  roles:
  - web



   1  clear
    2  cd
    3  ls
    4  mkdir rajesh
    5  cd rajesh/
    6  pwd
    7  sudo apt update
    8  sudo apt install software-properties-common
    9  sudo add-apt-repository --yes --update ppa:ansible/ansible
   10  sudo apt install ansible
   11  ansible
   12  ansible version
   13  ansible --version
   14  ls /usr/bin/ansi*
   15  ansible
   16  clear
   17  ansible localhost -m apt -a"name=apache2 state=latest"
   18  ansible localhost -m copy -a"src=index.html dest:/var/www/html/index.html"
   19  vi index.html
   20  ansible localhost -m copy -a"src=index.html dest:/var/www/html/index.html"
   21  ansible localhost -m copy -a"src=index.html dest=\/var/www/html/index.html"
   22  ansible localhost -m copy -a"src=index.html dest=/var/www/html/index.html"
   23  ls /var/www/html/index.html"
   24  ls /var/www/html/index.html
   25  ansible localhost -m service -a"name=apache2 state=started"
   26  ansible all -i 20.193.137.161, -m apt -a"name=apache2 state=latest"
   27  ansible all -i 20.193.137.161, -m apt -a"name=apache2 state=latest" -u ansible -k
   28  ansible all -i 20.193.137.161, -m apt -a"name=apache2 state=latest" -u ansible -k -b
   29  ansible
   30  ansible all -i 20.193.137.161, -m copy -a"src=index.html dest:/var/www/html/index.html" -u ansible -k -b
   31  ansible all -i 20.193.137.161, -m copy -a"src=index.html dest=/var/www/html/index.html" -u ansible -k -b
   32  clear
   33  vi inventory
   34  clear
   35  ansible all -i inventory -m apt -a"name=apache2 state=latest" -u ansible -k -b
   36  more /etc/ansible/ansible.cfg | grep fork
   37  more /etc/ansible/ansible.cfg\
   38  more /etc/ansible/ansible.cfg
   39  clear
   40  ls
   41  vi inventory
   42  ansible web -i inventory -m apt -a"name=apache2 state=latest" -u ansible -k -b
   43  clear
   44  ls
   45  vi web.yaml
   46  ansible-playbook -i inventory web.yaml -u ansible -k -b
   47  vi web.yaml
   48  ansible-playbook -i inventory web.yaml -u ansible -k -b
   49  ansible-playbook -i inventory web.yaml -u ansible -k -b --v
   50  ansible-playbook -i inventory web.yaml -vvv -u ansible -k -b
   51  clear
   52  ;ls
   53  clear
   54  l;s
   55  clear
   56  ls
   57  ansible-galaxy role init
   58  ansible-galaxy role -h
   59  ansible-galaxy role init web
   60  clear
   61  ls
   62  tree
   63  apt-get install tree -y
   64  clear
   65  tree
   66  clear
   67  ls
   68  more web.yaml
   69  vi web/tasks/main.yml
   70  vi web/vars/main.yml
   71  vi web/tasks/main.yml
   72  ls
   73  cp index.html web/files/
   74  tree
   75  vi site.yaml
   76  ls
   77  clear
   78  ls
   79  rm -rf index.html web.yaml
   80  ls
   81  ansible-playbook -i inventory site.yaml -u ansible -k -b
   82  history
   83  ansible-galaxy role install geerlingguy.java
   84  java\
   85  java
   86  vi site.yaml
   87  ansible-galaxy role install geerlingguy.java
   88  ansible-playbook -i inventory site.yaml -u ansible -k -b
   89  java
   90  clear
   91  vi inventory
   92  cleaer
   93  clear
   94  ls
   95  ansible-vault
   96  ansible-vault encrypt inventory
   97  cleare
   98  clear
   99  ls
  100  more inventory
  101  ansible -h
  102  ansible-playbook -i inventory site.yaml -b
  103  ansible-playbook -i inventory site.yaml -b -J
  104  history

Day 2 – Kubernetes – Part – 1

Master
- Api server -> POD -> Container -> Docker - Contd-> Image -> Google Registry
- etcd 	-> POD -> Container -> Docker - Contd-> Image -> Google Registry	
- schedular -> POD -> Container -> Docker - Contd-> Image -> Google Registry
- controller mgr -> POD -> Container -> Docker - Contd-> Image -> Google Registry
- kubelet
- Docker - containerd
- proxy -> POD -> Container -> Docker - Contd-> Image -> Google Registry

Worker
- kubelet
- Docker - containerd
- proxy -> POD -> Container -> Docker - Contd-> Image -> Google Registry


Workstation
- kubectl  ---> configfile
			APi Server add
			Cred

13.71.91.52
kubernetes
QSc#123456ddsd

https://www.devopsschool.com/blog/kubernetes-1-23-6-cluster-setup-master-and-worker-in-ubuntu-20-04/

https://stackoverflow.com/questions/43147941/allow-scheduling-of-pods-on-kubernetes-master

kubectl taint node k81 node-role.kubernetes.io/master:NoSchedule-

kubectl taint nodes --all node-role.kubernetes.io/control-plane-

node-role.kubernetes.io/control-plane

==================================================
API = ONE Service
		CREATE - READ - UP - DELETE
		
		GET PUT POST DELETE

	CREATE
		CMD	create
		
		YAML 	create -f yaml


	READ
		CMD	get 
		YAML	get -f yaml


	UPDATE
	
		CMD	edit 
		YAML	apply -f yaml

	DELETE
		CMD	delete
		YAML	delete -f yaml


  20  kubectl describe k81
   21  kubectl describe node  k81
   22  clear
   23  ls
   24  kubectl get pods --all-namespaces
   25  kubectl version
   26  kubectl\
   27  kubectl
   28  clear
   29  kubectl api-resources
   30  cleaer
   31  clear
   32  kubectl get ns
   33  kubectl get pods -n=kube-system
   34  cleasr
   35  clear
   36  kubectl
   37  clear
   38  kubectl get ns
   39  kubectl create ns rajesh
   40  kubectl get ns
   41  kubectl edit ns rajesh
   42  kubectl get ns
   43  kubectl describe  ns rajesh
   44  kubectl delete ns rajesh
   45  kubectl get ns

Day 2 – Kubernetes – Part – 3

POD
https://www.devopsschool.com/blog/kubernetes-pod-example-programs/


apiVersion: v1
kind: Pod
metadata:
  name: rajesh
  labels:
    app: helloworld
spec:
  containers:
  - name: devopsschool1
    image: scmgalaxy/nginx-devopsschoolv1
    ports:
    - name: nginx-port
      containerPort: 80

  47  clear
   48  kubectl explain pod
   49  kubectl explain pod.spec
   50  kubectl explain pod.spec.containers
   51  clear
   52  ls
   53  vi pod.yaml
   54  kubectl create -f pod.yaml -n=rajesh
   55  kubectl create ns rajesh
   56  kubectl create -f pod.yaml -n=rajesh
   57  kubectl get pods
   58  kubectl get pods -n=rajesh
   59  kubectl describe pod rajesh
   60  kubectl describe pod rajesh -n=rajesh
   61  clear
   62  ls
   63  clear
   64  ls
   65  vi pod.yaml
   66  kubectl apply -f pod.yaml -nrajesh
   67  kubectl delete -f pod.yaml -n=rajesh
   68  kubectl get pods
   69  kubectl get pods -n=rajesh
   70  kubectl apply -f pod.yaml -nrajesh
   71  kubectl get pods -n=rajesh
   72  kubectl get pods -n=rajesh -o wide
   73  curl http://192.168.0.6
   74  kubectl exec -it rajesh /bin/bash
   75  kubectl exec -it rajesh /bin/bash -n=rajesh
   76  clear
   77  kubectl logs rajesh -n=rajesh
   78  curl http://192.168.0.6
   79  kubectl logs rajesh -n=rajesh
   80  kubectl

Day 3 Terraform

Terraform
Azure Pipeline
==========================
What is terraform?
--------------------------
	IAAC
	Coding for infra

	Infra
		Azure
		AWS
		GC
		VMware
		https://registry.terraform.io/browse/providers

	in GO
	by Hashipcorp
	
	Community --- CMD	----> FREE 
	Enterprise --- GUI			- PAID

				PRIVATE
				CLOUD
		

Others
	ARM - > Azure
	CF --?> AWS
	GT -- GC
=========================================================
Why TF
------------
	CODING FOR EVERYTHING

How TF works? Aka TF Arch?
====================================



Step 1- Install TF 
https://developer.hashicorp.com/terraform/install

Step 2 - Download providers
			Using Code
Filename - anyname.tf
--------------------
		FOLDER
----------------------------------
one.tf 		2.tf 		3.tf

Terraform Tutorials: Basic Workflow Getting Started Guide
Step 3 - Write a code -------------------------------- VM Resource eg vm param | attributes image disk gr .tf resource1 vm att1 att2 resource2 att1 att2 resource3 net att1 att2 resource4 att1 att2 resource5 att1 att2
Azure Tutorials – How to create IAM user and assign Service Principal Access?
variable "prefix" { default = "rajtf" } resource "azurerm_resource_group" "example" { name = "${var.prefix}-resources" location = "Central India" } resource "azurerm_virtual_network" "main" { name = "${var.prefix}-network" address_space = ["10.0.0.0/16"] location = azurerm_resource_group.example.location resource_group_name = azurerm_resource_group.example.name } resource "azurerm_subnet" "internal" { name = "internal" resource_group_name = azurerm_resource_group.example.name virtual_network_name = azurerm_virtual_network.main.name address_prefixes = ["10.0.2.0/24"] } resource "azurerm_network_interface" "main" { name = "${var.prefix}-nic" location = azurerm_resource_group.example.location resource_group_name = azurerm_resource_group.example.name ip_configuration { name = "testconfiguration1" subnet_id = azurerm_subnet.internal.id private_ip_address_allocation = "Dynamic" } } resource "azurerm_virtual_machine" "main" { name = "${var.prefix}-vm" location = azurerm_resource_group.example.location resource_group_name = azurerm_resource_group.example.name network_interface_ids = [azurerm_network_interface.main.id] vm_size = "Standard_B1s" # Uncomment this line to delete the OS disk automatically when deleting the VM # delete_os_disk_on_termination = true # Uncomment this line to delete the data disks automatically when deleting the VM # delete_data_disks_on_termination = true storage_image_reference { publisher = "canonical" offer = "0001-com-ubuntu-server-jammy" sku = "22_04-lts" version = "latest" } storage_os_disk { name = "myosdisk1" caching = "ReadWrite" create_option = "FromImage" managed_disk_type = "Standard_LRS" } os_profile { computer_name = "hostname" admin_username = "testadmin" admin_password = "Password1234!" } os_profile_linux_config { disable_password_authentication = false } tags = { environment = "staging-raj" } } terraform { required_providers { azurerm = { source = "hashicorp/azurerm" version = "4.3.0" } } } provider "azurerm" { # Configuration options features {} client_id = "d4c19e56-d307-4536-b612-a93e117bbe68" client_secret = "" tenant_id = "49c4f74e-d704-424f-a964-32e76cc3ae50" subscription_id = "a112b874-8fea-4cdd-86ee-9b2cc8a59a7b" } https://www.devopsschool.com/blog/?s=terraform

Day 4

Web Tutorials
https://www.devopsschool.com/blog/

Slides
https://www.devopsschool.com/slide/
https://www.devopsschool.com/slides

Videos
https://www.devopsschool.com/blog/top-4-youtube-channel-for-free-videos-tutorials/
https://www.devopsschool.com/videos/
https://www.xopsschool.com/

Sample Program
https://www.devopsschool.com/blog/list-of-popular-projects-at-github-for-sample-lab-and-exercise/
https://www.devopsschool.com/blog/devopsschool-github-referenece/

Rajesh
https://www.rajeshkumar.xyz/

Subscribe
Notify of
guest

This site uses Akismet to reduce spam. Learn how your comment data is processed.

0 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
0
Would love your thoughts, please comment.x
()
x