/bin/sh: 無効なソルバー: Postgres のインストール中に権限が拒否されました。

/bin/sh: 無効なソルバー: Postgres のインストール中に権限が拒否されました。

このフォーラムでError InterpreterとPermission Deniedに関連する同様の投稿を見ましたが、この問題に対する解決策が見つかりませんでした。

私はvps Linux x64(v2.6.18、CentOS 6.7)を使用しています。私はクライアント(OpenClinica)用の特定のプロジェクトを進めており、.binファイルからPostgresqlバージョン8.4(私が知っている以前のバージョン)を直接インストールする必要があります。postgresql-8.4.1-1-linux-x64.bin私が理解したところによると、ファイル.bin.sh/tmp/postgresql_installer/

また、このファイルが正常に動作し、OpenClinicaを実行している他の多くのLinux(CentOS)システムにPostgresを正常にインストールしたと言われました。

コマンドラインからrootとして実行するときは、次のように入力します。

./postgresql* --mode text

私は次のような落ち込んだメッセージを受け取りました。

Error: 
Error running /tmp/postgresql_installer/getlocales.sh  : 
/bin/sh: /tmp/postgresql_installer/getlocales.sh: 
/bin/sh: bad interpreter: Permission denied

確認した内容(このフォーラムとは別のフォーラムで確認しました)

  1. 最初の行getlocales.sh#!/bin/sh

  2. sh -> bash*にリンクがあります/bin

    root@vps [/bin]# ls -l sh
    lrwxrwxrwx 1 root root 4 Nov 14 12:29 sh -> bash*
    
  3. sestatus障害のある

  4. 実行する前に権限を付与しましたchmod xpostgres*.bin

  5. 脱出も試みたが役に立たpostgres*.binなかっ~/た。

どんなアイデアがありますか?

答え1

前述のように、問題はnoexecを使用して/ tmpをマウントすることです。説明は簡単です。一部のインストールスクリプトは、/ tmpに実行可能ファイル/スクリプトを解凍して実行しようとします。

私は実際に数ヶ月前にセキュリティ上の理由から、いくつかのサーバーの/ tmpをnoexecに変更した後、いくつかのDebianパッケージのインストール/アップデートスクリプトが機能しなくなったときにこの問題を偶然発見しました。わざわざ変更を行ったので、当時の問題点を簡単に発見できました。

パブリックネットワークサーバーで/ tmpをnoexecに設定することはまだ良い考えだと思いますが、これまではこの特定の問題を解決する方法を見ていませんでした。

答え2

に基づいてルイの答え、私は以下のコマンドを実行しました。

mount -o remount,exec /tmp

関連情報