420 Commits

Author SHA1 Message Date
James E. Blair
eeb69e7ba2 Fix htpasswd creation for registry
We were using the wrong filename and encryption type.

Change-Id: I48d2a7288e5cd52e57f5632fee17f677429a1a9c
2019-02-16 11:59:56 -08:00
James E. Blair
e9e1535646 Temporarily stop installing openshift
Change-Id: If7a1070da62fb1d1aec5c5c530e0af174e3c3cf8
2019-02-14 10:19:59 -08:00
Zuul
d3e554e306 Merge "Stop running k8s-on-openstack nested" 2019-02-12 22:22:06 +00:00
Monty Taylor
0c4a981f73 Stop running k8s-on-openstack nested
The current code runs k8s-on-openstack's ansible in an ansible
task. This makes debugging failures especially difficult.

Instead, move the prep task to update-system-config, which will
ensure the repo is cloned, and move the post task to its own
playbook. The cinder storage class k8s action can be removed from
this completely as it's handled in the rook playbook.

Then just run the k8s-on-openstack playbook as usual, but without
the cd first so that our normal ansible.cfg works.

Change-Id: I6015e58daa940914d46602a2cb64ecac5d59fa2e
2019-02-12 18:17:46 +00:00
Zuul
c820963613 Merge "Install kubectl on bridge" 2019-02-11 22:02:36 +00:00
James E. Blair
94d404a535 Install kubectl on bridge
With a snap package.  Because apparently that's how that's done.

Change-Id: I0462cc062c2706509215158bca99e7a2ad58675a
2019-02-11 10:16:58 -08:00
James E. Blair
0d0e704267 Open port 5000 on the docker intermediate registry
Change-Id: I444356c3b3f0b8d5796b80ff125d381d03e2aaba
2019-02-11 09:57:14 -08:00
Zuul
34ecc43f2a Merge "Add opendev kubernetes nodes to ansible inventory" 2019-02-08 19:02:42 +00:00
Zuul
bf34a2e3c3 Merge "Update k8s-on-openstack for ssh known_hosts" 2019-02-08 18:30:14 +00:00
Zuul
6838616dde Merge "Run base-repos as ubuntu on k8s nodes to bootstrap" 2019-02-08 18:27:02 +00:00
James E. Blair
175a337e01 Handle registry role running under py3
Also, correct the host_vars filename.  Again.
Also, make sure we run the test on changes to the host_vars filename.

Change-Id: I95fb61531bae677f5c68f4e56ed718da6c507eb9
2019-02-08 09:13:06 -08:00
Monty Taylor
07edd9d297 Add opendev kubernetes nodes to ansible inventory
We want our base ansible roles to run on these nodes. However,
k8s-on-openstack manages firewall rules via openstack security
groups, so we don't want to run those there.

There was a discussion about making a minimal set of roles that
are run by default and then a group containing servers that got
the full set ... but that would require a duplicate entry for 99%
of our servers in the inventory, while the "only run a subset" is
the exception case.

Change-Id: I2cbf364305f758cecf11df41398d3d2c05222fda
2019-02-08 16:49:01 +00:00
Monty Taylor
a252f99de9 Update k8s-on-openstack for ssh known_hosts
Upstreamed a patch to improve ssh known_hosts handling.

https://github.com/infraly/k8s-on-openstack/pull/45

Change-Id: I2593f276df0c8b9637c05d41d80abfedf0904582
2019-02-08 16:48:58 +00:00
James E. Blair
ab557b2a98 Correct insecure-ci-registry01 hostvar filename
It's in opendev, not openstack.

Change-Id: Ib2f4154b18e6c15210e1f6ded9c1628b2fe5ef7a
2019-02-07 13:32:35 -08:00
James E. Blair
2766ec2595 Tell ansible to use py3 on insecure-ci-registry01
Change-Id: If0cf34f55524b7c87133fe04abb5513ad57e893b
2019-02-07 09:44:39 -08:00
Monty Taylor
8b71bf1a33 Run base-repos as ubuntu on k8s nodes to bootstrap
k8s-on-openstack uses the baked in ubuntu user and ssh keypairs
to interact with the host. Our other roles assume that we'll be
logging in directly as root.

Run base-repos logging in as ubuntu with become: true set so that
we can overwrite the root ssh key with the one allowing direct
login from bridge.

Change-Id: I98e91e0a9e5f4a44fcad8f22a0f710ce2c4138e0
2019-02-07 11:31:58 +00:00
James E. Blair
7610682b6f Configure .kube/config on bridge
Add the gitea k8s cluster to root's .kube/config file on bridge.

