Sunday, 28 January 2018

Docker guide for beginners - part 1


What is docker and Container?


Docker is a tool which helps developer life easier especially devops work. It helps us to create, deploy and running an application in easy manner using containers.

BTW what is container? containerization is one of the virtualization method and basically it is OS level virtualization concept. Container is an light weight image which contains executable piece of software application and its dependancies.

Think about normal application development and deployment, we need an instance with separate OS and need necessary packages to run an application and if we want to move our application to other environments (like dev, test, prod) we need to recreate entire instance/virtual machine and it is very tedious process.

But using software containers we can ship our code in to anywhere like physical containers,  Not like virtual machine, container won't have separate operating system. it uses host operating system's kernel so it is more efficient then VMs. container is like small instance which runs our application image.

Now just you can pack your code and dependance packages into container and run your container on anywhere with help of docker. Normally containers are very small and you can run many containers in single instance. We can move the containers to various environments like dev, test, prod and it uses same configuration.

Installing Docker(Community edition):


  

Once you installed docker, it will install docker client and docker server(also called docker machine/host) into your system. docker machine as an daemon process and it runs in background.  docker command is docker client and it speaks to docker server and return the response

Note:
Running docker without sudo : https://askubuntu.com/questions/477551/how-can-i-use-docker-without-sudo


run following commands in your command prompt to check docker client and server version details after successful installation. client and server versions normally same but it don't have to be same.

docker version





















If you want to get more details about your docker configuration and container information use "docker info" command

docker info




















Docker has two types of commands. Just simply type docker in command prompt and it will list out all the commands. Please find following standard format for using docker cli

docker <management command> <subcommand>
  • management commands
  • sub commands
docker





































Docker supports subcommands without management commands (old way). but latest subcommands are won't work without management commands. you can run docker commands in following two way.

docker container run
(or)

docker run


Docker Registry:


Docker's default registry is called dockerhub and it contains all container images similar to github. We can pull existing public images from docker-hub and can push our customized images to docker registry (it will be available for everyone). 

Docker image:


Docker image is a blueprint of an application. Docker images are basis of containers. We can search docker image in registry using docker search command.

docker search <image-name>
docker images can be classified 4 types.

  • Base images
    • It has no parent images. Usually it is like OS images Ex: ubuntu, python
  • Child Images
    • It is build based on parent images with additional functionality
  • Official images
    • It is created and maintained by docker folks
  • User images
    • It is custom images created by users. Normally it will be formatted like
      • <username>/<imagename>, 
      • ex: manojnuk50/flask-img
docker pull <image-name>
docker pull ubuntu:12.04

It will pull the ubuntu images from docker registry and store it your local system. 12.04 specifies the tag information. if not specifies the tag name it will download the latest images from registry.


What is unbuild images?



        Onbuild images are having multiple triggers. When we use unbuild image it will do some automate stuff for us. For example python inbuild image will do following steps while we creating containers

Image name: python:3-onbuild
  1. It will automatically copy requirements.txt file from current directory to container
  2. Run requirements.txt using pip install cmd
  3. Copy current directory files to /usr/src/app in container


Dockerfile:


    Dockerfile is a simple text-file that contains a list of commands that the Docker client calls while creating an image. It's a simple way to automate the image creation process.

Sample Docker file:
# base image
FROM python:3-onbuild
# specify the port that container should expos
EXPOSE 5000
# run the application
CMD ["python", "./app.py"]

FROM command specify the base image name. And expose 5000 specifies the port which need to expose
to outside the world.

CMD command specifies the command which needs to be execute when running the image in the container.
There can only be one CMD instruction in a Dockerfile. If you list more than one CMD then only the last CMD will take effect

Docker hello world:


Execute following hello-world docker command to check docker is installed properly in your machine. 

docker container run hello-world













It will download hello-world image from docker hub and pack it into container and then run the image. So run command create new container for every time.


Creating sample flask app using docker


Now we are going to create sample python flask hello world app using docker. First create a new folder and place following files into that folder. Refer this github repo

mkdir flask-helloworld
cd flask-helloworld

requirements.txt

Flask

app.py

from flask import Flask
app = Flask(__name__)

@app.route("/")
def hello():
    return "Hello World!"

if __name__ == "__main__":
    app.run(host='0.0.0.0')

Dockerfile

# base image
FROM python:3-onbuild
# specify the port that container should expos
EXPOSE 5000
# run the application
CMD ["python", "./app.py"]


