32 Commits

Author SHA1 Message Date
Jenkins
05a8acf0e7 Merge "Expose the vhost_name parameter on openstack_project::nodepool" 2014-10-24 13:34:47 +00:00
Jeremy Stanley
b565df047a Correct nodepool log vhost directory path
Change-Id: Id577ee397edda0af4b5d72ca4c5742e67c63c92c
2014-10-24 00:45:48 +00:00
Jenkins
5079df57b9 Merge "Stop notifying nodepool on log config changes" 2014-10-23 23:31:23 +00:00
Clark Boylan
434397fc0d Stop notifying nodepool on log config changes
Previously puppet would restart nodepool whenever the nodepool log
config changes. This is problematic because nodepool will try to do a
graceful shutdown which can take hours. During this time period no new
nodes are built. Stop doing this and rely on manual nodepool restarts
(which is status quo for any other nodepool changes).

Change-Id: I522070df96d4e455a2c478bcf832ae6bb8729bf2
2014-10-23 16:06:45 -07:00
Jeremy Stanley
c6ea9c4bbf Correct nodepool log document root reference
Change-Id: I19713d464ef62f6a9fc556475fb707311f5c023c
2014-10-23 23:01:31 +00:00
Jenkins
7b9c047612 Merge "Rotate out nodepool logs every 8-hours" 2014-10-23 21:19:08 +00:00
Ricardo Carrillo Cruz
5f4a50a34d Expose the vhost_name parameter on openstack_project::nodepool
The openstack_project::nodepool class does not expose vhost_name
parameter that is available in nodepool::init.pp class.

Change-Id: Ie975b4798d5219a3debde453e297bed3be72e9e6
Closes-Bug: 1383657
2014-10-23 12:58:40 +00:00
Ian Wienand
6d77d85ede Rotate out nodepool logs every 8-hours
Individual nodepool .log files have now grown to being > 250mb.  This
is a bit much to download and go through when you're trying to debug
an issue with a particular image.

8-hour rotations seems a bit more useful than 24-hour ... and perhaps
even that is a bit long.  I don't think we need to extended the number
of rotations, I'm not sure really old logs are that helpful.

Change-Id: Ia788db809afe470bb9241f17411e4fa97d09ea11
2014-10-22 10:32:52 +11:00
Ian Wienand
aa8a2584c1 Deploy vhost template for nodepool.o.o logs
In Ie0b269835ebb8effbac0285b782d8add7b47db32 I didn't consider how
difficult it is to get puppet to put in AllowOverride directives to
allow .htaccess to work.  The puppetlabs-apache version we use does
not support "override" as an argument, so you can't easily add this to
allow apache to read htaccess.  Upgrading is a big task because we are
so far behind (see I6fa5f3275a84ec4480169de562d1d4a656111814).

So deploy a full template for nodepool vhost that includes the config
options we need.

Additionally, the existing mimetype isn't set for the log-files

---
 $ curl -I http://nodepool.openstack.org/image.log.2014-10-14
 HTTP/1.1 200 OK
 Date: Fri, 17 Oct 2014 00:02:39 GMT
 Server: Apache/2.2.22 (Ubuntu)
 Last-Modified: Tue, 14 Oct 2014 23:59:56 GMT
 ETag: "f89bb-d458315-5056acfe33700"
 Accept-Ranges: bytes
 Content-Length: 222659349
---

I'm pretty sure this means it defaults to text/plain, but this makes
it explicit.  This should also matches on the timestampped log files
per the rules of multiple extensions [1]

[1] http://httpd.apache.org/docs/2.2/mod/mod_mime.html#multipleext

Change-Id: I7fa2603f4160b06af71a515e655d4a705fa0c768
2014-10-17 15:54:24 +11:00
Ian Wienand
bded3bc5a9 Enable gzip compression on nodepool logs
Add a .htaccess to the nodepool log directory to enable gzip
compression for text/text mime-types; e.g. the quite large .log files
that nodepool outputs there

Change-Id: Ie0b269835ebb8effbac0285b782d8add7b47db32
2014-10-15 11:58:28 +11:00
Ian Wienand
6b724858ec Install latest diskimage-builder on nodepool
Keep nodepool's version of diskimage-builder up-to-date by installing
the latest version for pip. DIB releases at least weekly so we can get
update quickly via this install method.

