Page MenuHomePhabricator

[drydock/libvirt] Implement a Drydock blueprint for libvirt-based hosts
AbandonedPublic

Authored by hach-que on Apr 4 2015, 4:46 PM.
Tags
None
Referenced Files
F18776643: D12276.id.diff
Fri, Oct 10, 10:47 PM
F18652178: D12276.diff
Sep 21 2025, 7:00 AM
F18625400: D12276.id33793.diff
Sep 15 2025, 10:43 PM
F18577756: D12276.id29474.diff
Sep 10 2025, 7:49 PM
F18546589: D12276.id33774.diff
Sep 8 2025, 4:14 AM
F18545998: D12276.id33774.diff
Sep 8 2025, 3:53 AM
F18187921: D12276.id29474.diff
Aug 16 2025, 8:25 PM
F18112936: D12276.diff
Aug 12 2025, 10:00 PM
Subscribers

Details

Reviewers
epriestley
Group Reviewers
Blessed Reviewers
Maniphest Tasks
T2015: Implement Drydock
Summary

Ref T2015. This implements support for allocating build hosts on a remote machine with libvirt. It basically supports dynamic allocation of virtual machines on your own infrastructure (in contrast to AWS).

It's not too fiddly to get working; there's mainly some things around how host images are prepared (since you don't have AWS to do it for you). Specifically when preparing Windows build images, you need to release the DHCP lease and stop the network service before shutting down the machine you're going to use as the base image, by running the following commands at an administrative command prompt:

ipconfig /release
net dhcp stop

The network topology also needs to be configured in a 'Routed' configuration (not NAT).

Test Plan

This has only been tested with Windows build agents.

Diff Detail

Repository
rP Phabricator
Branch
libvirt-drydock
Lint
Lint Passed
Unit
Test Failures
Build Status
Buildable 5118
Build 5136: [Placeholder Plan] Wait for 30 Seconds

Unit TestsFailed

TimeTest
852 msPhabricatorCelerityTestCase::testCelerityMaps
1,289 msPhabricatorLibraryTestCase::testMethodVisibility
11 msPhabricatorConduitTestCase::testConduitMethods
0 msPhabricatorInfrastructureTestCase::testApplicationsInstalled
0 msPhabricatorInfrastructureTestCase::testRejectMySQLNonUTF8Queries
View Full Test Results (2 Failed · 5 Passed)

Event Timeline

hach-que retitled this revision from to Implement a Drydock blueprint for libvirt-based hosts.
hach-que updated this object.
hach-que edited the test plan for this revision. (Show Details)
hach-que added a reviewer: epriestley.
hach-que edited edge metadata.

Fix various issues:

  • Ignore errors when closing libvirt VMs
  • Fix missing parenthesis
  • Support SSH commands over libvirt proxy
  • Remove leading test prefixes
  • Lookup IP address on each lease in case hosts obtain new DHCP leases
epriestley edited edge metadata.

Let's get DrydockPreallocatedHostBlueprintImplementation stable in production before adding a bunch of other host blueprints.

This is also probably not something we necessarily want in the upstream since I've never heard of libvirt before. I'd rather just leave this more esoteric stuff up to the community.

This revision now requires changes to proceed.Aug 8 2015, 6:54 PM

To clarify, libvirt is the common API for KVM / Xen / VirtualBox / etc. It abstracts allocation of virtual machines on non-cloud services (so when people have their own hardware or datacentre they want to manage virtual machines on, libvirt is a hypervisor-independent and platform-independent way of doing that).

hach-que retitled this revision from Implement a Drydock blueprint for libvirt-based hosts to [drydock/libvirt] Implement a Drydock blueprint for libvirt-based hosts.Aug 24 2015, 1:40 PM
hach-que edited edge metadata.
hach-que edited edge metadata.

Rebase on master