Build docker image:


Following command read your Dockerfile and build your custom images. Go to the path where your Docker file locates and execute following command.

docker build -t <imagename>:<tag-name> <path of your dockerfile>
docker build -t sample-app:v1 .

final dot(.) specifies the current directory. -t specifies the tag name of the image



Listing docker images:


docker images
docker images -a



Running Docker container:


Docker run command is used to run a image inside the container. If the specified image available in local machine docker will take it from local or it will download from dockerhub and then store it to local machine.
docker container run <image-name>
docker container run sample-app:v1
It will create a new container and run the sample-app image inside the container.




If you want to execute the container in background use --detach (or) -d flag. It will detach the process from foreground and allow us to execute it into background. It will return the unique container id.

docker container run -p 5000:5000 -d sample-app:v1



Executing commands inside the container:


Following command allow us to login inside the container. It is very helpful to debug our application if something went wrong. we can execute linux commands inside the container

docker run -it <image-name> sh

docker run -it sample-app:v1 sh

List out available containers:


you can see the list of containers in your local machine using following command
docker container ls





Flags:



docker container run -p 5000:5000 -d --name flask-helloworld sample-app:v1

docker flags are used to specify the specific action or behavior of the container while running
  • --name 
    • it specifies the name of the container
    • if we are not specifying the container name it will assign random  name
  • --detach (or) -d
    • it will detach the process from foreground and execute it into background process
    • docker container run -p 80:80 -d hello-world 
  •  --publish (or) -p
    • it specifies the port number need to be exposed from container to host machine
    • docker container run -p 80:80 hello-world
    • if you are not specifying the port while running command it will automatically assign random ports

docker port <container-name/id>

it will show all the ports used by the container




Docker logs:


docker log command used see the logs generated by containers while executing application images. basically it will be stdout results. following commands are used to play with container logs.


docker logs 9a425901d134






It will show the entire logs results generated by sample-host container.

docker logs --tail 20 9a425901d134
It will show the entire logs results generated by sample-host container.
docker logs --help
docker container top 9a425901d134
It will show the top processes running inside the container. (similar to linux top command)


Stop the container:


Following command used to stop the container.
docker container stop 9a425901d134

Deleting containers:


Every run docker creating new containers so it will eat disk space, so best practice is cleanup the containers once done with that.

docker container rm <container id>

docker container rm 9a4
docker rm $(docker ps -a -q -f status=exited)

  • Above command will delete all the containers created in local machine
  • -q only returns numeric Ids
  • -f filters output based on status
  • first 3 character of container id is enough to mention while deleting. it will be unique always


















Deleting Images:


docker rmi <image-id/name>

docker rmi $(docker images -a -q)














Conclusion:


In this part, I have convert some basic commands from docker. We will see more advanced concepts in next part.


















Thursday, 2 February 2017

Integrate pylint into git hook and pycharm

What is pylint:


Pylint is a source code, bug and quality checker for the Python programming language. It follows the style recommended by PEP 8, the Python style guide.[4] It is similar to Pychecker and Pyflakes, but includes the following features:
  • Checking the length of each line
  • Checking if variable names are well-formed according to the project's coding standard
  • Checking if declared interfaces are truly implemented.

Installing pylint:

Install following pylint package using pip installer

mac/unix:

    pip install pylint

windows:

   python -m pip install pylint

Once you installed pylint into your system, check the pylint version using following command to make sure pylint was installed properly or not.

 pylint --version

pylint example.py

Configure pylint into git hook:


