NOTE: this is a draft document, just because there are some things here that I'd really like to improve. Please let me know if you have a better way to do these things. There's also a few issues with Puppet Dashboard that appear to be bugs that need either improved documentation or changes to their source RPM to fix. I'd love to see better ways to fix this.
I am attempting to document how one can take an EL5 system (like CentOS 5.x) to Ruby 1.8.7 and meets the minimum requirements for Puppet Dashboard. There are many reasons for this: 1. PuppetLabs blames many server-side issues on Ruby 1.8.5's known memory problems. They have indicated that only Ruby 1.8.7 is supportable. 2. Dashboard requires Ruby 1.8.7 3. Foreman requires Ruby 1.8.7 Requirements: EL5 system with rpmbuild utilities and ~/rpmbuild structure set up as documented nearly everywhere. If you use different paths, adjust as necessary for the remainder of the document. Step 1: Upgrade Ruby I have seen recommendations for Koran's Ruby build, but it didn't build on a fairly stock EL5 system, and included a bunch of unrelated-to-puppet Tk and JP patches. I found a much simpler spec file that appears to build properly on EL5 that uses a significantly higher patch level of Ruby, fixes the autoconf problems. It was trivial to review the few patches on this. wget http://rbel.frameos.org/stable/el5/SRPMS/ruby-1.8.7.352-5.el5.src.rpm rpm -i ruby-1.8.7.352-5.el5.src.rpm rpmbuild -ba ~/rpmbuild/SPECS/ruby.spec For any of the nodes, you need only put this RPM in your repository and have Puppet upgrade them. It just works ;-) For the passenger server, you'll need to get the source RPM from stealth monkeys. You don't need to change anything at all -- just build the SRC rpm and it will adjust everything to use Ruby 1.8.7. Very simple. wget http://passenger.stealthymonkeys.com/SRPMS/rubygem-passenger-3.0.11-1.src.rpm rpm -i rubygem-passenger-3.0.11-1.src.rpm rpmbuild -ba ~/rpmbuild/SPECS/passenger.spec Step 2: Dashboard Requirements First you need to get the mysql drivers for Ruby. The EPEL version binds against ruby 1.8.5, but you can compile their source RPM on your ruby-1.8.7 system and it will work great. wget ${EPEL_MIRROR_OF_CHOICE}/5/SRPMS/ruby-mysql-2.7.3-1.el5.src.rpm rpm -i ruby-mysql-2.7.3-1.el5.src.rpm rpmbuild -ba ~/rpmbuild/SPECS/ruby-mysql.spec Next thing is that Puppet Dashboard requires a newer version of Ruby Gems, but it doesn't tell you this. Instead it just barfs weird error messages. They need to rewrite their Rakefile to explicitly define the minimum versions. Thankfully, upgrading gems is very easy. wget http://rbel.frameos.org/stable/el5/SRPMS/rubygems-1.8.10-1.el5.src.rpm rpm -i rubygems-1.8.10-1.el5.src.rpm rpmbuild -ba ~/rpmbuild/SPECS/rubygems.spec Unfortunately, I never found a simple way to build RPMs for the three gems you need. I'd like to fix this next part of the HOWTO in the near future. For now, the easiest way to get the minimum requirements installed is to run the following commands. gem install rake gem install rdoc gem install rack -v 1.1.2 You'll observe that we installed a very specific version of Rack. The reason for this is that Puppet Dashboard includes rack 1.1.2 within the package, but the default Rakefile doesn't load it -- so it wants you to have Rack in your normal gems library too. However if the version doesn't match the same version included in the frozen vendor directory, it complains about that and barfs. I consider this a bug in the dashboard packaging: https://projects.puppetlabs.com/issues/11669 However, if you install 1.1.2 and nothing newer, it will work just fine. Step 3: Install Dashboard For unknown reasons to me, the source RPM for dashboard can't be extracted on EL5 unless you pass --nomd5 --nosignature. The good news is that the source RPM for EL6 compiles without any changes on EL5. wget http://yum.puppetlabs.com/el/6/products/SRPMS/puppet-dashboard-1.2.4-1.el6.src.rpm rpm --nomd5 --nosignature -i puppet-dashboard-1.2.4-1.el6.src.rpm rpmbuild -ba rpmbuild/SPECS/puppet-dashboard.spec That's it! You now have puppet dashboard installed with all dependancies. You can then follow the standard documentation from puppet labs at http://docs.puppetlabs.com/guides/installing_dashboard.html#installation Skip the first two #1 bullets and the first #2 bullet and start with the second #2. One problem I found was that when I tried to run it under Passenger/Apache, I was told that it couldn't read the config.ru file. I had to do the following to fix this: cd /usr/share/puppet-dashboard ln ./vendor/rails/railties/dispatches/config.ru config.ru This is already tracked in https://projects.puppetlabs.com/users/3472 This is working great for me right now. Let me know if you have any ideas for streamlining this process. -- Jo Rhett Net Consonance : consonant endings by net philanthropy, open source and other randomness -- You received this message because you are subscribed to the Google Groups "Puppet Users" group. To post to this group, send email to puppet-users@googlegroups.com. To unsubscribe from this group, send email to puppet-users+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/puppet-users?hl=en.