Playing around with libvirt and Open VirtualSwitch

Some time ago, we had a couple of inquiries about support for running KVM hypervisors with Open vSwitch (OVS). Older versions of OVS included the brcompat module, which made OVS work with regular Linux bridges instead of its own virtual switches. This meant Abiquo would behave as if it were using regular bridges. However, with recent versions of OVS, this brcompat module has been deprecated and it is not working as well as it should. Support for OVS is in our development roadmap, but in the meantime, we will explain how to “hack” an unsupported version of this feature using libvirt “domain events”.


Developing tools with the Abiquo API: noVNC token generator

Most of the examples we have provided of how to interact with the Abiquo API are written in Python, so now it’s time to put some rubies in our blog. We will show you how to use Ruby to interact with Abiquo APIs. First we will consume events by connecting to the Outbound API, but we will not process event data, we will just use it as a trigger. When we detect a deploy/undeploy action, we will retrieve more information about deployed VMs by calling the REST API.


Abiquo Workflow Acceptance Tool explained!

When developing Abiquo v2.6, simplicity and functionality was the focus and the workflow acceptance tool has achieved just that.
The new workflow feature will allow you to create your own tools to interact with Abiquo processes at the very same moment they are being executed. In short, during certain Abiquo tasks, Abiquo will send an HTTP request with the task details to a configured endpoint. The task details will contain the links to accept or decline the task. It’s as simple as that.


v2.6 is on the air

Abiquo v2.6 release has launched earlier this week, it is Abiquo’s most anticipated release to date and we encourage you all to download and try it out.

To give you some background; the 2.4 release really focused on ensuring that we dealt with any scalability barriers detected in our stress tests. With v2.6 the focus has been on including even more extensive integration capabilities, to enable our customers to build innovative services and solutions.

We know that the “one size fits all” approach doesn’t work in the cloud marketplace, so an important goal for Abiquo is to enable our customers to offer a unique combination of services and solutions. With v2.6 we have enabled new integration capabilities, exciting enhancements to our outbound API, further back-up integration, workflow improvements and the opportunity to manage your public cloud through Amazon EC2.

Below is a review of these capabilities:


As simple as ABC – The Abiquo Brooklyn Catalog

Guest blogger: Alex Heneveld, CTO at CloudSoft

