Automation of Technology using Python-Script
Automation of Technology using Python-Script
data:image/s3,"s3://crabby-images/8a184/8a184b62c2a070e8c8bf1587cb9642ae07bc5a4c" alt="Image for post"
To Integrate Docker With Python3
Description
— — — — — — — — — — — — — — — — — — — — — — — —
- To Configure Docker on Top of REDHAT LINUX 8
- To Start Docker
- To Stop Docker
- To launch a container on Docker
- To Start and attach Container (if already exists)
- To stop container
- To check for Running Container
- To check for all container (Either running or stopped)
- To delete/remove the container on docker
— — — — — — — — — — — — — — — — — — — — — — — — —
SEE MENU OF DOCKER ON PYTHON:
data:image/s3,"s3://crabby-images/16eb6/16eb646670be4a00e3b65d074096b8a22f95b37e" alt="Image for post"
STEP 1.
- To Configure Docker on Top of REDHAT LINUX 8
data:image/s3,"s3://crabby-images/4b5a5/4b5a5a54f4b3ca445e3a040d1963e78aa5f76333" alt="Image for post"
There has to some step to follow to configure docker on Redhat linux 8.
data:image/s3,"s3://crabby-images/41869/4186983d209d02f2682bb089f89dfafcb4c9b60f" alt="Image for post"
In my case docker repo is already exists i have configured so i pressed ‘y’
data:image/s3,"s3://crabby-images/16023/16023f03a4f429c3283354f1e8e3c03038317c73" alt="Image for post"
and My Docker configured.
STEP 2.
To Start Docker
data:image/s3,"s3://crabby-images/90c87/90c87b836b283e74141a5216daf45ad1684caa40" alt="Image for post"
STEP 3.
To Stop Docker
data:image/s3,"s3://crabby-images/c5278/c5278eee004e7fcc0a5e0a9a0e866f428fa2a46b" alt="Image for post"
STEP 4.
To Launch a container/OS on Docker
data:image/s3,"s3://crabby-images/c549a/c549aed365536c55f3ae5084dea26abf5a86be68" alt="Image for post"
There has some step required to Launch container
- Download container
- Install and run container
data:image/s3,"s3://crabby-images/d2ece/d2ece12abdfce5119040bbd6d940b73d5c269efb" alt="Image for post"
In my Case I downloaded Ubuntu and Install Ubuntu 14.04.
See ,In last CLI of Ubuntu coming up.
STEP 5.
To start and Launch a container(if already exists)
In my case I just launched an Ubuntu container named os4.
data:image/s3,"s3://crabby-images/0e807/0e807299c6ae330f1e3fec556834d2159833f71e" alt="Image for post"
STEP 6.
To stop container/OS
In my case I stopped os4 container.
data:image/s3,"s3://crabby-images/aff6d/aff6dc6361790cd57f0f9f1252501ebf17a2d346" alt="Image for post"
STEP 7.
To check for Running Container
data:image/s3,"s3://crabby-images/a0534/a0534af1a00ca26d83066e1d0b1ac72c7a11e466" alt="Image for post"
here, you can see no container is running . I launched os4 and stopped os4 so no container is running.
STEP 8.
To check for all container (Either running or stopped)
data:image/s3,"s3://crabby-images/fe3a9/fe3a9db95efb8acdc3c118b48e62fca7ada1c532" alt="Image for post"
See, there are 3 contained which are in exited state.
STEP 9.
To delete/remove the container on docker
data:image/s3,"s3://crabby-images/9bef1/9bef12732e70ef7bd22534e7cf2fb57504b59396" alt="Image for post"
to removing container from Docker you have to know the id of container . so here, asking do you know container id . i do not so i pressed ’n’ ,then program showed me id Then I copied and gave the ID then It removed.
Hadoop
First we try and automate the process of setting up a system as a hadoop node, that maybe a namenode (master), datanode(slave) or even a client node in a hadoop cluster.
First we have to setup and install hadoop on our LinuxOS. This involves two steps:
Step1 — Installing jdk
Step2 — Installing hadoop
jdk-8u171-linux-x64.rpm
hadoop-1.2.1–1.x86_64.rpm
These are the rpm files required for our setup.
Either get these files first and then use ‘rpm –ivh jdk-8u171-linux-x64.rpm ‘ and ‘hadoop-1.2.1–1.x86_64.rpm — force’ commands respectively, or we can further automate this process by configuring our yum or dnf repository and using ‘yum install jdk-8u171-linux-x64.rpm’ and ‘yum install hadoop-1.2.1.-1.x86_64.rpm’ also we could use wget() and yum or dnf together to automate both download and installation together.
Now after installation we display our hadoop menu to execute further configurations according to requirements. These are the choices available:
Configure Hadoop as a namenode
Configure Hadoop as a datanode
Configure hadoop as a client node
User can choose the appropriate serial no.
For namenode:
import os,json
from requests import get
ip=json.loads(get(‘https://api.ipify.org?format=json').text)
ip=ip[‘ip’]
Using the above lines we can get access to the user’s system’s public IP address, it makes use of an expternal API
with open(‘/etc/hadoop/core-site.xml’, ‘w+’) as file:
str =“<property>\n<name>fs.default.name</name>\n<value>hdfs://”+ip+”:9001</value>\n</property>\n”
file.write(str)
with open(‘/etc/hadoop/hdfs-site.xml’, ‘w+’) as file:
str =“<property>\n<name>dfs.name.dir</name>\n<value>/nn1</vale>\n</property>\n”
file.write(str)
Now we have written both core-site and hdfs configuration files for a Hadoop namenode.
os.system(“hadoop namenode -format”)
Formatting the space for namenode
os.system(‘hadoop-daemon.sh start namenode’)
This helps us to start hadoop’s process on our OS.
For Datanode:
ip = str(input(“ Enter Master’s IP:”))
with open(‘/etc/hadoop/core-site.xml’, ‘w+’) as file:
Str=“<property>\n<name>fs.default.name</name>\n<value>hdfs://”+ip+”:9001< /value>\n</property>\n”
file.write(str)
with open(‘/etc/hadoop/hdfs-site.xml’, ‘w+’) as file:
str =”<property>\n<name>dfs.data.dir</name>\n<value>/dn1</value>\n</p roperty>\n”
file.write(str)
Asking for master’s public IP and writing both configuration files for hadoop datanode.
os.system(‘hadoop-daemon.sh start datanode’)
Starting hadoop’s process as a datanode on our OS.
For client setup:
ip = str(input(“ Enter Master’s IP:”))
with open(‘/etc/hadoop/core-site.xml’, ‘w+’) as file:
str = “<property>\n<name>fs.default.name</name>\n<value>hdfs://”+ip+”:9001</value>\n</property>\n”
file.write(str)
Asking for master’s public and configuring hadoop’s core-site.xml file for setting up the system as a client on a cluster.
Automating LVM Partition using Python-Script
Automating LVM Partition using Python-Script
data:image/s3,"s3://crabby-images/a47a4/a47a4a8dd840e5a4e896d80f10eddc891c1fd87d" alt="Image for post"
data:image/s3,"s3://crabby-images/0443c/0443c6b4098992d64dd511d13e86eebcb9e44fd6" alt="Image for post"
data:image/s3,"s3://crabby-images/5a9f6/5a9f61e92bc70029d2a5d9fd130e366fc999e462" alt="Image for post"
data:image/s3,"s3://crabby-images/8bb40/8bb409783a3bb2e95a8292483bf90374eebbdd52" alt="Image for post"
data:image/s3,"s3://crabby-images/2a1f4/2a1f4bc789de71d1c36191d3182be2f7f04af04c" alt="Image for post"
data:image/s3,"s3://crabby-images/a9859/a98593ac9866aecab4540379c89d52b8bc436c3a" alt="Image for post"
data:image/s3,"s3://crabby-images/439b7/439b7861a29908bca2687a7326df850daa5facf9" alt="Image for post"
data:image/s3,"s3://crabby-images/e5d5e/e5d5ecbcb358f7699e2902bbee503712a5e0fbc8" alt="Image for post"
data:image/s3,"s3://crabby-images/8cd8f/8cd8fde0f3ade49aeca7f48e79e51bc4c1ec32bc" alt="Image for post"
data:image/s3,"s3://crabby-images/37b04/37b041be3c51943875c4975b88716943e8e4584b" alt="Image for post"
data:image/s3,"s3://crabby-images/3b89d/3b89dccb72f22920819684f460039a5345734071" alt="Image for post"
data:image/s3,"s3://crabby-images/d4c86/d4c86746f4e500811b4e8db2d3e788589ca3fd76" alt="Image for post"
data:image/s3,"s3://crabby-images/74c78/74c7870d3266fe283f693b1601de3a5776e491f7" alt="Image for post"
data:image/s3,"s3://crabby-images/9fe43/9fe434f0082571ca57d6f17406010d4e67ff11ff" alt="Image for post"
data:image/s3,"s3://crabby-images/bc8d4/bc8d412e73c1370d9174211f348102dc563a53db" alt="Image for post"
data:image/s3,"s3://crabby-images/04575/045757289b82443cfa26292b370dc44723af7319" alt="Image for post"
Automating AWS with Python Script
Key Features:-
✔Creates a key pair.
✔Creates a new ec2 instance.
✔Creates a security group.
✔Start an ec2 instance.
✔Creates an ebs volume.
✔Creates a cloudfront distribution.
✔Creates a s3 bucket.
✔Attach an ebs volume to an instance.
✔Detach an ebs volume.
✔Describe ec2 instances.
✔Terminate ec2 instances.
So, the first and foremost question that comes in our mind is →
What is AWS?
Amazon Web Services (AWS) is an evolving cloud computing platform provided by Amazon. It provides a mix of infrastructure as a service (IaaS), Platform as a service (PaaS), and Packaged software as a service (SaaS) offerings.
AWS can be accessed in 3 ways
- Using WEB UI(Web Interface (Console)).
- Automation (Application Programming Interface).
- Using CLI (Command Line Interface).
What is AWS CLI?
Let me start with an example….In WEB UI, we are using Chrome or any other browser as an interface to connect with AWS, Similarly… In CLI, to connect with AWS, we need an interface and this interface is AWS CLI.
data:image/s3,"s3://crabby-images/6fd4e/6fd4ef44bff3d241678ab70a8220afecdf6bab0c" alt="Image for post"
Why do we use AWS CLI if we already have a WEB UI provided?
In the WEB UI, everything needs to be done manually and the CLI is mostly used to automate the things and make things happen faster or agile.
There are some benefits of using CLI over WEB UI such as -
If we want to launch many instances( let’s take a number ..say 10) in one go, we can’t do so using WEB UI. In WEB UI, we need to launch an instance manually 10 times, but in CLI, we can reduce the efforts and can launch many instances altogether.
If you are using a Linux server with no GUI, then you will have to manage AWS through the CLI. The CLI isn’t as user friendly as the web console (at least for beginners), but it does offer power users certain advantages. Writing custom scripts to automate processes is one major advantage that comes to mind. Generally, people who use the CLI like it for it’s more granular control over AWS services.
AWS documentation is really robust, with fully detailed docs listing all the CLI commands for various services. If you already have strong Linux skills, then using the CLI to manage AWS services should be fairly easy for you.
For the latest version of the AWS CLI: https://awscli.amazonaws.com/AWSCLIV2.msi
We need to download and install it on the top of the Operating System with which we are working. So, after installing to check whether it is successfully installed, use the command :
aws --version
data:image/s3,"s3://crabby-images/b95f3/b95f37fe9167139ab13db9a85dff1bfcd8c33e4a" alt="Image for post"
Now, as we can see AWS CLI is installed.
data:image/s3,"s3://crabby-images/7c774/7c774af5c9b1beaa0fa5a1c988b3e1c670ab20b4" alt="Image for post"
In order to access the AWS services from the CLI, we need to set-up an IAM user with appropriate permissions.
There are some steps to create an IAM user.
Step 1. From the AWS dashboard, search for the “IAM” service and select it.
Step 2. Now, you will be seeing something like shown below, from there select the “Add user” icon under the “Users”.
data:image/s3,"s3://crabby-images/f61fb/f61fb2cbc6c594ee056173f913766638f49b395d" alt="Image for post"
Step 3. On this screen, provide the details for the IAM user:
- User name = geekylane-CLI
- Access type = Programmatic access
We have only checked the “Programmatic access” because we only want this user to have access to “Command Line Interface”.
If you want to access it from the AWS management console also,you can select the second option too.
Step 4. Set Permissions →
Go with → Attach Existing Policies Directly.
Now select → POWER USER ACCESS
Create User
Remember I did not create any security group or any key pair while creating this IAM user.
Step 5. Download “credentials.csv”
On this screen, you will be only prompted to download the “credentials.csv” file only once, so make sure you download them to your computer at this point.
data:image/s3,"s3://crabby-images/9a01e/9a01eaa84a8afc74178d29d48342fcc1579e5c4d" alt="Image for post"
So now we are done with the set-up of IAM user.
We now need to configure the IAM User that we just created. For the first time, we need to run this command.
aws configure
Now, we are done with the configuration/login part.
I verified it by veiwing all the previously present instance using the command
The name of the command.
NAME
describe-instances
data:image/s3,"s3://crabby-images/4ec50/4ec5057bb5a804c8b5f2f9eaf800783b50b28a74" alt="Image for post"
How can we create a new Key-Pair in our AWS account?
You can get help with any command when using the AWS Command Line Interface (AWS CLI). To do so, simply type help
at the end of a command name.
For example, the following command displays help for the general AWS CLI options and the available top-level commands.
$ aws help
The following command displays the available Amazon Elastic Compute Cloud (Amazon EC2) specific commands.
$ aws ec2 help
The following example displays detailed help for the Amazon EC2
Now we can go with creating a key pair using the command provided in ec2 help. To create a key pair, use the create-key-pair command with the --query
option, and the --output text
option to pipe your private key directly into a file.
aws ec2 create-key-pair --key-name taskkey
data:image/s3,"s3://crabby-images/782fe/782feae5a54393a66da7727ab62c1a99d6e54565" alt="Image for post"
Now if i want to verify that my keypair is created successfully
I can do so by checking it in AWS management console too.
data:image/s3,"s3://crabby-images/f8f5f/f8f5fad8db928fe8fb0c77eea853f3cd259d15ab" alt="Image for post"
We can clearly see here that “taskkey “ is created.
How can we create a security group in our AWS account through CLI?
A question might arise in your mind..
What is a Security Group?
Amazon offers a virtual firewall facility for filtering the traffic that crosses your cloud network segment; but the way that AWS firewalls are managed differs slightly from the approach used by traditional firewalls. The central component of AWS firewalls is the “security group,” which is essentially what other firewall vendors would call a policy (i.e., a collection of rules)
Usually we create security group through AWS management console .
An example of how we create it using AWS Management Console is given below →
data:image/s3,"s3://crabby-images/3effc/3effc46c6f791ba024f217ab501fbb7f85b966f1" alt="Image for post"
But now we want to create it through CLI …
So now we are creating a security group..
Here i have given the group name → “My_Security “ and the group description →” Help”….You can give an appropriate group description .I just gave it for a test purpose.
data:image/s3,"s3://crabby-images/6a0ed/6a0ed9690fd403b2a644909db16c843fd7c4cbb2" alt="Image for post"
— description (string) : used to give the description for the security group. This is informational only.
— group-name (string) : used to give the name of the security group.
— vpc-id (string) : [EC2-VPC] The ID of the VPC( Virtual Private Cloud) which is required for EC2-VPC.
So, we have our security group created.
data:image/s3,"s3://crabby-images/c55bf/c55bf31f2a23b9b372f2785aac5684e9e753c983" alt="Image for post"
How can we create an EC2 instance from above created Security Group and Key pair using CLI ?
Now, lets create an EC2 instance. This instance will have the keypair and security groups attached that we created just now.
aws ec2 run-instances
--image-id ami-0e306788ff2473ccb
--instance-type t2.micro
--count 1
--subnet-id subnet-00b114a570c91caa6
--security-group-ids sg-04193d748e5fbc442
--key-name taskkey
data:image/s3,"s3://crabby-images/a32cb/a32cb22f6897104501a3a8fe1223bd454d9cd5c5" alt="Image for post"
Our instance is created finally.
data:image/s3,"s3://crabby-images/1120c/1120ccfd391dfb05b076e26628c806ce4c16591a" alt="Image for post"
The instance which is at the top and has no name is the instance we just created.
How can we create an EBS volume of 1GB from CLI ?
EBS comes under the EC2 service of AWS.
The volume type will be general purpose SSD Volume.
aws ec2 create-volume
--availlability-zone ap-south-1a
--size 1
--volume-type gp2
data:image/s3,"s3://crabby-images/85048/85048a8b7a03e3dd904e1e33a7a88ea78c848c4c" alt="Image for post"
As we can clearly see that we created an EBS volume of 1 GB.
data:image/s3,"s3://crabby-images/affed/affedd48a701257bb2dabcc43a2307fca1a6abfa" alt="Image for post"
The upper one is the volume we just created.
How can we attach the EBS volume we created to the instance we launched from CLI ?
This volume we need to attach to the EC2 instance we have created earlier.
aws ec2 attach-volume
--volume-id vol-0ef37a7b52cf3c87b
--instance-id i-05bea6de1322b3aec
--device /dev/xvdh
data:image/s3,"s3://crabby-images/bdbb9/bdbb9333c24dbce79ee997e8fe62a0235d38f298" alt="Image for post"
As we can see the instance we created is attached to the EBS volume we created.
How can we detatch the EBS volume?
For this ,we can use the following command
— -> aws ec2 detach-volume — volume-id vol-0deea87bd15afcf09
How can we terminate the AWS instance using CLI ?
To terminate the instance using CLI ,we can use the following command
→ aws ec2 terminate-instances — instance-ids i-0090de2f9625bf745
data:image/s3,"s3://crabby-images/e5a95/e5a95553f49c02b319917942057f92916c0af3fc" alt="Image for post"
data:image/s3,"s3://crabby-images/4b214/4b214fef14247cbc66ce45fa6e86bf30f78220dd" alt="Image for post"
ARTH- The School of Technologies
ARTH2020.18.13
Sai Kishen Kothapalli
Tamanna Verma
Vaibhav Maan
Rahul Kumar
Comments
Post a Comment