Change-Id: I7e97388d890d37f1f86b860c2309ab1d63f76e41
2014-10-10 10:20:19 -07:00
James E. Blair
c348a3237f Switch nodepool to project-config
Change-Id: I72dbb32d28bd30955ac6a76ebfceb9cd98a49d5f
2014-09-25 11:03:04 -07:00
Clark Boylan
ad2d29cf4b Put /usr/local/bin in nodepool PATH for dib
When we install dib via pip the executables are put in /usr/local/bin
which was not in nodepool's PATH. The PATH is configured by the init
script so update the variable to include /usr/local/bin.

Change-Id: Ie456ecf667d330b925d3168a456d4ac84d1c48f4
2014-09-23 13:38:45 -07:00
Clark Boylan
49df962f75 Give nodepool user sudo access for dib
Disk image builder requires root permissions to chroot and mount images.
Update the puppet manifest for nodepool to optionally enable
passwordless sudo access for the nodepool user. This defaults to being
allowed but can be toggled if this is deemed an unnecessary security
risk.

Change-Id: If0bf5f182d88c848cd2a64c5c75cc64cc0b42c58
2014-09-23 09:40:26 -07:00
Monty Taylor
7f5ab7fff4 Add pre-requisites needed for diskimage-builder
For nodepool to use diskimage-builder, it needs a set of pre-reqs
on the nodepool host. Install them.

Also create /opt/nodepool_dib for building images.  This is
deliberately placed on the non-ephemeral disk as new host builds have
a large partion mounted here.  Testing shows test images were coming
in at about 2.6GB each. If we figure two images for precise and trusty
and one each for centos6 and f20 that is about 15GB.

Change-Id: I725cad999f795a556fd89818578b78b9114fb110
2014-09-17 07:20:01 +10:00
Ramy Asselin
46518a0523 Allow zuul & nodepool to be installed on one VM
When attempting to install zuul & nodepool on a single machine
 (typical for third party environments) you get the following error:

Duplicate declaration: Package[python-lxml] is already declared in file
/root/config/modules/zuul/manifests/init.pp at line 64;
 cannot redeclare at /root/config/modules/nodepool/manifests/init.pp:39 on node ci.novalocal

Update the puppet scripts so that python-lxml do not conflict with each other.

Change-Id: I63453e46702d37fa845504f31fa006b0b9fc5330
2014-08-22 13:19:53 -07:00
James E. Blair
fdd01d84a8 Nodepool dependens indirectly on lxml
Nodepool now depends indirectly on lxml via keystoneclient.  To pip
install lxml you need libxml and libxslt development packages on the
system to provide headers so that the library bindings can be
compiled, so it's easier to just use the python-lxml system packages
instead.

Co-Authored-By: Jeremy Stanley <fungi@yuggoth.org>
Change-Id: Id5c2070250cd9474c83edaa6ed1119a5325ea913
2014-08-14 15:29:48 -07:00
Ramy Asselin
8c5918ecf5 Allow nodepool standalone puppet install
Installing nodepool standalone has this error:
 Could not find dependency Class[Pip] for Exec[install_nodepool] at
 /root/config/modules/nodepool/manifests/init.pp:90

Add the missing include pip statement.