The default context does not exist in order to force us to explicitly
specify a context for all commands (so that we do not inadvertently
deploy something on the wrong k8s cluster).

Change-Id: I53368c76e6f5b3ab45b1982e9a977f9ce9f08581
2019-02-06 15:43:19 -08:00
Zuul
b427d64a07 Merge "Add resources for deploying rook and xtradb to kuberenets" 2019-02-06 18:08:48 +00:00
Zuul
ed731bc24c Merge "Set explicit version for k8s-on-openstack" 2019-02-06 14:05:20 +00:00
Zuul
133116a430 Merge "Save a copy of all messages to openstack-discuss" 2019-02-05 21:07:47 +00:00
Zuul
a765807789 Merge "Run k8s-on-openstack to manage k8s control plane" 2019-02-05 20:34:58 +00:00
Monty Taylor
b867289ad2 Add resources for deploying rook and xtradb to kuberenets
The gitea service needs an HA shared filesystem, which is provided by
cephfs and managed by rook.io.

It also needs a database service, which is provided by
percona-xtradb-cluster.

Change-Id: Ie019c2e24c3780cec2468a00987dba4ac34ed570
2019-02-05 18:52:21 +00:00
Monty Taylor
9b276914bd Set explicit version for k8s-on-openstack
In order to make sure we don't accidentally get broken by any
upstream patches, pin k8s-on-openstack to a specific sha.

Change-Id: Iabd80a7f95646304ed293fe11bed3a9260411705
2019-02-05 18:50:31 +00:00
Monty Taylor
9cac3c6b63 Run k8s-on-openstack to manage k8s control plane
The k8s-on-openstack project produces an opinionated kubernetes
that is correctly set up to be integrated with OpenStack. All of the
patches we've submitted to update it for our environment have been
landed upstream, so just consume it directly.

It's possible we might want to take a more hands-on forky approach in
the future, but for now it seems fairly stable.

Change-Id: I4ff605b6a947ab9b9f3d0a73852dde74c705979f
2019-02-05 18:50:31 +00:00
Jeremy Stanley
fea54bc43c Move OpenStackID host_vars to group_vars
Both staging and production OpenStackID servers are being updated to
our enumerated host naming convention as part of their upgrade from
Ubuntu Trusty to Xenial. Move their host-specific Ansible variables
to the new host groups we've created for each of them.

Change-Id: I359a51812b749bf9937943bae1cf1850bc1f85c3
2019-02-05 17:19:17 +00:00
Zuul
1604ac6325 Merge "Run a docker registry for CI" 2019-02-04 22:11:13 +00:00
Zuul
40c40c5a1f Merge "Grab container logs at the end of run-base" 2019-02-04 21:56:06 +00:00
Zuul
bd3e496449 Merge "Use stage-output role in system-config-run" 2019-02-04 21:43:29 +00:00
Colleen Murphy
0727a5b3a6 Fix update_puppet_version playbook
Updating the system-config git checkout was not working correctly. Since
we don't need the whole repo anyway, just retrieve the install_puppet.sh
script.

Change-Id: If83482eacdb303ea4fc3fe453818ea435ed062dc
2019-02-03 12:25:04 +01:00
James E. Blair
12709a1c8b Run a docker registry for CI
Change-Id: If9669bb3286e25bb16ab09373e823b914b645f26
2019-02-01 10:12:51 -08:00
James E. Blair
8062f4c1ec Grab container logs at the end of run-base
So that we automatically get container logs for future jobs
which use containers.

Change-Id: I329c67eefb8c6a2ff9a8ce8ef69cc844cef6012a
2019-02-01 10:12:39 -08:00
James E. Blair
22ad414a86 Use stage-output role in system-config-run
This simplifies log collection.

Change-Id: I754637115f8c7469efbc1856e88bbcb6fb83b4ce
Depends-On: https://review.openstack.org/634293
2019-01-31 11:03:25 -08:00
James E. Blair
d145e86f71 Switch to zuul-jobs docker build jobs
There are upstream jobs in zuul-jobs with the docker build playbooks,
so use them.  The system-config jobs are kept so that we don't have
to duplicate the secret stanza.

Change-Id: Iceee55a3d0e8b243549fa988f134b1ea9bb6dac5
2019-01-23 13:44:04 -08:00
James E. Blair
9e6db28ffb Save a copy of all messages to openstack-discuss
To debug DMARC issues, save a copy of every message sent to
openstack-discuss with as little manipulation as possible.

