====== Install all e-smith/smeserver packages on EL6 ====== These are just my notes to get a EL6 system booting with all the e-smith and smeserver packages installed. As soon as I get it to boot, I'll put this info into contribs.org wiki. ===== Minimal EL6 Install ===== Just install a minimal el6 installation (I just installed a few utilities like htop, screen, rsync, vim, openssh-clients etc...). You can use either the DVD, the minimal CD install, a net install with PXE, it's up to you ;-) ===== Disable graphical boot ===== It will be easier to see what's going on (and turn off selinux at kernel level, just to be sure) sed -i -e 's/rhgb quiet/selinux=0/g' /boot/grub/menu.lst ===== Disable SELinux ===== sed -i -e 's/SELINUX=.*/SELINUX=disabled/g' /etc/sysconfig/selinux ===== Remove selinux-policy-targeted and authconfig ===== They conflict with some e-smith/smeserver packages yum remove selinux-policy-targeted authconfig ===== Configure third party repo ===== * Enable the EPEL repo rpm -Uvh http://fr2.rpmfind.net/linux/epel/6/i386/epel-release-6-8.noarch.rpm * Enable the ATrpms repo rpm -Uvh http://dl.atrpms.net/el6-x86_64/atrpms/stable/atrpms-repo-6-6.el6.x86_64.rpm * Enable RPMForge rpm -Uvh http://pkgs.repoforge.org/rpmforge-release/rpmforge-release-0.5.2-2.el6.rf.x86_64.rpm * Configure SME repository (EL5 version for now) cat<<'EOF' > /etc/yum.repos.d/sme.repo [smeaddons] enabled=1 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smeaddons-8 name=SME Server - addons gpgcheck=1 enablegroups=1 [smecontribs] enabled=0 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smecontribs-8 name=SME Server - contribs gpgcheck=1 enablegroups=1 [smedev] enabled=0 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smedev-8 name=SME Server - dev gpgcheck=1 enablegroups=1 [smeextras] enabled=1 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smeextras-8 name=SME Server - extras gpgcheck=1 enablegroups=1 [smeos] enabled=1 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smeos-8 name=SME Server - os gpgcheck=1 enablegroups=1 [smetest] enabled=0 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smetest-8 name=SME Server - test gpgcheck=1 enablegroups=1 [smeupdates] enabled=1 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smeupdates-8 name=SME Server - updates gpgcheck=1 enablegroups=1 [smeupdates-testing] enabled=0 mirrorlist=http://mirrorlist.contribs.org/mirrorlist/smeupdates-testing-8 name=SME Server - updates testing gpgcheck=1 enablegroups=1 EOF * import SME's GPG key rpm --import http://sme-mirror.firewall-services.com/releases/8/smeos/x86_64/RPM-GPG-KEY-SMEServer * install yum-plugin-priorities yum install yum-plugin-priorities ===== Configure yum priorities ===== * Set the base, updates and extras repo in /etc/yum.repos.d/CentOS-Base.repo a high priority (respectivly 50, 40, 50) [...] [base] name=CentOS-$releasever - Base mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os #baseurl=http://mirror.centos.org/centos/$releasever/os/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 priority=50 #released updates [updates] name=CentOS-$releasever - Updates mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=updates #baseurl=http://mirror.centos.org/centos/$releasever/updates/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 priority=40 #additional packages that may be useful [extras] name=CentOS-$releasever - Extras mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=extras #baseurl=http://mirror.centos.org/centos/$releasever/extras/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 priority=50 [...] * Set Epel to a priority of 60 in /etc/yum.repos.d/epel.repo [epel] name=Extra Packages for Enterprise Linux 6 - $basearch #baseurl=http://download.fedoraproject.org/pub/epel/6/$basearch mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-6&arch=$basearch failovermethod=priority enabled=1 gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6 priority=60 * Set RPMForge to a priority of 65 in /etc/yum.repos.d/rpmforge.repo [rpmforge] name = RHEL $releasever - RPMforge.net - dag baseurl = http://apt.sw.be/redhat/el6/en/$basearch/rpmforge mirrorlist = http://apt.sw.be/redhat/el6/en/mirrors-rpmforge #mirrorlist = file:///etc/yum.repos.d/mirrors-rpmforge enabled = 1 protect = 0 gpgkey = file:///etc/pki/rpm-gpg/RPM-GPG-KEY-rpmforge-dag gpgcheck = 1 priority=65 * Set atrpms to priority of 70 in /etc/yum.repos.d/atrpms.repo [atrpms] name=Red Hat Enterprise Linux $releasever - $basearch - ATrpms failovermethod=priority baseurl=http://dl.atrpms.net/el$releasever-$basearch/atrpms/stable enabled=1 gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-atrpms priority=70 ===== Install som epackage without dependancy check ===== A few packages have to be installed manually without dependancy check: rpm -Uvh --nodeps http://sme-mirror.firewall-services.com/releases/8/smeupdates/x86_64/RPMS/smeserver-yum-2.2.0-20.el5.sme.noarch.rpm rpm -Uvh --nodeps http://sme-mirror.firewall-services.com/releases/8/smeupdates/x86_64/RPMS/e-smith-samba-2.2.0-49.el5.sme.noarch.rpm rpm -Uvh --nodeps http://sme-mirror.firewall-services.com/releases/8/smeos/x86_64/SME/e-smith-test-2.2.0-1.el5.sme.noarch.rpm * Two perl package need to be installed manually with sme and epel repo disabled (I need to figure out why repo priority doesn't fix this) yum install perl-Razor-Agent perl-Data-UUID --disablerepo=sme\* --disablerepo=epel ===== Install e-smith-base ===== Now, you should be ready to install e-smith-base. For me, this pulls 222 packages (166MB). For some reason, the GPGKey is not recognized, so just run yum with --nogpgcheck yum --nogpgcheck install e-smith-base ===== Install the remaining e-smith/smeserver packages ===== Now install all the remaining e-smith/smeserver packages yum --nogpgcheck install e-smith\* smeserver\* It should install the following packages and their dependancies: e-smith e-smith-LPRng e-smith-apache e-smith-backup e-smith-devtools e-smith-dynamicdns-dyndns e-smith-dynamicdns-dyndns.org e-smith-dynamicdns-tzo e-smith-dynamicdns-yi e-smith-flexbackup e-smith-horde e-smith-hosts e-smith-imp e-smith-ingo e-smith-ldap e-smith-lib-compspec e-smith-mysql e-smith-ntp e-smith-oidentd e-smith-openssh e-smith-php e-smith-pptpd e-smith-proftpd e-smith-proxy e-smith-qmailanalog e-smith-quota e-smith-radiusd e-smith-turba e-smith-viewlogfiles smeserver-release ===== Install samba ===== Now install samba-client (e-smith-samba has been installed manually without dep check, otherwise it would have pulled samba3x package instead of samba) yum install samba-client ===== Replace upstart with SysVinit ===== We've almost finished, we just have to replace upstart with the good old SysVinit, because upstart doesn't support the custom runlevel 7 SME uses rpm -e --nodeps upstart sysvinit-tools rpm -Uvh http://sme-mirror.firewall-services.com/releases/8/smeos/x86_64/SME/SysVinit-2.86-17.el5.x86_64.rpm ===== Move some perl modules ===== We need to copy some perl modules to a new directory, because @INC has changed in EL6: cp -a /usr/lib/perl5/site_perl/esmith/ /usr/share/perl5/vendor_perl/ ===== Create a service entry for rsyslog ===== We need to create a new service entry in the DB, because the standard syslog package is now rsyslog: /sbin/e-smith/db configuration set rsyslog service status enabled cp -a /etc/rc7.d/S05syslog /etc/rc7.d/S05rsyslog ===== Run post-upgrade ===== We can now try to post-upgrade /sbin/e-smith/signal-event post-upgrade And reboot. Unfortunatly, I wasn't able to reboot properly at this stage, because of the upstart -> SysVinit transition (the error message is "/dev/initctl: No such file or directory") so I had to destroy the VM completly ===== The system boots but completly broken :-) ===== Ok, so the system should now boot, but is really not usable, after a quick look, at least the following doesn't work as expected: * The console on the first boot don't really work. It asks for the admin password (and BTW the password appears in cleartext) but it's all * No network interfaces are detected by the console menu (because kudzu is not installed, only available in SME repo, and require an older python which conflicts with the the one from EL6) * slapd won't start * httpd won't start * squid won't start * manually running expand-template has no effect (and no error message is printed). But signal-event seems to work (files get expanded and services restarted) * as the network interface are not configured, all the services which requires the internel IP (or the external one) in their config (at least sshd squid and dnscache) won't start * even if we manually add 0.0.0.0 after the ListenAddress line in /etc/ssh/sshd_config, we cannot connect using SSH (the daemon is running, but from a computer on the same network, I get a ssh_exchange_identification: Connection closed by remote host error) * qpsmtpd won't start (can't locate Qpsmtpd/TcpServer.pm in @INC) * There's probably a lot more which is not working * [[what_is_not_working_on_el6|A more complete list of broken things]]