Change-Id: Id30814eb1788e7b7eb533794a26c231000e9b41c
2014-05-29 17:49:18 -07:00
James E. Blair
398e1175f4 Fixes to nodepool installation on jenkins-dev.o.o
The patch to add nodepool to jenkins-dev (https://review.openstack.org/#/c/57333)
did not work.

There were a few issues with it:
  1. jenkins-dev.pp was passing literal strings to the nodepool module, instead it
     should be passing in the variables.
  2. jenkins-dev.pp was calling ::nodepool but puppet seems to think that it wants
     ::openstack_project::nodepool due to puppet's scoping weirdness :(
  3. The script to build nodepool machines needed the jenkins_dev_ssh_key.

Fixes to above issues:
  1. This is trivial, just passed the variables thru instead of literal strings.
  2. The nodepool.pp module is renamed to nodepool_prod.pp to prevent the scoping problem.
  3. We use the dev jenkins ssh key with dev nodepool by allowing the nodepool module
     to pass arbitrary env settings through the defaults file.

Change-Id: Id91053212f088079ff1b0f06ebdce5c381f5cd19
2014-04-25 11:52:08 -07:00
Matthew Oliver
8e9853cd4c Nodepool image logs accessible via HTTP
Nodepool logs the creation of nodepool images to an image.log which
are only accessible to root users. This change updates the nodepool
puppet configuration to install apache and allows users to access
these image logs.

Change-Id: I867030c258d00ce017c69812c133f3419215d045
2014-02-13 12:26:18 +11:00
Clark Boylan
d9cd59d5c5 Bump mysql connection limit for nodepool.
Nodepool is having its file descriptor limit bumped to 8192. Bump the
mysql connection limit to match to avoid having trouble on the other
side.

Change-Id: Ic164bddc860f8f569a2a0acb5290aaeb775bdd9a
2014-01-06 23:00:37 -08:00
Clark Boylan
48f9a1bd19 Bump nodepool's file descriptor limit.
Nodepool is running into file descriptor limits like Zuul. Again
compromise and bump the limit in the init script to give us breathing
room until the problem can be properly fixed.

Change-Id: Idd1fd679bdad1d3ea4951be7f9330214d7065027
2014-01-06 22:49:36 -08:00
Monty Taylor
0222d3040e Use pip install instead of setup.py install
The pip vs. easy_install interactions continually get the systems
into a weird state. pip install $path_to_repo, on the other hand,
works like a charm.

Left out two graphite installs because they are doing path manipulation
and I want to do further testing before touching that.

Change-Id: I373b29aca03f1ebd20e533ebaaf5de9ef2db017e
2013-10-27 18:38:38 -04:00
Jenkins
c164abc879 Merge "Upgrade puppetlabs-mysql to 0.6.1." 2013-10-12 20:57:34 +00:00
Jenkins
41a0740cf7 Merge "Remove ::1 mysql root user." 2013-10-12 20:56:12 +00:00
Clark Boylan
9a30d3a309 Upgrade puppetlabs-mysql to 0.6.1.
Puppetlabs-mysql 0.6.1 correctly removes the local ::1 root user in the
account_security manifest. Upgrade to this version to take advantage of
that. Do not upgrade to latest version (0.9.0) to minimize delta that
needs testing.

Change-Id: Ic8265733f1159f34ae0afcccdea4c7d8cd44e3cb
2013-10-12 17:37:24 +00:00
Clark Boylan
0adc30f151 Remove ::1 mysql root user.
The version of puppetlabs-mysql that we use does not remove the local
::1 root user from the mysqld. Explicitly remove this user.

Change-Id: I626fcc77c75a29d3f3cab57217b714e68a30b468
2013-10-12 17:32:09 +00:00
James E. Blair
c16d5c18f3 Set mysql max_connections to 1024 on nodepool
Nodepool can end up with one connection per thread when dealing
with launches and deletions.  If we have a lot of node turnover,
that's a lot of threads.

Change-Id: Ice483f5f9f3a47963357f9ff59bf4d735a18aa43
2013-09-27 15:10:33 -07:00
James E. Blair
ba7bc1799c Update nodepool init script to nodepoold
Change-Id: Ia119d3812b721810668c82bf2cb36a1a2d108307
2013-08-30 15:00:31 -07:00
James E. Blair
53478793d9 Add image logging config for nodepool
An upcoming change to nodepool supports logging the output from
the image creation process.  Use it.

Change-Id: I3a45a30f813d0f7b9fff4f602b945d72f2dcda3e
2013-08-29 16:25:02 -07:00
James E. Blair
6c8642ff08 Fix nodepool dir perms
Change-Id: If3f594559d7903c9eacd6d324e1ec9ed58c81a49
2013-08-16 20:46:17 -07:00
James E. Blair
8222c6e00f Add nodepool host
Change-Id: Ib216bd400aa269ccdb17848b3870ab65400cf3d2
2013-08-16 13:15:42 -07:00