Pre-commit hook for Git checking Python code quality. The hook will check files ending with .py or that has a she bang (#!) containing python.
The script will try to find pylint configuration files in the order determined by pylint. It also looks for a [pre-commit-hook] section in the pylint configuration for commit hook specific options.
pip install git-pylint-commit-hook
Next go to your git initialized folder and navigate into .git/hooks/ directory. Rename the existing template file "pre-commit.sample" into "pre-commit"
Delete everything in that file and paste this in the pre-commit file
#!/bin/sh
git-pylint-commit-hook

Usage

The commit hook will automatically be called when you are running git commit. If you want to skip the tests for a certain commit, use the -n flag,
 git commit -n.

pylint configuration

Settings are loaded by default from the .pylintrc file in the root of your repo.
[pre-commit-hook]
command=custom_pylint
params=--rcfile=/path/to/another/pylint.rc
limit=8.0
command is for the actual command, for instance if pylint is not installed globally, but is in a virtualenv inside the project itself.
params lets you pass custom parameters to pylint
limit is the lowest value which you want to allow for a pylint score. Any lower than this, and the script will fail and won’t commit.

Integrate Pylint into pycharm IDE:


step 1: 
Go to file -> settings 


Step2:

select "Tools -> External tools-> click add icon"



Step 3:

Fill the tool setting parameters. To be a little more flexible, you can use PyCharm macros. As an example use the value “$FilePath$” for Working directory and “$Promt$” for Parameters. This allows the use in other projects, too.



Step 4:

Now pylint is configured into your system. Right click the file and select pylint from external tools to run pylint for specific files












Sunday, 18 September 2016

How SMTP server works? and How to configure SMTP server for apache airflow?

What is SMTP?


     SMTP stands for Simple Mail Transfer Protocol. First of all what is protocol? Almost all your online activity made through the help of protocols. Protocol is the set of roles and guidelines which is help your computer to link up to networks everywhere.

    There are lot of protocols are there which are used for various purpose like send Email, File Transfer, Online shopping, read news etc. SMTP closely works with MTA (Mail Transfer Agent) which is running in your computer, so emails are moves from your computer's MTA to an another computer MTA.

How it works?


    In simple words SMTP Server is a machine just like our normal server which is designed for more specific purpose. Our machine email client connect SMPT server using specific port (usually port number 25).

If we send the email through SMTP server, first our email client makes request to SMTP server which is configured in your machine. 

SMTP server receive the request and verify your authentication credentials, once verification done then it is process further steps

The request contains message content, sender address, recipient email addresses and other information

Then the server send the request to recipient's mail server, recipient's server repeats the same process of authentication and verification.

Recipient's server verifies the sender and receiver addresses, message content, DNS issues, signature verification and more on.

Once everything fine, recipient mail server will deliver the message to recipient.


SMTP Providers:

 
 There are several SMTP providers available across the world. I have listed few common service providers below.


PROVIDER
URL
SMTP SETTINGS
Gmail
Gmail.com
Smtp.gmail.com
Yahoo
Yahoo.com
Smtp.mail.yahoo.com
Outlook.com (former Hotmail)
Outlook.com
Smtp.live.com
Bluewin
Bluewin.ch
Smtpauths.bluewin.ch
BT Connect
Btconnect.com
Mail.btconnect.tom
Comcast
Comcast.net
Smtp.comcast.net
Earthlink
Earthlink.net
Smtpauth.earthlink.net
AOL
Aol.com
Smtp.aol.com
Orange
Orange.net
Smtp.orange.net
Tin
Tin.it
Mail.tin.it
Tiscali
Tiscali.co.uk
Smtp.tiscali.co.uk
Verizon
Verizon.net
Outgoing.verizon.net
Virgin
Virgin.net
Smtp.virgin.net
Wanadoo
Wanadoo.fr
Smtp.wanadoo.fr
AT&T
Att.net
Outbound.att.net


Configure SMTP server in apachi airflow:


 
    Airflow is a python based platform for schedule and monitoring the workflows. Want to know more about airflow go through the airflow document.

Airflow allow us to send email notification when specific event occurs like job fails, retry, sla notification. It having email operator also you can send email based on your requirement. Before that we need to configure SMTP server for enable airflow can send email notification.

We need to add smtp configuration settings in airflow.cfg file which is usually located in airflow home folder (/root/airflow/).  Here I have using gmail SMTP server for below example configuration. 

Open airflow.cfg file in any editor and add configuration in [smtp] section.

[smtp]
# If you want airflow to send emails on retries, failure, and you want to use
# the airflow.utils.email.send_email_smtp function, you have to configure an smtp
# server here
smtp_host = smtp.gmail.com
smtp_starttls = True
smtp_ssl = False
smtp_user = <your gmail address>
smtp_port = 587
smtp_password = <password>
smtp_mail_from = <from mail address>

In default SMTP uses port 25, but if you using google SMTP server, you have to use port 587. Once done your configuration try using EmailOperator class in airflow to check the functionality.

send_mail = EmailOperator (
                         dag=dag_id,
                         task_id="simple_email_opearetor",
                         to=[''my_mail@gmail.com","second_mail@yahoo.com"],
                         subject="Testing",
                         html_content="<h3>Welcome to Airflow</h3>")