-
-
Notifications
You must be signed in to change notification settings - Fork 102
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Proposal - increase proportion of testing performed in docker containers #1809
Comments
I'm curious about the general thinking behind "Let's run test in containers". What problem should be solved by moving the tests into containers? And why did you chose containers as the tool to partition a beefy server? |
The problem (and I accept that wasn't clear from the title of this) is lack of xLinux capacity and an immediate need to resolve it, regardless of whether it's the final solution. This was the easiest setup to get going in a way that didn't require large numbers of systems and did not introduce extra complexity in the way things are running via jenkins. There is no explicit problem being solved by "moving the tests into containers" (Bear in mind I explicitly said in the description that I don't want all testing in containers, but a small amount seems prudent to catch any potential customer scenarios) Ref the choice of docker I wold suggest that with docker being increasingly popular as a choice of software execution it is prudent to perform some testing in such an environment |
It was clear to me, but I want to capture the thinking behind it. You don't have to convince me. Historically, we've done a lot of things where it wasn't clear why we did it this way afterwards. Normally, we would have created half a dozen VMs somewhere. Why not this time? |
Lack of sponsored providers with known capacity |
Summary: Because of a lack of sponsors of VMs we have to resort to using bare metal servers. To partition those (tests do not scale linearly with core count and available RAM), we decided to use containers instead of ESX and KVM to have more variation. Would you agree with that, @sxa? |
At least as an interim solution, yes other than saying that a large VM could handle the docker images as well, it doesn't explicitly require bare metal unlike other virtualisations. The |
Proposal receieved no objections during the last TSC meeting so I will proceed with getting this "production ready" CentOS8 images are going to need a little additional work but subject to the concerns listed in adoptium/aqa-tests#2138 this is going well. Next steps
I'm open to suggestions on the last one of these ... I've tried a couple of options:
Personally I'm coming round to the Slack thread for reference in case it contains more views :-) |
For my own notes. I had a try on ppc64le using containers restricted to 2 core/6Gb and am getting quite a lot of slowdown between that and running on the host |
For my 2 cents, it is nice to have test-docker in the name as then its very obvious. I like obvious! (exclamation mark!) |
I'm inclined to agree so I'll be renaming things to match this convention (after next week's release to avoid any confusion) in the absence of any major objections showing up in the meantime. Renames that need to occur to meet that are as follows (First column is the name of the existing docker images):
I do also want to try and have some more OSs if possible. So far I have Fedora 33 and Ubuntu 16.04/18.04/20.04 and 20.10 but we should have at least one RHEL derivative too (possibly including CentOS stream or UBI) |
Comment for completed moves: On test-packet-ubuntu1604-armv8-1 (147.75.74.50 - ThunderX):
On build-packet-ubuntu1804-armv8-1 (139.178.82.234) D05):
On test-packet-ubuntu2004-amd-1 (139.179.85.251 - EPYC):
On test-packet-ubuntu2004-amd-1 (147.75.79.143 - Intel GOLD):
I've left the osuosl and linaro ones as-is for now as they're not fully up and running yet |
testdocker.tar.gz (NOTE: Needs
hostname and which
added to install list on Fedora33)We are currently losing some of our capacity as a result of #1781. The biggest impact of this is on the Linux/x64 systems where we currently have 12 test systems (4 each of CentOS7, Debian8, and Ubuntu16.04). Losing this capacity will have a significant impact on our abnility to run testing.
In order to mitigate this, I am proposing running a subset (not all, since we need to test some using the real kernel for the operating system) in Docker containers. For prototyping purposes I am using one large system with static docker images of differnet OSs to give us a mix, but going forward we could probably spin them up on the fly in a comparable way to how we build the Linux/x64 and Linux/aarch64 builds using the
dockerBuild
nodes today.I have configured a 24-core (48 thread) system docker-packet-ubuntu2004-x64-1 with six static docker containers (One each of Ubuntu 16,04, 18.04, 20.04, 20.10) and two Fedora 33) and these are in jenkins with the name of the host system and a suffix to indicate the OS in the container. While this doesn't quite match the 12-machine set at GoDaddy it will still be adequate to prevent xLinux capacity from being a limiting factor
The important thing about this is that we need to understand how many tests can be performed within docker containers as (external tests excepted) it is not something we have tried before. The containers on this host are restricted to 4 CPUs each and 6Gb of RAM. This limitation prevents the
system
test suites in particular consuming all the resources on the machine. Initial testing from last night shows that the load on the machine was around the 25-30 mark, which is likely OK.Issues relating to running tests in docker specifically can be captured in adoptium/aqa-tests#2138
Dockerfiles used to create these images (not the full playbooks are in the attachment
If you have an concerns about this approach, feel free to add them into the comments :-)
The text was updated successfully, but these errors were encountered: