Wednesday, June 24, 2020

Ansible Tower

Ansible Tower(<https://www.ansible.com/products/tower>) by Red Hat is an enterprise framework for managing your Ansible automation that provides a UI and restful API.
It provides role-based access control, graphical inventory management, and job scheduling.
It provides real-time output of playbook runs and is fully compatible with the major cloud environments.
Ansible Tower features:
  • Role-based access control: you can set up teams and users in various roles. These can integrate with your existing LDAP or AD environment.
  • Job scheduling: schedule your jobs and set repetition options
  • Portal mode: this is a simplified view of automation jobs for newbies and less experienced Ansible users. This is an excellent feature as it truly lowers the entry barriers to starting to use Ansible.
  • Fully documented REST API: allows you to integrate Asible into your existing toolset and environment
  • Tower Dashboard: use this to quickly view a summary of your entire environment. Simplifies things for sysadmins while sipping their coffee.
  • Cloud integration: Tower is compatible with the major cloud environments: Amazon EC2, Rackspace, Azure.
Ansible Tower is supported by the following operating systems:
  • Red Hat Enterprise Linux 6 64-bit
  • Red Hat Enterprise Linux 7 64-bit
  • CentOS 6 64-bit
  • CentOS 7 64-bit
  • Ubuntu 12.04 LTS 64-bit
  • Ubuntu 14.04 LTS 64-bit
  • Ubuntu 16.04 LTS 64 bit
  • 64-bit support required (kernel and runtime) and 20 GB hard disk.
  • Minimum 2 GB RAM (4+ GB RAM recommended) is required.
  • 2 GB RAM (minimum and recommended for Vagrant trial installations
  • 4 GB RAM is recommended /100 forks


Tuesday, June 23, 2020

Top GUI's for Docker

Graphical user interfaces give you a bunch of different and useful ways to interact with Docker.
Portainer:
Portainer (formerly UI for Docker) is a free open-source web application that runs as a container itself. You can install and start it with:
docker run -d -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock portainer/portainer
Rancher:
Rancher is a tool that takes what’s possible with a Docker GUI further and is more useful for production clusters. 
Reflecting this focus on production, Rancher is designed to work on Linux machines, so to test locally you might need to install onto a Virtual Machine.
Start the Rancher container using the following docker run command:
sudo docker run -d --restart=unless-stopped -p 8080:8080 rancher/server:stable

DockStation (Desktop app):
OS Support: Linux/Mac/Windows
DockStation is a free full-featured desktop app which allows you to work with docker and docker-compose. It can help generate a clean and native docker-compose.yml file which can be used even outside the application, using the native Docker Compose CLI commands.

With DockStation, you can easily track CPU, Memory, Networks I/O, Blocks I/O usage and open ports. 



Lazydocker (Terminal UI):
        Open-sourceOS: (Linux/OSX/Windows)
  • Requirements:
  • Go version >= 1.8
  • Docker >= 1.13 (API >= 1.25)
  • Docker-Compose >= 1.23.2 (optional)
Shipyard:
With a similar set of features to the other web-based GUIs mentioned in this article, Shipyard provides an interface to your containers, images, and Docker instances. Start it running with this one command that handles multiple operating systems:
curl -s https://shipyard-project.com/deploy | bash

 

Conclusion:
The above is not a full list but some of the most popular and convenient free GUIs for Docker. Which one to select — depends on your needs.
If you need a really powerful instrument for a team with access management, works with Docker swarm, with Docker stack and can be deployed on a remote server — choose Portainer. 

Monday, June 22, 2020

Netflix Eureka Server

In a typical microservice architecture we have many small applications deployed separately and they often need to communicate with each other.

Problem in this type of architecture is how the client service finds all of its end services. We normally hardcode the hostname/port in some property file,which is not a best practice. 

There could be any number of microservices, and it's time and resource-consuming to hard-code when there's an uncertain amount of them, and when their locations may change.

Discovery implies a mechanism where:
  • Services have no prior knowledge about the physical location of other Service Instances
  • Services advertise their existence and disappearance
  • Services are able to find instances of another Service based on advertised metadata
  • Instance failures are detected and they become invalid discovery results
Service Discovery is not a single point of failure by itself.

To solve this issue, we need a tool that will monitor and maintain the registry of all the microservices in the ecosystem.

Netflix Eureka:

Netflix to provide a solution to the above problem. It consists of the Eureka Server and Eureka clients. Eureka Server is itself a microservice to which all other microservices registers. Eureka Clients are the independent microservices.

The actual routing is done at runtime along with equally distributing the load among the end services.

There are other service discovery clients like Consul,Zookeeper,etcd,Cloudfoundry..etc.


High Availability in Eureka:

Netflix Eureka is built for High Availability. In CAP Theorem terms, it favors Availability over Consistency.

Focus is on ensuring Services can find each other in unplanned scenarios like network partitions or Server crashes.

High Availability is achieved at two levels:
  • Server Cluster :Production setup includes a cluster of Eureka Servers,
  • Client Side Caching.
Client Side Caching:

One of the best Eureka features is Client Side Caching. The Client pulls regularly discovery information from the registry and caches it locally. 

It basically has the same view on the system as the Server. In case all Servers go down or the Client is isolated from the Server by a network partition, it can still behave properly until its cache becomes obsolete.

Note:Clients retrieve and cache the registry information from the Eureka Server. In case all Servers crash, the Client still holds the last healthy snapshot of the registry.

Sunday, June 21, 2020

Install Jenkins Plugins

Plugins are the primary means of enhancing the functionality of a Jenkins environment to suit organization needs. 

There are over a thousand different plugins which can be installed on a Jenkins master and to integrate various build tools, cloud providers, analysis tools, and much more.

Plugins can be automatically downloaded, with their dependencies, from the Update Center. 

The Update Center is a service operated by the Jenkins project which provides an repository of open source plugins which have been developed and maintained by various members of the Jenkins community.

Jenkins provides a couple of different methods for installing plugins on the master:
  • Using the "Plugin Manager" in the web UI.
  • Using the Jenkins CLI install-plugin command.
The plugins are packaged as self-contained .hpi files, which have all the necessary code, images, and other resources which the plugin needs to operate successfully.

Advanced installation:

The Update Center only allows the installation of the most recently released version of a plugin.

For Older version plugins, a Jenkins administrator can download an older .hpi archive and manually install that on the Jenkins master.




Docker on AWS

Docker is a tool that allows developers,sys-admins etc. to easily deploy their applications in a sandbox (called containers) to run on the host operating system i.e. Linux. 

The key benefit of Docker is that it allows users to package an application with all of its dependencies into a standardized unit for software development.Like virtual machines, containers do not have high overhead and hence enable more efficient usage of the underlying system and resources.

There are a Multiple ways to run your containerized workloads on AWS. 
  • Amazon Elastic Container Service with AWS Fargate
  • AWS Ec2 Instance
  • Amazon Elastic Container Service for Kubernetes
  • AWS Elastic BeanStack with Single Conatiner Docker

In this blog post, we are going to install Docker on EC2 instance.


Jenkins Installation on Windows Machine


Thursday, June 18, 2020

Java14 Features

A significant number of Java Enhancement Proposals (JEPs) have been released in version 14. (Even more JEPs than Java 12 and 13 combined).

JDK 14 reached General Availability on 17 March 2020.

JAVA 14 addresses a total of 16 main enhancements/changes (JEPs) ranging from the Java language support to the latest APIs for ongoing JDK flight recorder monitoring. 

The entire feature list consists of:
  • Pattern Matching for instanceof (Preview)
  • Non-Volatile Mapped Byte Buffers (Incubator)
  • Helpful NullPointerExceptions
  • Switch Expressions (Standard)
  • Packaging Tool (Incubator)
  • NUMA-Aware Memory Allocation for G1
  • JFR Event Streaming
  • Records (Preview)
  • Deprecate the Solaris and SPARC Ports
  • Remove the Concurrent Mark Sweep (CMS) Garbage Collector
  • ZGC on macOS (experimental)
  • ZGC on Windows (experimental)
  • Deprecate the ParallelScavenge + SerialOld GC Combination
  • Remove the Pack200 Tools and API
  • Text Blocks (Second Preview)
  • Foreign-Memory Access API (Incubator)

ES12 new Features