Seshan's Blog

keyboard_backspaceBack to Posts
Windows Server on KVM in Docker on DigitalOcean
December 12, 2018

Yep, you read the title right. I… uh… yea I installed Windows Server 2008 on KVM in a Docker container on a DigitalOcean Droplet. For a production environment…

So as some of you may know I work for ConnectUS, a company who is designing a website/service for the educational sector. It’s not released yet, so I don’t really know how much I can actually say. Anyway, we needed a mail server for the usual verify your account, and also for some pretty integral parts of the website. Now, we already use GNU/Linux for everything else, and all we needed was basically an SMTP server, so something like Postfix would’ve been the reasonable thing to do. Of course, me being myself wouldn’t satisfied that that. Nope, we need to make this interesting!

So the plan was to install Microsoft Exchange Server (which didn’t end up happening sadly, setting up Active Directory and everything else required for enterprise Microsoft software was not really worth it, considering the timeline too). Oh and btw, if you ever wanted to see some crazy stuff, look up the recommend system specs for Exchange 2019, it’s like 128GB of RAM or something stupid like that. Anyway, I digress. I choose Windows Server 2008 becuase of the maximum fun factor, plus it’s still in support. It also uses way less resources than Server 2019 would.

So began the adventure. I’ve already installed Windows a number of times in QEMU+KVM, Virt IO en all. Now, we already use Docker extensively, to host the various components of the website ( backend, frontend, db, proxies, etc), so why not put the mail server VM in a container too? As it turns out, I wasn’t the only one with this idea, and I found a pretty cool GitHub project that was a Docker container (CentOS) with QEMU. Seems pretty simple, right? Wrong! It’s actually even cooler. The VMs network card is actually mapped to the Containers IP, meaning you can manage all you networking (like exposing ports) right with Docker, and treat everything running inside the VM just as if it was a normal container. It has some other nice things too, like a serial port on the guest thats mapped to the docker container’s logs.

First thing to do was to install Windows onto a qcow2 image (using the Windows VirtIO drivers for storage). After that I forked the repo to make some changes to the QEMU options (including making it more Windows friendly). Finally spin up the container and boom! VM on Docker:

Awesome! Now, it wasn’t all that smooth. My first mistake was forgetting to enable RDP (the container doesn’t expose any way of access the QEMU QUI, and the built-in VNC doesn’t work since the containers IP is mapped to inside the VM, not the QEMU process). Ok, no problem just shut off the container, install RDP, then try again. Then came issue #2, I realized that I never installed the VirtIO network drivers. Thats fine, just shut off the container and replace the network card for now. The the really stupid part: I forgot the RDP port. I spent so long wondering why I couldn’t connect. Turns out I forwarded port 3386 instead of 3389. *sigh*

But yea, that’s basically it… yay? For those wondering, instead of Exchange Server I went with hMailServer. I actually totally forgot about it’s existence. I actually tried using it a really long time ago as a kid (idk make 11 or 12), so there was some nostalgia there (and hey, this time I got the software to work!).

ID: 46