Change-Id: Ic1156849957bc326e9216c2aca0ab9d180e158e6
2019-01-23 11:19:00 -08:00
James E. Blair
f99b72fd0c Correct typo in zuul restart playbook
This is very confusing when watching the output.

Change-Id: I555f8ac1689192f40af509db1a85890250fda027
2019-01-23 08:53:42 -08:00
James E. Blair
7a6ae3aadb Add docker image building jobs
This adds the infrastructure for building docker images: the
credential used to upload to Docker Hub as well as the parent jobs
and playbooks to perform the builds.

Change-Id: I7cbbcdd184c4934f1b0ce5905d9760c732b06aa9
Depends-On: https://review.openstack.org/631078
2019-01-16 11:28:14 -08:00
James E. Blair
9e6a4d327e Remove all docker image building jobs
These will be re-added in followup changes based on the new
zuul-jobs roles.

Change-Id: I0c0691afb180903c573cc1a9eb39590fa58e7ca6
2019-01-16 11:28:07 -08:00
Monty Taylor
b1c4a6d36a Build a gerrit image
The gerrit source dir needs three plugins cloned into
the plugins dir and also a few files updated.

Depends-On: https://review.openstack.org/631007
Change-Id: I56037137d43ee1cea0a4c17e48d09102e1599ddc
2019-01-16 11:27:20 -08:00
Monty Taylor
d1a2dfa6f5 Add support for per-image build-arg settings
Change-Id: Ia14397389be0c7178c1879844cd675a3d291a3d0
2019-01-15 09:27:16 -08:00
James E. Blair
a546e25e76 Delete change tags from docker image repos
Whenever we promote an image, delete the change tag for that image
in Docker Hub, and also delete any change tags older than 24 hours
in order to keep the Docker Hub image registry tidy.

Change-Id: Id4654c893963bdb0a364b1132793fe4fb152bf27
2019-01-14 16:51:13 -08:00
Monty Taylor
700f195706
Add support for passing path to docker build
If we clone gerrit to ~/src/gerrit.googlesource.com/gerrit but
want to keep the Dockerfile in system-config, then we need to be
able to run:

  docker build ~/src/gerrit.googlesource.com/gerrit -f Dockerfile

Most of the time the dir will just be '.', so put in a sensible
default.

Change-Id: I235080c05e679d2ac270cd5401b85c655fab3112
2019-01-12 21:34:40 +00:00
James E. Blair
2059b73584 Fix image promote playbook
This job has no nodes; the playbook needs to run on localhost.
The only tasks use the uri module without local files, so should
be safe.

Change-Id: Ic012426a66be3b85efe9af35089addf1316dfa63
2019-01-11 13:39:07 -08:00
James E. Blair
899a2023d2 Use promote pipeline for system-config images
Upload an image to dockerhub with a change-specific tag in every
gate job, and then, if the change lands, re-tag the image in
dockerhub.

Change-Id: Ie57fc342cbe29d261d33845829b77a0c1bae5ff4
2019-01-11 08:22:19 -08:00
James E. Blair
3ce494abab Add gitea dockerfile
Change-Id: Iae2c4cbd174212e97445dd3080e2b85be730c5c4
Story: 2004627
2019-01-10 10:53:48 -08:00
Zuul
b671e4056e Merge "Install openshift module on bridge" 2019-01-09 23:27:23 +00:00
Clark Boylan
b8b1fdde75 Nameservers are now managed with ansible
Remove the puppetry for managing nameservers as we now use ansible
configured name servers without puppet.

We will need to follow this up with deletion of the existing
ns*.openstack.org and adns1.openstack.org servers.

Change-Id: Id7ec8fa58c9e37ce94ec71e4562607914e5c3ea4
2019-01-08 16:16:49 -08:00
Colleen Murphy
edc0571d66 Fix glob for lists.katacontainers.io
Change-Id: I000146f0ea048ea1c82a766875ce536f63b7d940
2019-01-04 08:08:52 -08:00
Colleen Murphy
2f766f2cb5 Turn on future parser for one zuul executor
Change-Id: I8e5b0da658ebc85a7182341b5ac9e135f633bb42
2019-01-04 08:08:52 -08:00
Colleen Murphy
09d854e899 Turn on future parser for one nodepool builder
Change-Id: I92ad4527653ee2024f938b50e7e8062396824af3
2019-01-04 08:08:52 -08:00
Colleen Murphy
289520bd3b Turn on the future parser for master nameserver
Change-Id: I30a42d01453f48fd4edc3b3e71b0b4218ba1cfa2
2019-01-04 08:08:47 -08:00