Saturday, February 25, 2017

Installing Docker (OperatingSystem : CentOs 7)


There are two method to Install Docker in CentOS 7

[METHOD1]: INSTALL WITH YUM 

$ cd /etc/yum.repos.d yum.repos.d]$ ls -la CentOs-Base.repo,CentOs-CR.repo,CentOs-Debuginfo.repo, CentOs-fasttrack.repo,CentOs-Media.repo,CentOs-Soureces.repo CentOs-Vault.repo,epel.repo, epel-testing.repo $ sudo vim docker.repo [dockerrepo] name=Docker Repository baseurl=https://yum.dockerproject.org/repo/main/centos/7/ enable=1 gpgcheck=1 gpgkey=https://yum.dockerproject.org/gpg $sudo yum update $sudo yum install docker-engine $sudo systemctl enable docker //To enable our docker service $sudo systemctl start docker //start the docker $sudo systemctl status docker //check the status of the docker By default the docker create a file in "/var/run" directory that own by the docker group called docker.sock, if you are not the member of that group or you are not root by default you dont have access to the docker daemon. $ sudo usermod -aG docker your_username //add your user to docker group $ docker images $ docker run hello-world // pull the image and create a Container

[METHOD2]: INSTALL WITH SCRIPT 

$ sudo yum update //make sure your existing yum packages are up-to-date $ curl -fsSL https://get.docker.com/| sh //run the docker installation script This Script adds the docker.repo repository and installs Docker. $ sudo service docker start

UNINSTALL DOCKER: 

$ yum list installed |grep docker //list the package you have installed $ sudo yum -y remove docker-engine.x86_64 //remove the package This command does not remove images, containers, volumes or user-created configuration files on host. $ rm -rf /var/lib/docker //delete all your images,containers,volumes

Demonstrate Dockerswarm to create, add, deploy and inspect the service

Create a swarm

(Make sure the Docker Engine daemon is started on the host machines) Step1:Open a terminal and ssh into the machine where you want to run your manager node. Step2:$docker swarm init --advertise-addr 192.168.99.100 To add a worker to this swarm, run the following command: docker swarm join \ --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0xx\ 192.168.99.100:2377 To add a manager to this swarm, run "docker swarm join-token manager" and follow the instructions. Step3:Run docker info to view the current state of the swarm:$ docker info Step4:Run the docker node ls command to view information about nodes: $ docker node ls

Add nodes to the swarm 

(Once you've created a swarm with a manager node, you're ready to add worker nodes) Step5: Open a terminal and ssh into the machine where you want to run a worker node Step6: create a worker node joined to the existing swarm $ docker swarm join\ --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0xx\ 192.168.99.100:2377 If you don't have the command available, you can run the following command on a manager node to retrieve the join command for a worker: $ docker swarm join-token worker Step7: Open a terminal and ssh into the machine where you want to run a second worker node[worker2] Step8: $ docker swarm join\ --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0\ 192.168.99.100:2377 Step9:Open a terminal and ssh into the machine where the manager node runs. $ docker node ls ID HOSTNAME STATUS AVAILABILITY MANAGER 03g1y59jwfg7 worker2 Ready Active 9j68exjopxe7 worker1 Ready Active dxn1zf6l61qs * manager1 Ready Active Leader

Deploy a service to the swarm 

(After you create a swarm, you can deploy a service to the swarm. For this tutorial, you also added worker nodes, but that is not a requirement to deploy a service) Step1:Open a terminal and ssh into the machine where you run your manager node Step2:$ docker service create --replicas 1 --name helloworld alpine ping docker.com Step3:$ docker service ls //shows the list of running services

Inspect a service on the swarm 

(When you have deployed a service to your swarm, you can use the Docker CLI to see details about the service running in the swarm) Step1:If you haven't already, open a terminal and ssh into the machine where you run your manager node Step2:$docker service inspect --pretty helloworld //display the details about a service Step3:Run docker service ps <SERVICE-ID> to see which nodes are running the service: $docker service ps helloworld Step4:$ docker ps

Scale the service in the swarm 

(Once you have deployed a service to a swarm, you are ready to use the Docker CLI to scale the number of service ps in the swarm) Step1: If you haven't already, open a terminal and ssh into the machine where you run your manager node $docker service scale <SERVICE-ID>=<NUMBER-OF-TASKS> $docker service scale helloworld=5 Step2: Run docker service ps <SERVICE-ID> to see the updated task list: $ docker service ps helloworld Step3: Run docker ps to see the containers running on the node.

Delete the service running on the swarm 

Step1: If you havent already, open a terminal and ssh into the machine where you run your manager node $docker service rm helloworld Step2: Run docker service inspect <SERVICE-ID> to verify that the swarm manager removed the service: $docker service inspect helloworld

STEPS TO INSTALL JAVA ON LINUX x64 AND SETTING JAVA PATH

step1: download the javaSE jdk-8u11-linux-x64.tar.gz step2: open the terminal and unzip the tar file $ tar -zxvf jdk-8u101-linux-x64.tar.gz step3: copy the unzip folder to usr/lib/java, $ cd /usr/lib $ sudo mkdir java $ cd ~/home/user/Downloads $ sudo mv jdk1.8.0_101/ /usr/lib/java $ cd /usr/java/java1.8.0_101/bin step4: Run the below commands sudo update-alternatives --install "/usr/bin/java" "java" "/usr/lib/java/jdk1.8.0_101/bin/java" 1 sudo update-alternatives --install "/usr/bin/javac" "javac" "/usr/lib/java/jdk1.8.0_101/bin/javac" 1 sudo update-alternatives --install "/usr/bin/javaws" "javaws" "/usr/lib/java/jdk1.8.0_101/bin/javaws" 1 step5: update the JAVA_HOME in your ~/.bashrc #JAVA HOME directory setup export JAVA_HOME=/usr/lib/java/jdk1.8.0_101 export PATH="$PATH:$JAVA_HOME/bin" VERIFY: $ java -version jdk1.8.0_101 version $ echo $JAVA_HOME /usr/lib/java/jdk1.8.0_101

Create a php project which retrieve records from AWS RDS Database instances running on AWS EC2 instances

