У меня стандартная установка "из коробки"
Linux version 3.0.1.stk64 (dfn@localhost.localdomain) (gcc version 4.5.1 20100924 (Red Hat 4.5.1-4) (GCC) ) #1 SMP Sat Aug 13 12:53:46 EDT 2011
Postgresql 8.4 установлен как (запускающий скрипт)
/etc/init.d/postgresql
Каталог данных
/etc/postgresql/8.4/main/
Моя проблема в том, что иногда ядро решает убить некоторые процессы Postgresql во время нехватки памяти. Я хотел бы сообщить ядру, что Postgresql не следует выбирать для уничтожения. Я читал из документации postgresql (http://www.postgresql.org/docs/9.1/static/kernel-resources.html) что командная строка echo -17 > /proc/self/oom_adj
можно использовать, чтобы избежать убийства.
Я попытался добавить эту командную строку в /etc/init.d/postgresql
сценарий, но действительно не знаю, где его там разместить.
Есть указания, как это сделать? Scipt (/etc/init.d/postgresql
) кстати это:
#!/bin/sh
set -e
### BEGIN INIT INFO
# Provides: postgresql
# Required-Start: $local_fs $remote_fs $network $time
# Required-Stop: $local_fs $remote_fs $network $time
# Should-Start: $syslog
# Should-Stop: $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: PostgreSQL RDBMS server
### END INIT INFO
# Setting environment variables for the postmaster here does not work; please
# set them in /etc/postgresql/<version>/<cluster>/environment instead.
[ -r /usr/share/postgresql-common/init.d-functions ] || exit 0
. /usr/share/postgresql-common/init.d-functions
# versions can be specified explicitly
if [ -n "$2" ]; then
versions="$2 $3 $4 $5 $6 $7 $8 $9"
else
get_versions
fi
case "$1" in
start|stop|restart|reload|status)
for v in $versions; do
$1 $v
done
;;
force-reload)
for v in $versions; do
reload $v
done
;;
*)
echo "Usage: $0 {start|stop|restart|reload|force-reload|status} [version ..]"
exit 1
;;
esac
exit 0
Вы должны настроить oom_adj непосредственно на pid postmaster, добавить такие строки (НЕ ПРОВЕРЕНО):
pid=`cat $PGDATA/postmaster.pid | head -1`
echo -17 > /proc/$pid/oom_adj