We recently had the pleasure of hosting a visit from Abiquo; pleasurable because it quickly morphed into a hackathon with Xavier Fernandez which yielded a nicely working integration. A long flight gave me the chance to clean it up and make a Brooklyn pull request (#813) with the net result that Abiquo is now (for all you TL;DR vics) a first-class target for the Brooklyn Catalog.

The session started with the usual describe-and-demo. However it is always the surprises which are most interesting so here’s what surprised me:

  • Abiquo has their own API. Is this madness given the momentum of the *-stack bandwagons? I don’t want to have to work with yet another API. But it turns out I don’t have to: they’ve got bindings for jclouds and other client libraries which meant, and as we’ll talk about below, it worked with a lot less fuss than I’m used to.
  • It’s a very nice GUI. Pretty is always nice, but more importantly it had clearly been through a few rounds of real usability feedback. The little things that usually irk me had all been solved, like searching for resources … acting on several VM’s at the same time … and hanging on a slow connection. (The down-side is that it’s Flex not HTML5/JS/REST, but Abiquo are on the case so look out for a new version when 3.0 is released later this year.)


  • It’s multi-cloud. Multi-hypervisor is old news, but there still are not many cloud platforms which can front many locations. Add in wide-area, use a datastore efficiently (Redis, in Abiquo’s case), and include locations which are someone else’s cloud with a different API, and the list is very short. Location is a first-class concept, and the current snapshot version supports AWS locations. OpenStack and CloudStack targets around the corner, hopefully.


An open approach to code reviews

One of the key aspects of every software product is the quality of the product itself. This is often measured by taking the number of bugs, performance metrics, the amount of memory needed to run it, and shown to the world in the form of attractive reports and graphics. However, there is one aspect that is very difficult to measure but extremely important: code quality. How can this be measured? Measuring code quality can be a very subjective process, so instead of relying on reports and tools to generate cool graphics, the smart approach is to integrate the code quality assurance process into the development cycle. Today I’ll explain how adding a code review process to our development cycle has helped us deliver better software.


Deploying Abiquo 2.4 with Cobbler

Now that you can download Abiquo and get a 30-day trial license, you may like to automate the deployment of a new datacenter in your Abiquo environment. I’ll explain here how to automatically deploy Abiquo using Cobbler.

First of all, you need to get Cobbler up and running. I’m not going to explain here how to install it, but you can use the official guide that is very detailed or these instructions for installing on CentOS 6. However, I will give you some advice about Cobbler installation. Review the output of the ‘cobbler check’ command to double check that everything is working fine. You will need to have at least DHCP and TFTP managed by Cobbler.


Locking disks on KVM using libvirt-lock-sanlock

When you are managing a huge number of virtual machines with a shared datastore, it could be very dangerous for different virtual machines to access the same disk file or volume. This can lead to data consistency problems, and in a worse case scenario, the loss of all information on the disk.

We all know that things that should never happen sometimes do. That’s why it’s good practice to add an extra security layer, to ensure that disk access will always be controlled.

A tool for this purpose is listed on the libvirt webpage:

With libvirt-lock-sanlock, we create a connection between libvirt and sanlock. Whenever libvirt is using a disk or volume, sanlock will create a lock, so other virtual machines that would be using the same disk won’t be able to start up.


Abiquo 2.4.0 EE is here!

It is a pleasure to announce in our technical blog the release of Abiquo 2.4 (internally called King Piccolo). I don't think it's necessary to go over all the features included in this release because you can read about them on our public site and I'm sure that Abiquo's business associates will make an announcement of them on their websites.

However, I do want to highlight some exciting technical solutions included in this release that will move the platform to a new stage of scalabilityreliability and robustness (even more so than previous versions).

I think the major change in this release, ahead of other internal improvements, is the full Load Balancing capability of the Abiquo Management Server, enabling you to put Abiquo behind any load balancer and horizontally scale based on the needs of your business.

Implementing load balancing may seem easy, but it isn't when you have a distributed environment orchestrated by queues, which sometimes needs a coherent job order, or when it isn't evident when your scheduler engine must maintain the integrity of resource data, so you must ensure one allocation at a time.


Addicted to automating complex environments

Welcome to Abiquo, goodbye to the same ol’ thing

Abiquo is a Software company with development branches located in Barcelona and the UK, targeting the Cloud Computing market. Currently we are developing a leading IaaS product that is revolutionizing Cloud Management with installations around the world.

We have an important job opportunity available for an excellent engineer who can help us in the continuous integration process, automating the testing and verification of complex situations. Only suitable for bold people.

We’re on the lookout for an Engineer to help us in our quest to build the best cloud management platform on the market. Be part of the Barcelona team and be passionate about building complex Automated tests from building the environments, to driving the software and verifying the results.



What we look for in every employee

Get it done
We value aptitude and attitude as well as experience. We value the ability to get things done with the highest standards.

There’s no I in culture
Our company is based around small, dynamic teams working with agile methodologies. You should work well with others, and treat teamwork and team achievement as the end goal.

You are our ambassador
On a personal level you should have good written and oral communication skills. Every employee is a spokesperson for the company at all times.

Key Experience

Excellent Automation skills, Continuous integration.

Key Requirements

  • Can automate tests that drive not only the Abiquo Platform but the multiple 3rd party platforms with which we integrate (Hypervisors, Virtual Machines, etc.)
  • You must enjoy programming and solving complex test automation problems
  • Excellent Continuous Integration skills (Jenkins)
  • English is a requirement

Desired Requirements

  • Experience automating complex environments!
  • Knowledge of testing tools,(e.g. Selenium, FlexMonkey..)
  • Knowledge of languages that aid automation. (e.g JAVA/C#/Ruby/Python/Perl..)
  • Knowledge/experience of Performance/Stress/load/Functional testing techniques
  • Source code control experience (Git)
  • Experience in an Agile environment. (Understanding of working in a Scrum team – sprints, etc.)
  • Good level of Linux administration (Centos/Ubuntu).
  • Experience using Eclipse, Maven, JIRA and other Open Source tools
  • Nice to have: Certification of a Testing Qualification (e.g. TMap/ISEB/ISTQB..)
  • Nice to have: Experience  in Open Source environments (e.g. involved in an Open Source project or community)
  • Nice to have: knowledge of virtualization technologies (Xen, VMware, KVM, VirtualBox, etc).
  • Nice to have: Chef/puppet capabilities
  • Nice to have: Networking knowledge
  • An understanding of Cloud Services (Products, companies, etc.) and standards is a plus
  • Experience of working in a company producing Enterprise Software

In return you can expect a salary package in line with your experience (Between 34K and 37K + variable) as well as the opportunity to participate in a very ambitious project full of challenges.

Please apply sending your CV to (GitHub account is a plus)