Difference between revisions of "Setting up RPM Building for SME Server"
Line 68: | Line 68: | ||
$ cd ~/rpms/e-smith-runit/sme9 | $ cd ~/rpms/e-smith-runit/sme9 | ||
$ make mockbuild | $ make mockbuild | ||
+ | |||
+ | # If there is no sme9 directory do | ||
+ | $ cd ~rpms/module_name | ||
+ | $ ln -s sme8 devel | ||
+ | $ cd devel | ||
+ | $ make mockbuild | ||
+ | |||
It will determine if this is for SME Server 9 or 8, and the package to build, based on which directory that you are in. The results are put under that directory. | It will determine if this is for SME Server 9 or 8, and the package to build, based on which directory that you are in. The results are put under that directory. | ||
Line 78: | Line 85: | ||
state.log | state.log | ||
+ | Note if there are any perl directory requirments : | ||
+ | |||
+ | $ rpm -qpl package_name.noarch.rpm |grep perl | ||
+ | |||
+ | Add your notes to http://wiki.contribs.org/SME9BuildQueue | ||
Notes: | Notes: |
Revision as of 03:45, 2 February 2013
Setting up RPM Building for SME Server
http://www.openfusion.net/linux/mocking_rpms
Mock is a Fedora project that allows you to build RPM packages within a chroot environment, allowing you to build packages for other systems than the one you're running on (e.g. building CentOS 4 32-bit RPMs on a CentOS 5 64-bit host), and ensuring that all the required build dependencies are specified correctly in the RPM spec file.
It is recommended that you use the latest CentOS 6 (64bit) version as a base http://mirror.centos.org/centos/6/isos/x86_64/
- I have verified this with CentOS-6.3-x86_64-bin-DVD1.iso
You should apply all available updates.
# Check for, and apply, all updates
yum update
You need to have EPEL repository configured as EPELs version of mock will be used
# Enable EPEL for Centos 6
rpm -Uvh http://fr2.rpmfind.net/linux/epel/6/i386/epel-release-6-8.noarch.rpm
So then the installation of mock is just:
Installing Mock
# Install mock and python-ctypes packages (the latter for better setarch support) $ sudo yum --enablerepo=epel install mock python-ctypes # Also need make and rpm-build $ sudo yum install make rpm-build
# Add yourself to the 'mock' group that will have now been created $ sudo usermod -G mock [youraccount]
The mock package creates an /etc/mock directory with configs for various OS versions (mostly Fedoras). Shad has provided working configurations for SME Server here http://mirror.canada.pialasse.com/contribs/slords/mock/
Copy all the .cfg files into /etc/mock including overwriting the site-defaults.cfg
Testing building environment
You can then run a test by doing:
# e.g. initialise a smeserver-9-x86_64-base chroot environment $ CONFIG=smeserver-9-x86_64-base $ mock -r $CONFIG --init # It might take a while to configure at the "Start: yum update"
which will setup an initial chroot environment using the given config. If that seemed to work (you weren't inundated with error messages), you can try a build: You will need an SRPM, for instance from http://mirror.canada.pialasse.com/releases/testing/9/smeupdates-testing/SRPMS/
# Rebuild the given source RPM within the chroot environment # usage: mock -r <mock_config> --rebuild /path/to/SRPM e.g. $ mock -r $CONFIG --rebuild ~/rpmbuild/SRPMS/e-smith-runit-2.4.0-1.el6.sme.src.rpm
If the build succeeds, it drops your packages into the /var/lib/mock/$CONFIG/result directory. If it fails, you can check mock output, the *.log files above for more info, and/or rerun mock with the -v flag for more verbose messaging.
ls -1 /var/lib/mock/smeserver-9-x86_64/result build.log e-smith-runit-2.4.0-1.el6.sme.noarch.rpm e-smith-runit-2.4.0-1.el6.sme.src.rpm root.log state.log
Normally you make builds from the working directory of the module you are working on, eg ~/rpms/e-smith-runit/sme9:
# Build the given module within the chroot environment $ cd ~/rpms/e-smith-runit/sme9 $ make mockbuild
# If there is no sme9 directory do $ cd ~rpms/module_name $ ln -s sme8 devel $ cd devel $ make mockbuild
It will determine if this is for SME Server 9 or 8, and the package to build, based on which directory that you are in. The results are put under that directory.
ls -1 ~/rpms/e-smith-runit/sme9/e-smith-runit-2_4_0-2_el6_sme/ build.log e-smith-runit-2.4.0-2.el6.sme.noarch.rpm e-smith-runit-2.4.0-2.el6.sme.src.rpm root.log state.log
Note if there are any perl directory requirments :
$ rpm -qpl package_name.noarch.rpm |grep perl
Add your notes to http://wiki.contribs.org/SME9BuildQueue
Notes:
- Using the provided .cfg files I have verified smeserver-8-x86_64-base.cfg & smeserver-9-x86_64-base.cfg and managed to build e-smith-runit for SME 9
- the chroot environments are cached, but rebuilding them and checking for updates can be pretty network intensive, so you might want to consider setting up a local repository to pull from. mrepo (available from rpmforge) is pretty good for that.
- there don't seem to be any hooks in mock to allow you to sign packages you've built, so if you do want signed packages you need to sign them afterwards via a rpm --resign $RPMS.
- If you get an error message 'create archive failed cpio: Bad magic' then try 'yum update' as this appears to be a known problem on COS6.