RPM % наилучшая практика
Я пытаюсь отследить, что является лучшим для сценариев% pre /% post в файле rpm.spec.
В частности, у меня есть система, которая имеет довольно сложную установку. Помимо прочего, для этого необходимо выполнить множество настроек "Security-Enhanced Linux", редактирование iptable, создание пользователей (с паролями) и "chown" и т. Д.
Вопрос в том, где это сделать? Должно ли это быть вставлено в скрипты pre / post? Лучшей практикой, как представляется, является сохранение их как можно более простым и определенно не делать его интерактивным.
Я заметил, что установщик Postgres (и некоторые другие) выполняет шаг "ручной постустановки", когда пользователю root нужно запустить скрипт для выполнения определенных действий, таких как установка пароля пользователя postgres и т. Д. Вы можете увидеть его ниже, где печатает rpm этот: To initialize, run /etc/init.d/postgres-9.1-openscg start as root user.
Вот извлеченные скриптлеты:
rpm -qp --scripts postgres-9.1.2-1.i386.openscg.rpm
Предварительно установите скриптлет (используя /bin/sh):
if [ "$1" = "2" ]; then
#Perform maintenance tasks before server upgrade begins.
#Determine if server is running, stops it.
/etc/init.d/postgres-9.1-openscg status &> /dev/null
if [ "$?" = "0" ];
then
/etc/init.d/postgres-9.1-openscg stop
touch /tmp/pg_9.1.stopped
fi
fi
скрипт сценария postinstall (используется /bin/sh):
if type "/usr/bin/chcon" &> /dev/null ; then
/usr/bin/chcon -t textrel_shlib_t $RPM_INSTALL_PREFIX/lib/libedit.so &> /dev/null
fi
#Create a soft link to init script
if [ ! -f /etc/init.d/postgres-9.1-openscg ]
then
ln -s $RPM_INSTALL_PREFIX/bin/postgres-9.1-openscg /etc/init.d/postgres-9.1-openscg
fi
#In case of upgrade, dump environment values file
#if [ "$1" = "2" ];
#then
#Fix for psql dumb terminal issue
LD_PRELOAD_VALUE=""
for libreadline in `find -L /lib -type f -name libreadline.\* 2> /dev/null`
do
LD_PRELOAD_VALUE="$libreadline:$LD_PRELOAD_VALUE"
done
if [ x"$LD_PRELOAD_VALUE" != x"" ];
then
LD_PRELOAD_VALUE="export LD_PRELOAD=$LD_PRELOAD_VALUE"
fi
#Dump environment values
cat <<ENVEOF > $RPM_INSTALL_PREFIX/pg91-openscg.env
#!/bin/bash
$LD_PRELOAD_VALUE
export PGHOME=$RPM_INSTALL_PREFIX
export PGDATA=$RPM_INSTALL_PREFIX/data
export PATH=$RPM_INSTALL_PREFIX/bin:\$PATH
export LD_LIBRARY_PATH=$RPM_INSTALL_PREFIX/lib:\$LD_LIBRARY_PATH
export PGUSER=postgres
export PGDATABASE=postgres
ENVEOF
#Determine port from postgresql.conf
PGPORT_VALUE=""
if [ -f $RPM_INSTALL_PREFIX/data/postgresql.conf ]; then
PGPORT_VALUE=`grep "port =" $RPM_INSTALL_PREFIX/data/postgresql.conf | sed -e "s/^.*port[[:space:]]=[[:space:]]\([0-9]\+\).*$/\1/"`
PGPORT_VALUE="export PGPORT=$PGPORT_VALUE"
cat <<ENVEOF >> $RPM_INSTALL_PREFIX/pg91-openscg.env
$PGPORT_VALUE
ENVEOF
fi
#fi
# If it is an upgrade, and we stopped a running server, start it.
if [ "$1" = "2" -a -f /tmp/pg_9.1.stopped ];
then
rm /tmp/pg_9.1.stopped
/etc/init.d/postgres-9.1-openscg start
fi
if [ "$1" = "1" ];
then
echo "PostgreSQL 9.1 is now installed in $RPM_INSTALL_PREFIX."
echo
echo "To initialize, run /etc/init.d/postgres-9.1-openscg start"
echo "as root user."
fi
if [ "$1" = "2" ];
then
echo "PostgreSQL 9.1 is upgraded in $RPM_INSTALL_PREFIX."
fi
preuninstall скриптлет (используя /bin/sh):
if [ "$1" = "0" ]; then
#Action is uninstallation, not called due to upgrade of a new package
#Determine if server is running, stops it.
/etc/init.d/postgres-9.1-openscg status &> /dev/null
if [ "$?" = "0" ];
then
echo "Attempting to stop server..."
/etc/init.d/postgres-9.1-openscg stop
fi
echo "Attempting to update server startup status..."
if type "/sbin/chkconfig" &> /dev/null ; then
/sbin/chkconfig --del postgres-9.1-openscg
fi
fi
скрипт сценария postuninstall (используется /bin/sh):
if [ "$1" = "0" ]; then
#Action is uninstallation, not called due to upgrade of a new package
rm /etc/init.d/postgres-9.1-openscg
echo "Uninstallation complete."
fi
1 ответ
Если вы имеете в виду наилучшую практику, связанную с взаимодействием с пользователем при установке RPM, никаких вопросов не возникает. НЕ делай этого. Делайте то, что не требует взаимодействия с пользователем в скриптлетах, и либо попросите пользователя запустить скрипт после установки, либо получите всю информацию при первом запуске приложения.