Difference between revisions of "Buildbot and EC2"

From CDOT Wiki
Jump to: navigation, search
(Tasks)
Line 18: Line 18:
  
 
===      Release 0.1 ===
 
===      Release 0.1 ===
'''Goals:'''
+
 
 +
==== Goals ====
 
* Add in a new build step to Buildbot
 
* Add in a new build step to Buildbot
 
* Allow Buildbot to connect with Amazon's EC2 service
 
* Allow Buildbot to connect with Amazon's EC2 service
  
 +
==== Downloads ====
  
Basically, the first thing that needs to be done is add a new step to Buildbot's build process. Once a new step has been added, the next step is to make this new build step access my EC2 account.  
+
    [http://matrix.senecac.on.ca/~awdelyea/EC2_build_step_nokeys.py EC2_build_step_nokeys.py]
  
After I can actually access my EC2 account through Buildbot, then a possible next step would be to make Buildbot check to see if I have any open Virtual Instances running already (no point in starting another instance if ones running already).
+
    Note: You will need to install the boto library located [http://boto.googlecode.com/files/boto-0.9a.tar.gz here].
  
One thing that may need to be kept in mind is that Amazon charges 10 cents per hour, or part of an hour, per instance. So, each time you start a new instance, it costs 10 cents. The best way I can think of doing this is make each instance you start, last for at least an hour, so that if you start another build in 10 mins, you can continue to use the same instance instead of starting a new one.
 
  
For this, Buildbot would need to run a service on the OS to constantly check to see if an instance is approaching the 1 hour mark, and not running any build slaves. Not quite sure how I'd do that, but it's something to keep in mind.
+
==== About ====
 +
 
 +
Basically, this first version attempts to connect to an EC2 account, and then display the connection information to show that it has connected.
 +
 
 +
It uses a library called "boto", and this library is used to connect to all of [http://www.amazon.com/gp/browse.html?node=3435361 Amazon's Web Services]
 +
 
 +
To use this in a Buildbot configuration file, simply call the connect_to_ec2() function, which takes in as paramaters, an Amazon id key, and an Amazon secret key.
 +
 
 +
Example:
 +
<pre>
 +
    connection = connect_to_ec2("73ghf9h38fh", "75vo87rVO*&V%O7o75v7i%i75I&5li7%i75")
 +
</pre>
 +
 
 +
----
 +
 
 
===      Release 0.2 ===
 
===      Release 0.2 ===
 +
 +
==== Goals ====
 +
 +
* Start New Instances
 +
* Add new instances to build slave list
 +
* Start a build on an EC2 instance build slave
 +
 +
==== Downloads ====
 +
 +
==== About ====
 +
----
 +
 
===      Release 0.3 ===
 
===      Release 0.3 ===
 +
 +
==== Goals ====
 +
 +
==== Downloads ====
 +
 +
==== About ====
  
 
== Tasks ==
 
== Tasks ==
  
 
<table style="width: 100%;" class="standard-table" cellborder=1 border=1 cellpadding=2 cellspacing=0>
 
<table style="width: 100%;" class="standard-table" cellborder=1 border=1 cellpadding=2 cellspacing=0>
     <th style="width: 15%;background-color:grey">Task</th>
+
     <th style="width: 15%;">Task</th>
     <th style="width: 10%; background-color:grey">Details</th>
+
     <th style="width: 10%; ">Details</th>
     <th style="width: 10%; background-color:grey; font-color:white">Priority</th>
+
     <th style="width: 10%;">Priority</th>
     <th style="width: 10%; background-color:grey; font-color:white">Contributors</th>
+
     <th style="width: 10%;">Contributors</th>
     <th style="width: 10%; background-color:grey; font-color:white">Status</th>
+
     <th style="width: 10%;">Status</th>
     <th style="width: 10%; background-color:grey; font-color:white">Link(s)</th>
+
     <th style="width: 10%;">Link(s)</th>
  
 
     <tr>
 
     <tr>
 
         <td>Define new build step</td>
 
         <td>Define new build step</td>
 
         <td>Add a new build step to the build master config file. The build step will be in an external file and imported into the build master config file.</td>
 
         <td>Add a new build step to the build master config file. The build step will be in an external file and imported into the build master config file.</td>
         <td style="background-color: red; text-align: center; font-weight: bold; font-size: bigger">High</td>
+
         <td style="background-color: green; text-align: center; font-weight: bold; font-size: bigger">Done</td>
 
         <td>Adam Delyea</td>
 
         <td>Adam Delyea</td>
         <td>In Progress, On Track</td>
+
         <td>&nbsp;</td>
 
         <td>[http://buildbot.net/repos/release/docs/buildbot.html#Writing-New-BuildSteps Writing New Build Steps]</td>
 
         <td>[http://buildbot.net/repos/release/docs/buildbot.html#Writing-New-BuildSteps Writing New Build Steps]</td>
 
     </tr>
 
     </tr>
Line 55: Line 88:
 
         <td>Connect To EC2 using Python</td>
 
         <td>Connect To EC2 using Python</td>
 
         <td>Utilize the EC2 python library to connect to an account on the EC2 network. Once connected, display some information about the users account to prove it's actually connecting.</td>
 
         <td>Utilize the EC2 python library to connect to an account on the EC2 network. Once connected, display some information about the users account to prove it's actually connecting.</td>
         <td style="background-color: red; text-align: center; font-weight: bold; font-size: bigger">High</td>
+
         <td style="background-color: green; text-align: center; font-weight: bold; font-size: bigger">Done</td>
 +
        <td>Adam Delyea</td>
 +
        <td>&nbsp;</td>
 +
        <td><ul><li>[http://code.google.com/p/boto/ Boto Amazon Web Services Library in Python]</li><li>[http://jimmyg.org/2007/09/01/amazon-ec2-for-people-who-prefer-debian-and-python-over-fedora-and-java/ Amazon-ec2-for-people-who-prefer-debian-and-python-over-fedora-and-java]</li></ul></td>
 +
    </tr>
 +
 
 +
    <tr>
 +
        <td>Start new instances</td>
 +
        <td>Allow Buildbot to spawn an instance on demand.</td>
 +
        <td style="background-color: yellow; text-align: center; font-weight: bold; font-size: bigger">Medium</td>
 +
        <td>Adam Delyea</td>
 +
        <td>In Progress, On Track</td>
 +
        <td>&nbsp;</td>
 +
    </tr>
 +
 
 +
    <tr>
 +
        <td>Add new instances to build slave list</td>
 +
        <td>Allow newly created EC2 instances to be added to the build slave list</td>
 +
        <td style="background-color: yellow; text-align: center; font-weight: bold; font-size: bigger">Medium</td>
 +
        <td>Adam Delyea</td>
 +
        <td>In Progress, On Track</td>
 +
        <td>&nbsp;</td>
 +
    </tr>
 +
 
 +
<tr>
 +
        <td>Start a new build on an EC2 instance</td>
 +
        <td>Allow Buildbot to successfully start a build using a build slave on an EC2 instance</td>
 +
        <td style="background-color: yellow; text-align: center; font-weight: bold; font-size: bigger">Medium</td>
 
         <td>Adam Delyea</td>
 
         <td>Adam Delyea</td>
 
         <td>In Progress, On Track</td>
 
         <td>In Progress, On Track</td>
         <td><ul><li>[http://code.google.com/p/boto/ Boto Amazon Web Services Library in Python]</li><li>[http://jimmyg.org/2007/09/01/amazon-ec2-for-people-who-prefer-debian-and-python-over-fedora-and-java/ Amazon-ec2-for-people-who-prefer-debian-and-python-over-fedora-and-java]</li></ul></td>
+
         <td>&nbsp;</td>
 
     </tr>
 
     </tr>
 
</table>
 
</table>
Line 73: Line 133:
  
 
2007-10-11: Found a python EC2 library that has all of the functions I will need for interacting with EC2. Just need to write a custom build step to run these library functions.
 
2007-10-11: Found a python EC2 library that has all of the functions I will need for interacting with EC2. Just need to write a custom build step to run these library functions.
 +
 +
2007-10-12: Release v0.1 is complete and available for download.
 +
 +
2007-10-12: Release v0.2 loosely defined. More detail to follow.

Revision as of 18:33, 12 October 2007

Project Name

Buildbot and EC2

Project Description

The BuildBot is software for automatically building and testing other software. EC2 is Amazon's "Elastic Compute Cloud", a service that lets you run Virtual Machines on Amazon's computing grid using a web API. It would be awesome if BuildBot had an EC2 module, and could spawn Virtual Machines on-demand to perform tasks. Conveniently, BuildBot is written in Python, and there's a Python library for interfacing with EC2.

References: Amazon EC2 Basics For Python Programmers

Project Leader(s)

Adam Delyea

Project Contributor(s)

Project Details

Release 0.1

Goals

  • Add in a new build step to Buildbot
  • Allow Buildbot to connect with Amazon's EC2 service

Downloads

    EC2_build_step_nokeys.py

    Note: You will need to install the boto library located here.


About

Basically, this first version attempts to connect to an EC2 account, and then display the connection information to show that it has connected.

It uses a library called "boto", and this library is used to connect to all of Amazon's Web Services

To use this in a Buildbot configuration file, simply call the connect_to_ec2() function, which takes in as paramaters, an Amazon id key, and an Amazon secret key.

Example:

    connection = connect_to_ec2("73ghf9h38fh", "75vo87rVO*&V%O7o75v7i%i75I&5li7%i75")

Release 0.2

Goals

  • Start New Instances
  • Add new instances to build slave list
  • Start a build on an EC2 instance build slave

Downloads

About


Release 0.3

Goals

Downloads

About

Tasks

Task Details Priority Contributors Status Link(s)
Define new build step Add a new build step to the build master config file. The build step will be in an external file and imported into the build master config file. Done Adam Delyea   Writing New Build Steps
Connect To EC2 using Python Utilize the EC2 python library to connect to an account on the EC2 network. Once connected, display some information about the users account to prove it's actually connecting. Done Adam Delyea  
Start new instances Allow Buildbot to spawn an instance on demand. Medium Adam Delyea In Progress, On Track  
Add new instances to build slave list Allow newly created EC2 instances to be added to the build slave list Medium Adam Delyea In Progress, On Track  
Start a new build on an EC2 instance Allow Buildbot to successfully start a build using a build slave on an EC2 instance Medium Adam Delyea In Progress, On Track  

Project Resources

Project News

2007-09-17: Project claimed!

2007-10-11: Found a python EC2 library that has all of the functions I will need for interacting with EC2. Just need to write a custom build step to run these library functions.

2007-10-12: Release v0.1 is complete and available for download.

2007-10-12: Release v0.2 loosely defined. More detail to follow.