EC2 Instance RDS Instance ---------------------------------------------------------------- Instance type t2.micro (Free tier) db.t2.micro (Free tier) Availability zone us-east-1 us-east-1 Security group DemoSG DemoSG IAM role RDSfullaccess-role ---------- Root volume 8 GB SSD 8GB SSD Public IP address Yes Yes VPC ID and Subnet Default Default -------------------------------------------------------------- Security Group (DemoSG): -------------------------------------------------------------- inbound : open http (80), https (443), ssh (22) and MySQL/Aurora (3306) Outbound: All traffic IAM role: Attach AmazonRDSReadOnlyAccess policy -------------------------------------------------------------- Test the RDS Database connection from the Linux/Ubuntu Terminal --------------------------------------------------------------- Install the NETCAT software $sudo yum install nc Test the RDS connection $nc -zv <DB-instance-endpoint> <port> (Syntax) --------------------------------------------------------------- Steps to install Apache Webserver on Centos 7: --------------------------------------------------------------- step1: Connect to your EC2 instance and install the Apache web server $ sudo yum -y install httpd step2: About service. $ sudo systemctl start httpd [start the apache server] $ sudo systemctl enable httpd [apche start at boot] $ sudo systemctl status httpd [check the status of httpd] $ sudo systemctl stop httpd [stop the appache] step3: Create a sample html file [index.html] $ vi /var/www/html/index.html <html> <title>Demo Page </title> <body> <h1>Welcome to Apace Webserver! </h1></body> </html> step4: Open a browser window and enter the URL to access the file (It is the public DNS name of the EC2 instance followed by the file name) http://EC2-instance-public-DNS Step5: Add the www group to your instance $sudo group add www step7: Add your user (in our case centos) to the www group sudo usermod -a -G www centos Logout and connect the instance onces again step8:Change the group ownership of /var/www and connects to the www group sudo chown -R root:www /var/www step9: Recursively change the directory permissions of /var/www and its subdirectories to add group Write permissions to set the group ID on future subdirectories sudo chmod 2775 /var/www $find /var/www -type d -exec sudo chmod 2775 {}\; step10: Recursively change the file permissions of /var/www and its subdirectories to add group write Permissions $find /var/www -type f -exec sudo chmod 0664 {}\; ---------------------------------------------------------------------- Install the PHP, extensions and configure the php.ini ----------------------------------------------------------------------- step1: Connect to the EC2 Instance and install the PHP $sudo yum install php Step2: Restart the httpd service $sudo systemctl restart httpd.service Step3: Install the PHP extensions or Modules $sudo yum search php- (display all the php packages) $sudo yum install php-fpm (PHP FastCGI Process Manager) $sudo yum install php-dba (A database abstraction layer module for PHP applications) $sudo yum install php-mysqlnd . (A module for PHP applications that use MySQL databases) $sudo yum install php-pdo (A database access abstraction module for PHP applications) $sudo yum install php-pgsql (A PostgreSQL database module for PHP) Step4: Add the extension in php.ini in same order and restart httpd service (/etc/php.ini) extension pdo.so extension mysqlnd.so extension pdo_sqlite.so extension pdo_mysqlnd.so extension pdo_sqlite.so extension mysqlnd_mysql.so step5: Create files in /var/www/html ------------------------------------------------------------------------- index.html ------------------------------------------------------------------------- <html> <body> <h1>Connect to the DataBase! </h1> <form action="script.php" method="post"> <input type="submit" value=”connect”/> </form> </body> </html> ----------------------------------------------------------------- dbinfo.inc ------------------------------------------------------------------ <?php define('DB_SERVER', 'RDS_EndPoint'); define('DB_USERNAME', 'RDS_masterUsername'); define('DB_PASSWORD', 'RDS_master_password'); define('DB_DATABASE', 'RDS_database_name'); ?> ----------------------------------------------------------------- script.php ----------------------------------------------------------------- <html> <body> <h1>DATABASE TABLE </h1> <?php include "dbinfo.inc"; $db=DB_DATABASE; /* Connect to MySQL and select the database. */ $con = mysqli_connect(DB_SERVER, DB_USERNAME, DB_PASSWORD); if (mysqli_connect_errno()) echo "Failed to connect to MySQL: " . mysqli_connect_error(); $statement="SELECT * FROM $db.Employee"; $result=mysqli_query($con,$statement); if(!$result){ die("SQL Error:".mysqli_error($con)); } // Fetch one and one row while ($row = mysqli_fetch_array($result)) { echo $row['name'],"<br>"; } // Free result set mysqli_free_result($result); mysqli_close($con); ?> </body> </html> Step6: To bind the address form our httpd web server with RDS instances, we need to run the following Commands: $ausearch -c 'httpd' --raw | audit2allow -M my-httpd $semodule -X 300 -i my-httpd.pp ------------------------------------------------------------------------- Logs and Important files used for debugging ------------------------------------------------------------------------ httpd: /var/log/httpd/access_log /var/log/httpd/error_log /etc/httpd/conf/httpd.conf /etc/httpd/modules PHP modules: /usr/lib64/php/modules /etc/php.ini Datadir /var/lib/mysql Socket /var/lib/mysql/mysql.sock MySQL file /etc/my.cnf ------------------------------------------------------------------------ RDS Database SQL Quieres: ------------------------------------------------------------------------- Step1: MySQL workbench download url: http://dev.mysql.com/downloads/workbench/ Step2: Install the MSI installer [windowns] $sudo apt-get install mysql-server [ubuntu] $sudo yum install mysql-server [linux] Step3: >mysql -h yourDatabaseEndpoint -P 3306 -u USERNAME -p >show databases; [Show the Databases] >use database_name; [use the following database] >Create table Employee( ID integer(3),name varchar(20),desg varchar(20),sal integer(6)); >desc Employee; Step4: >insert into Employee(ID,name,desg,sal)values(101,'fasi','CEO',80000); >insert into Employee(ID,name,desg,sal)values(102,'Raj','SSE',50000); >insert into Employee(ID,name,desg,sal)values(103,'suraj','SE',30650); >insert into Employee(ID,name,desg,sal)values(104,'prem','HW',18800); Step5: > select * from Employee; ---------------------------------------------------------------------------------- IF you want to create Docker container Convert your PHP application into Image by using Docker file below: Note: copy the /etc/php.ini file to your /var/www/html/ where your Dockerfile is there Dockerfile: ------------ FROM centos/httpd RUN yum install -y php RUN yum install -y php-mysqlnd php-fpm php-dba COPY . /var/www/html/ COPY php.ini /etc/php.ini EXPOSE 80 Run these commands: --------------------- docker build -t fasi/httpd . docker run -d -p 80:80 fasi/httpd docker exec -it <contianerID> bash Test in the browser: http://yourEC2_public_IP_addresss