Sunday, January 17, 2021

Jenkins Slave on AWS EC2 instances with SSH configuration

After configuring the  Jenkins Master we need to configure the slave or agent on EC2 instance. There are various methods to connect with the Slave node. In this post, 

I would like to share the SSH key-based remoting method.

Pre-requisites

  • Jenkins Master already Up and Running
  • Java (JDK) installed on the Slave node


Jenkins master slave configuration on EC2

Here we are in the slave machine and proceed with the following steps for configure a SSH based Jenkins slave.

How to create user and generate ssh-key on Slave?

Login to slave node terminal using ssh or PuTTY switch to root user. 
useradd jenkins_slave
mkdir -p /home/jenkins_slave
usermod -d /home/jenkins_slave jenkins_slave
tail -1 /etc/passwd # To check useradded to userlist
Now switch to the newly created user 'jenkins_slave'.
sudo su - jenkins_slave
SSH Key generate for 'jenkins_slave' user with the following command:
cd .ssh
ssh-keygen -t rsa -N ""
The above command will create two files in /home/jenkins_slave/.ssh folder id_rsa (private key) and id_rsa.pub (public key). Now navigate to the .ssh folder then push the public key content into authorized_keys file.
cat id_rsa.pub>authorized_keys
Now make the authorized_keys file permission to 700.
chmod 600 authorized_keys

How to Configure known_hosts on Master node?

Login to the "Master machine" and switch to user 'jenkins' and then create .ssh folder. Add the slave host to the known_hosts file using following command(ssh-keyscn).
cd .ssh;
ssh-keyscan -H 172.31.37.235>>known_hosts
chmod 600 known_hosts


All set on the master node about the slave node. Now go to the Jenkins dashboard. On the left pane select the "Manage Jenkins" > Manage Nodes and Cloud > New Node Enter the following values:

    1. Name: node1
    2. Description: Build server
    3. # of executors: 5
    4. Remote root directory: /tmp/slave 
    5. Labels: node1
    6. Usage: Use this node as much as possible
    7. Launch method : Launch agents via SSH
    a. Host: ip-address
    b. Credentials: jenkins_slave
    c. Host Key Verification Strategy: Known host file Verification Strategy
        1. Availability: Keep this agent online as much as possible

        Node configuration on Jenkins


        Now go to the slave node and fetch the content of the id_rsa file (that is private key content).

        ssh-key private key

        In the Jenkins Dashboard  - On the left pane section select : Credentials 

        Global Credentials(unrestricted)

        Add Jenkins Global credentials
        Scope: Global
        Username : jenkins_slave (which was created in the above top step)
        Private key copy the above content to the Jenkins Private key Text box from the slave node ~/.ssh/id_rsa

        Global credentials

        After configuring the slave settings, Save the Project. 

        Finally, you can see the Node is active state as shown below:

        Active Node on Jenkins



        References:




        No comments:

        Categories

        Kubernetes (24) Docker (20) git (13) Jenkins (12) AWS (7) Jenkins CI (5) Vagrant (5) K8s (4) VirtualBox (4) CentOS7 (3) docker registry (3) docker-ee (3) ucp (3) Jenkins Automation (2) Jenkins Master Slave (2) Jenkins Project (2) containers (2) docker EE (2) docker private registry (2) dockers (2) dtr (2) kubeadm (2) kubectl (2) kubelet (2) openssl (2) Alert Manager CLI (1) AlertManager (1) Apache Maven (1) Best DevOps interview questions (1) CentOS (1) Container as a Service (1) DevOps Interview Questions (1) Docker 19 CE on Ubuntu 19.04 (1) Docker Tutorial (1) Docker UCP (1) Docker installation on Ubunutu (1) Docker interview questions (1) Docker on PowerShell (1) Docker on Windows (1) Docker version (1) Docker-ee installation on CentOS (1) DockerHub (1) Features of DTR (1) Fedora (1) Freestyle Project (1) Git Install on CentOS (1) Git Install on Oracle Linux (1) Git Install on RHEL (1) Git Source based installation (1) Git line ending setup (1) Git migration (1) Grafana on Windows (1) Install DTR (1) Install Docker on Windows Server (1) Install Maven on CentOS (1) Issues (1) Jenkins CI server on AWS instance (1) Jenkins First Job (1) Jenkins Installation on CentOS7 (1) Jenkins Master (1) Jenkins automatic build (1) Jenkins installation on Ubuntu 18.04 (1) Jenkins integration with GitHub server (1) Jenkins on AWS Ubuntu (1) Kubernetes Cluster provisioning (1) Kubernetes interview questions (1) Kuberntes Installation (1) Maven (1) Maven installation on Unix (1) Operations interview Questions (1) Oracle Linux (1) Personal access tokens on GitHub (1) Problem in Docker (1) Prometheus (1) Prometheus CLI (1) RHEL (1) SCM (1) SCM Poll (1) SRE interview questions (1) Troubleshooting (1) Uninstall Git (1) Uninstall Git on CentOS7 (1) Universal Control Plane (1) Vagrantfile (1) amtool (1) aws IAM Role (1) aws policy (1) caas (1) chef installation (1) create deployment (1) create organization on UCP (1) create team on UCP (1) docker CE (1) docker UCP console (1) docker command line (1) docker commands (1) docker community edition (1) docker container (1) docker editions (1) docker enterprise edition (1) docker enterprise edition deep dive (1) docker for windows (1) docker hub (1) docker installation (1) docker node (1) docker releases (1) docker secure registry (1) docker service (1) docker swarm init (1) docker swarm join (1) docker trusted registry (1) elasticBeanStalk (1) global configurations (1) helm installation issue (1) mvn (1) namespaces (1) promtool (1) service creation (1) slack (1)