Jenkins: Setting up Slave nodes on AWS
data:image/s3,"s3://crabby-images/97ec7/97ec7937ea72f3c42d9c67f8334d38fb11340e5b" alt="Jenkins_Logo.png"
In this tutorial, we'll setup Jenkins nodes (1 master and 2 slaves) on AWS using Amazon Linux AMI.
Let's create 3 instances 1 for a master and 2 for slaves:
data:image/s3,"s3://crabby-images/e0a17/e0a17f5be7d2371016eee8b31cdf1dee510f7229" alt="jenkins-nodes.png"
Note that the three instances should be in the same availability zone to avoid any bandwidth charges.
The slaves should have the master's public key in their authorized_keys. So, first we need to create rsa key on the master:
$ ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/home/ec2-user/.ssh/id_rsa): Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/ec2-user/.ssh/id_rsa. Your public key has been saved in /home/ec2-user/.ssh/id_rsa.pub. The key fingerprint is: b3:ca:78:39:2c:d1:c1:67:13:71:05:6d:d6:b3:e6:17 ec2-user@ip-172-31-44-59 The key's randomart image is: +--[ RSA 2048]----+ | ..o+.. | | .. + o | | . . o o | | o + oE | | . +S. o .| | . . o . .| | o .. . | | .o=. | | .oo. | +-----------------+
Then, on the two slaves, copy the master's public key to authorized_keys:
$ echo "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC8o7NpoyqRwPtlCfgZR+5+Zi0bzqgu3ZwjFZyS0MbECAHDlohfORkNIjGT05LhylnapFrqumxefIrNnH1NtlVDJjCClDsMluPGE2AHaIdfVBY4iVuwRoNzzlRcZneRPIn/liQJfOHAXiI2kv11zPuvINpgnzGxlboF0AAY/Y3cUw4afe/x7AZaS6hj0kVuhJUeBTU/xNmC9mpWBsWQkf4+5oKmXKQ1xUZKTV3F7JuTOc00GKmDeUDxmDZOpSUTB8Zz55UvL3X/uUKH1fVsBSzFIug4iYZQ8zP22SBXOzyXXo4ANxqu1ms9xXT/rvXcmEyZV6c33JAmp0cOPdWzfqqD ec2-user@ip-172-31-44-59" >> authorized_keys
Do the same to the "slave-2" node as well.
Let's install Jenkins on the master node. We'll use LTS YUM repository for the LTS Release Line:
$ sudo wget -O /etc/yum.repos.d/jenkins.repo http://pkg.jenkins-ci.org/redhat-stable/jenkins.repo $ sudo rpm --import https://jenkins-ci.org/redhat/jenkins-ci.org.key $ sudo yum install jenkins
Start the Jenkins:
$ sudo service jenkins start Starting Jenkins [ OK ]
On master Jenkins, click "Build Executor Status", and select "New Node". Type in "node-1" for "Node name", and select "Permanent Agent".The "Configure" page looks like this:
data:image/s3,"s3://crabby-images/49640/496400cc3747c558fddc1e387c882fcfaaadc098" alt="node-1-configure.png"
For Credential, we paste the master's private key (~/.ssh/id_rsa) as shown below:
data:image/s3,"s3://crabby-images/4db2a/4db2ab080d4a0a3faab3c44fbec3f63f8c75ab27" alt="PrivateKey.png"
In case when the slave may remain in offline, we need to install java on the slave node:
$ sudo yum install java
For the 2nd slave node, we can just copy the 1st node and use it after naming it as "node-2":
data:image/s3,"s3://crabby-images/077ba/077baa27e7f373e75d98300e1f48944103820ee7" alt="node-2-configure.png"
The only thing we need to change is the private ip-address of the slave instance!
Click the "Save" button:
data:image/s3,"s3://crabby-images/fef42/fef42b6c54cc2cc0ab3d972723081ca690d0d7a0" alt="JenkinsExecutorStatus.png"
Now it's time to test our Jenkins node. We may want to create two identical simple task using shell script doing just 10s sleep:
data:image/s3,"s3://crabby-images/9672b/9672b3b7bb59d102488b5155aa067a44fe0b7992" alt="FreestyleJob-1.png"
data:image/s3,"s3://crabby-images/f2c74/f2c746cfdfa22c807431ba1509378611a91837c7" alt="BuildExecuteShellSleep.png"
Here we have the two identical jobs:
data:image/s3,"s3://crabby-images/34a8c/34a8c54a26691a4772a07774e0aaabacd9adb1c3" alt="Jenkins-Job-1-Job-2.png"
Let's run both tasks:
data:image/s3,"s3://crabby-images/dcdb3/dcdb3b1265f76754c661e73c92cf5a7c02de3df8" alt="Two-Tasks-Running.png"
As we can see the two tasks are running: one on master and the other one on slave-1!
Jenkins
Ph.D. / Golden Gate Ave, San Francisco / Seoul National Univ / Carnegie Mellon / UC Berkeley / DevOps / Deep Learning / Visualization