I had a user ask for Java to be installed on the cluster systems, so I started up by making a simple JRE5 module for puppet, but this first one didn’t quite work:
class jre5 { package { "sun-java5-jre": ensure => latest; } }
It doesn’t work because Sun wants you to agree to its license before installing the JRE. There’s a couple of ways around this. First, the old-school method:
ssh host "yes | apt-get -y install sun-java5-jre"
where ‘yes’ is a standard Unix program that just prints out “yes” over and over until the program on the other side of the pipe terminates. But “ssh host foo” is not the way of the managed infrastructure.
The second method, much more friendly to centralized management, is to first install debconf-utils on a candidate system, and then install sun-java5-jre on the same system. Once that’s done, you can query the debconf database to see how it stored your answers to the Sun license agreement:
ch226-12:~# debconf-get-selections | grep sun- sun-java5-bin shared/accepted-sun-dlj-v1-1 boolean true sun-java5-jre shared/accepted-sun-dlj-v1-1 boolean true sun-java5-jre sun-java5-jre/jcepolicy note sun-java5-jre sun-java5-jre/stopthread boolean true sun-java5-bin shared/error-sun-dlj-v1-1 error sun-java5-jre shared/error-sun-dlj-v1-1 error sun-java5-bin shared/present-sun-dlj-v1-1 note sun-java5-jre shared/present-sun-dlj-v1-1 note
Save those results (debconf seeds) into a file on the gold server. Then we can modify our jre5 class as follows:
class jre5 { package { "sun-java5-jre": require => File["/var/cache/debconf/jre5.seeds"], responsefile => "/var/cache/debconf/jre5.seeds", ensure => latest; } file { "/var/cache/debconf/jre5.seeds": source => "puppet:///jre5/jre5.seeds", ensure => present; } }
Now our class will download the preseeded answers for the Java license, download and install the JRE, and then use the preseeded answers to skip past the license agreement. I had never messed with debconf seeding previously, since I had either just imaged my systems, or provided config files that would be used when I restarted any daemons or programs that depended on those files. Now debconf-utils is part of my standard system class definition.
Note that this method doesn’t work with the default puppet provided in Debian Etch (version 0.20) — the responsefile parameter for Debian packages was only added in puppet 0.22.
When I ran debconf-get-selections, the various ‘accepted’ fields had the value ‘select true’. This still causes you to be asked (or, if using puppet, the install to fail.) So this is a note to anyone else finding this: make sure that they are ‘boolean true’ as they are in this post. It turns out to be something that takes about 45 minutes of staring to work out ๐
Additionally, there must not be more than a single space between ‘boolean’ and ‘true’ or you may spend a very long time figuring it out again.
Even if that’s what debconf-get-selections provides in your case.
Odd. I don’t recall editing anything in the debconf output; it may have changed with the Lenny release? Might be something else entirely, too.
Thank you SO much for this! Have been looking around for a while for a good solution to that problem. It is quite painful to accept the license agreement manually on tens of servers ๐
Thank you. Also: I run Lenny on my machines and I didn’t have to edit the debconf-get-selections output.
This is awesome! Thank you very much. If I get time, I will repost this on my blog updated for Ubuntu 10.04, Puppet 0.25 and JDK6
Excellent ! Just what I was looking for ! I didn’t even know this preseeding technique.
Successfully applied this pre-seeding technique for java6 / ubuntu 10.04.
Trรจs bien !