web-dev-qa-db-ja.com

Linuxカーネルがpostgresqlプロセスを強制終了しないようにする

標準の「すぐに使える」インストールがあります

Linux version 3.0.1.stk64 ([email protected]) (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
5
Martin

Oom_adjをpostmasterpidに直接調整し、次のような行を追加する必要があります(テストされていません):

pid=`cat $PGDATA/postmaster.pid | head -1`
echo -17 > /proc/$pid/oom_adj
3