Port centos-minimal to yum-minimal
Now that we have a generic yum-minimal element, just use it in centos instead of rinse. Adding base as an element-provides of yum-minimal because this element conflicts with the base element. Co-Authored-By: Gregory Haynes <greg@greghaynes.net> Change-Id: I15275d821781171c118f21aa0c0bca55f65a65b3
This commit is contained in:
parent
c67ab571cb
commit
eadd79c2cb
@ -3,9 +3,12 @@ centos-minimal
|
|||||||
==============
|
==============
|
||||||
Create a minimal image based on CentOS 7.
|
Create a minimal image based on CentOS 7.
|
||||||
|
|
||||||
Use of this element will also require the tool 'rinse' to be
|
Use of this element will require 'yum' and 'yum-utils' to be installed on
|
||||||
available on your system. It should be available on Ubuntu and Debian.
|
Ubuntu and Debian. Nothing additional is needed on Fedora or CentOS.
|
||||||
|
|
||||||
The `DIB_OFFLINE` or more specific `DIB_CENTOS_USE_RINSE_CACHE`
|
This element cannot be used with the base element, therefore must pass the -n
|
||||||
|
flag to disk-image-create when using this element.
|
||||||
|
|
||||||
|
The `DIB_OFFLINE` or more specific `DIB_YUMCHROOT_USE_CACHE`
|
||||||
variables can be set to prefer the use of a pre-cached root filesystem
|
variables can be set to prefer the use of a pre-cached root filesystem
|
||||||
tarball.
|
tarball.
|
||||||
|
@ -1,4 +1 @@
|
|||||||
dib-run-parts
|
yum-minimal
|
||||||
redhat-common
|
|
||||||
rpm-distro
|
|
||||||
yum
|
|
||||||
|
@ -1 +1,2 @@
|
|||||||
|
base
|
||||||
operating-system
|
operating-system
|
||||||
|
@ -1 +1,2 @@
|
|||||||
export DISTRO_NAME=centos7
|
export DISTRO_NAME=centos
|
||||||
|
export DIB_RELEASE=${DIB_RELEASE:-7}
|
||||||
|
@ -1,119 +0,0 @@
|
|||||||
#
|
|
||||||
# packages which we will need to download for a minimal installation for
|
|
||||||
# CentOS 7.x
|
|
||||||
#
|
|
||||||
|
|
||||||
audit-libs
|
|
||||||
basesystem
|
|
||||||
bash
|
|
||||||
binutils
|
|
||||||
bzip2-libs
|
|
||||||
chkconfig
|
|
||||||
cracklib
|
|
||||||
cracklib-dicts
|
|
||||||
crontabs
|
|
||||||
coreutils
|
|
||||||
libdb
|
|
||||||
device-mapper
|
|
||||||
e2fsprogs
|
|
||||||
e2fsprogs-libs
|
|
||||||
elfutils-libelf
|
|
||||||
ethtool
|
|
||||||
expat
|
|
||||||
file-libs
|
|
||||||
filesystem
|
|
||||||
findutils
|
|
||||||
gawk
|
|
||||||
gdbm
|
|
||||||
glib2
|
|
||||||
glibc
|
|
||||||
glibc-common
|
|
||||||
grep
|
|
||||||
info
|
|
||||||
initscripts
|
|
||||||
iputils
|
|
||||||
keyutils-libs
|
|
||||||
krb5-libs
|
|
||||||
libacl
|
|
||||||
libattr
|
|
||||||
libcap
|
|
||||||
libcom_err
|
|
||||||
libgcc
|
|
||||||
libidn
|
|
||||||
libselinux
|
|
||||||
libsepol
|
|
||||||
libstdc++
|
|
||||||
libsysfs
|
|
||||||
libgcrypt
|
|
||||||
dbus-libs
|
|
||||||
libcurl
|
|
||||||
lua
|
|
||||||
libutempter
|
|
||||||
libxml2
|
|
||||||
libxml2-python
|
|
||||||
logrotate
|
|
||||||
lsof
|
|
||||||
man-pages
|
|
||||||
m2crypto
|
|
||||||
mcstrans
|
|
||||||
mlocate
|
|
||||||
ncurses
|
|
||||||
ncurses-libs
|
|
||||||
neon
|
|
||||||
net-tools
|
|
||||||
nss
|
|
||||||
nss-sysinit
|
|
||||||
nss-softokn
|
|
||||||
nss-softokn-freebl
|
|
||||||
openldap
|
|
||||||
libssh2
|
|
||||||
cyrus-sasl-lib
|
|
||||||
nss-util
|
|
||||||
nspr
|
|
||||||
openssl-libs
|
|
||||||
pam
|
|
||||||
passwd
|
|
||||||
libuser
|
|
||||||
ustr
|
|
||||||
pcre
|
|
||||||
popt
|
|
||||||
procps-ng
|
|
||||||
psmisc
|
|
||||||
pygpgme
|
|
||||||
python
|
|
||||||
python-libs
|
|
||||||
python-pycurl
|
|
||||||
python-iniparse
|
|
||||||
python-urlgrabber
|
|
||||||
readline
|
|
||||||
rpm
|
|
||||||
rpm-libs
|
|
||||||
rpm-python
|
|
||||||
sed
|
|
||||||
setup
|
|
||||||
shadow-utils
|
|
||||||
sudo
|
|
||||||
centos-release
|
|
||||||
sqlite
|
|
||||||
rsyslog
|
|
||||||
tzdata
|
|
||||||
util-linux
|
|
||||||
xz
|
|
||||||
xz-libs
|
|
||||||
yum
|
|
||||||
yum-plugin-fastestmirror
|
|
||||||
yum-plugin-keys
|
|
||||||
yum-plugin-protectbase
|
|
||||||
yum-metadata-parser
|
|
||||||
yum-utils
|
|
||||||
zlib
|
|
||||||
libffi
|
|
||||||
libsemanage
|
|
||||||
libblkid
|
|
||||||
libmount
|
|
||||||
device-mapper-libs
|
|
||||||
libestr
|
|
||||||
gmp
|
|
||||||
json-c
|
|
||||||
libss
|
|
||||||
libuuid
|
|
@ -1,7 +0,0 @@
|
|||||||
{
|
|
||||||
"family": {
|
|
||||||
"redhat": {
|
|
||||||
"lsb_release": "redhat-lsb",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,109 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# Copyright 2014 Hewlett-Packard Development Company, L.P.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
# not use this file except in compliance with the License. You may obtain
|
|
||||||
# a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
# License for the specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
||||||
#
|
|
||||||
|
|
||||||
if [ ${DIB_DEBUG_TRACE:-1} -gt 0 ]; then
|
|
||||||
set -x
|
|
||||||
fi
|
|
||||||
set -eu
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
if [ -f ${TARGET_ROOT}/.extra_settings ] ; then
|
|
||||||
. ${TARGET_ROOT}/.extra_settings
|
|
||||||
fi
|
|
||||||
# Override global DISTRO_NAME, because centos7 does not work for rinse
|
|
||||||
DISTRO_NAME=centos
|
|
||||||
DIB_RELEASE=${DIB_RELEASE:-7}
|
|
||||||
DIB_RINSE_EXTRA_ARGS=${DIB_RINSE_EXTRA_ARGS:-}
|
|
||||||
RINSE_TARBALL=$DIB_IMAGE_CACHE/rinse-${DISTRO_NAME}-${DIB_RELEASE}-${ARCH}.tar.gz
|
|
||||||
DIB_DISTRIBUTION_MIRROR=${DIB_DISTRIBUTION_MIRROR:-http://mirror.centos.org/centos/7/os/x86_64/Packages/}
|
|
||||||
http_proxy=${http_proxy:-}
|
|
||||||
|
|
||||||
if [ -n "$DIB_OFFLINE" -o -n "${DIB_CENTOS_USE_RINSE_CACHE:-}" ] && [ -f $RINSE_TARBALL ] ; then
|
|
||||||
echo $RINSE_TARBALL found in cache. Using.
|
|
||||||
sudo tar -C $TARGET_ROOT --numeric-owner -xzf $RINSE_TARBALL
|
|
||||||
else
|
|
||||||
|
|
||||||
sudo sh -c "http_proxy=$http_proxy rinse \
|
|
||||||
--mirror $DIB_DISTRIBUTION_MIRROR \
|
|
||||||
--pkgs-dir $TMP_HOOKS_PATH/packages \
|
|
||||||
--arch $ARCH \
|
|
||||||
--distribution $DISTRO_NAME-$DIB_RELEASE \
|
|
||||||
--directory $TARGET_ROOT \
|
|
||||||
$DIB_RINSE_EXTRA_ARGS"
|
|
||||||
|
|
||||||
echo "Customizing result for cloud use"
|
|
||||||
(
|
|
||||||
cd $TARGET_ROOT
|
|
||||||
# effectively: febootstrap-minimize --keep-zoneinfo --keep-rpmdb --keep-services "$target"
|
|
||||||
# locales
|
|
||||||
sudo rm -rf usr/{{lib,share}/locale,{lib,lib64}/gconv,bin/localedef,sbin/build-locale-archive}
|
|
||||||
# docs
|
|
||||||
sudo rm -rf usr/share/{man,doc,info,gnome/help}
|
|
||||||
# cracklib
|
|
||||||
sudo rm -rf usr/share/cracklib
|
|
||||||
# i18n
|
|
||||||
sudo rm -rf usr/share/i18n
|
|
||||||
# yum cache
|
|
||||||
sudo rm -rf var/cache/yum
|
|
||||||
sudo mkdir -p --mode=0755 var/cache/yum
|
|
||||||
# sln
|
|
||||||
sudo rm -rf sbin/sln
|
|
||||||
# ldconfig
|
|
||||||
sudo rm -rf etc/ld.so.cache var/cache/ldconfig
|
|
||||||
sudo mkdir -p --mode=0755 var/cache/ldconfig
|
|
||||||
|
|
||||||
# allow networking init scripts inside the container to work without extra steps
|
|
||||||
cat << EOF | sudo tee etc/sysconfig/network > /dev/null
|
|
||||||
NETWORKING=yes
|
|
||||||
NETWORKING_IPV6=yes
|
|
||||||
NOZEROCONF=yes
|
|
||||||
EOF
|
|
||||||
|
|
||||||
for interface in eth0 eth1; do
|
|
||||||
cat << EOF | sudo tee etc/sysconfig/network-scripts/ifcfg-$interface > /dev/null
|
|
||||||
DEVICE=eth0
|
|
||||||
BOOTPROTO=dhcp
|
|
||||||
ONBOOT=on
|
|
||||||
EOF
|
|
||||||
done
|
|
||||||
)
|
|
||||||
|
|
||||||
sudo rm -f $TARGET_ROOT/*rpm
|
|
||||||
sudo umount $TARGET_ROOT/proc
|
|
||||||
sudo umount $TARGET_ROOT/sys
|
|
||||||
cat << EOF | sudo tee ${TARGET_ROOT}/etc/fstab > /dev/null
|
|
||||||
proc /proc proc nodev,noexec,nosuid 0 0
|
|
||||||
LABEL=${DIB_ROOT_LABEL} / ext4 errors=remount-ro 0 1
|
|
||||||
EOF
|
|
||||||
|
|
||||||
# The filesystem package as shipped is broken. For reasons I don't fully
|
|
||||||
# understand, rinse installs files into proper dirs, but subsequent RPM
|
|
||||||
# operations expect these locations to be symlinks. If this next block
|
|
||||||
# is not executed, yum installs or updates will fail with a cryptic cpio
|
|
||||||
# failure. Moving the files in /sbin and /lib64 to /usr/sbin and /usr/lib64
|
|
||||||
# and then making symlinks makes rpm happy.
|
|
||||||
for broken in lib64 sbin ; do
|
|
||||||
sudo cp -a $TARGET_ROOT/$broken/* $TARGET_ROOT/usr/$broken
|
|
||||||
sudo rm -rf $TARGET_ROOT/$broken
|
|
||||||
sudo ln -s usr/$broken $TARGET_ROOT/$broken
|
|
||||||
done
|
|
||||||
|
|
||||||
echo Caching rinse result in $RINSE_TARBALL
|
|
||||||
sudo tar --numeric-owner -C $TARGET_ROOT -zcf $RINSE_TARBALL --exclude='./tmp/*' .
|
|
||||||
fi
|
|
||||||
|
|
||||||
sudo rm -f ${TARGET_ROOT}/.extra_settings
|
|
6
elements/centos-minimal/yum.repos.d/yum.repo
Normal file
6
elements/centos-minimal/yum.repos.d/yum.repo
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
[centos]
|
||||||
|
name=CentOS-$releasever - Base
|
||||||
|
mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os
|
||||||
|
gpgcheck=0
|
||||||
|
#baseurl=http://mirror.centos.org/centos/$releasever/os/$basearch/
|
||||||
|
#gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
|
@ -142,7 +142,7 @@ function install_grub2 {
|
|||||||
sed -i -e 's/\(^GRUB_CMDLINE_LINUX.*\)"$/\1 nofb nomodeset vga=normal"/' /etc/default/grub
|
sed -i -e 's/\(^GRUB_CMDLINE_LINUX.*\)"$/\1 nofb nomodeset vga=normal"/' /etc/default/grub
|
||||||
GRUB_MKCONFIG=update-grub
|
GRUB_MKCONFIG=update-grub
|
||||||
;;
|
;;
|
||||||
'fedora'|'centos7')
|
'fedora'|'centos7'|'centos')
|
||||||
echo 'GRUB_CMDLINE_LINUX="nofb nomodeset vga=normal"' >>/etc/default/grub
|
echo 'GRUB_CMDLINE_LINUX="nofb nomodeset vga=normal"' >>/etc/default/grub
|
||||||
;;
|
;;
|
||||||
'opensuse')
|
'opensuse')
|
||||||
|
Loading…
Reference in New Issue
Block a user