Solaris ネーミングの設定と構成

NIS+ クライアントを構成する

ここでは、ルートドメイン内であるかどうかとは関係なく、一般的な NIS+ クライアントの構成方法を説明します。ここでの説明は、通常の NIS+ クライアント、および後で NIS+ サーバーとなるクライアントに当てはまります。また、標準の NIS+ ドメイン内、および NIS 互換ドメイン内のクライアントにも当てはまります。


注意 - 注意 -

ドメインとホストで同じ名前を使用しないでください。たとえば、sales というドメインを使用している場合、sales という名前の付いたマシンは使用しないでください。同様に、home という名前のマシンを使用する場合は、home という名前のドメインを作成しないでください。これは、サブドメインの場合にもあてはまります。たとえば、マシンに west という名前を付けている場合、sales.west.myco.com というサブドメインを作成しないでください。


NIS+ クライアントの設定には、次の作業が必要です。

ただし、ルートドメインの設定と同様、クライアントの設定も、これら 3 つの作業を順番に実行するような単純なものではありません。構成手続を実行しやすくするため、これらの作業を個々の手順に分割し、次に示すように、これらの手順を最も効率的な順に並べてあります。

  1. ドメインのマスターサーバーにログインします。

  2. 新しいクライアントワークステーション用の DES 資格を作成します。

  3. クライアントにスーパーユーザーとしてログインします。

  4. クライアントに新しいドメイン名を設定します。

  5. クライアントの nsswitch.conf ファイルの設定を確認します。

  6. NIS+ のファイルを削除し、プロセスを終了します。

  7. クライアントを初期設定します。

  8. keyserv デーモンのプロセスを終了して再起動します。

  9. keylogin を実行します。

  10. クライアントを再起動します。

セキュリティ上の留意点

クライアントの設定には、セキュリティ上の主な必要要件が 2 つあります。つまり、システム管理者とクライアントの両方が、適切な資格とアクセス権を持つことです。そうでない場合、クライアントがセキュリティレベル 2 で実行しているドメインの資格を入手する唯一の方法は、クライアントのホームドメイン内での有効な DES 資格と cred テーブルに対する変更権とを持つシステム管理者が資格を作成することです。システム管理者は DES 資格を、クライアントのホームドメイン内、または自分のホームドメイン内に所持できます。

システム管理者がクライアントの資格を作成すると、そのクライアントは構成プロセスを終了できます。しかしクライアントは、ホームドメインのディレクトリオブジェクトに対する読み取りアクセス権を必要とします。第 5 章「ルートドメインの設定」または第 8 章「非ルートドメインの構成」の手順に従ってクライアントのホームドメインを構成した場合、ディレクトリオブジェクトの作成に使用した NIS+ コマンド (nisinitnismkdir) によって、読み取りアクセス権がその他のクラスに提供されています。

ディレクトリオブジェクトのアクセス権をチェックするには、niscat-o コマンドを使用します。このコマンドは、アクセス権などのディレクトリ属性を表示します。次にその例を示します。

rootmaster# niscat -o doc.com. 
ObjectName : Doc 
Owner : rootmaster.doc.com. 
Group : admin.doc.com. 
Domain : Com. 
Access Rights : r---rmcdr---r---

ディレクトリオブジェクトのアクセス権は、これに対する変更権があれば、nischmod コマンドを使用して変更できます。詳しくは、Solaris ネーミングの管理の権利に関連する章を参照してください。

前提条件

クライアントの資格を設定するシステム管理者は、次の条件をすべて満たしている必要があります。

クライアントは次の条件をすべて満たしている必要があります。

必要な情報

NIS+ クライアントを設定する方法

  1. ドメインのマスターサーバーにログインします。

    スーパーユーザーとして、または自分自身のユーザー名でログインします。どちらでログインするかは、どちらの NIS+ 主体がドメインの cred テーブルに資格を追加するための適切なアクセス権を所有しているのかに依存します。

  2. 新しいクライアントワークステーション用の DES 資格を作成します。

    -p-P の引数を付けた nisaddcred コマンドを実行します。

    nisaddcred -p secure-RPC-netname  principal-name des [domain]

    secure-RPC-netname は、接頭辞 unix に、クライアントのホスト名、@ 記号、およびクライアントのドメイン名を付けて構成しますが、最後にドットは付けません。 principal-nameは、クライアントのホスト名とドメイン名によって構成され、最後にドットを付けます。このクライアントの所属するドメインが、コマンドを入力したサーバーとは異なる場合、2 番目の引数の後にクライアントのドメイン名を追加します。

    この例では、doc.com. ドメイン内の client1 という名前のクライアントワークステーションに対する DES 資格を追加します。

    rootmaster% nisaddcred -p unix.client1@doc.com -P client1.doc.com. des  
    Adding key pair for unix.client1@doc.com (client1.doc.com.). 
    Enter client1.doc.com.'s root login passwd: 
    Retype password:

    nisaddcred コマンドについて、詳細は、Solaris ネーミングの管理の資格に関する章を参照してください。

  3. クライアントにスーパーユーザーとしてログインします。

    これでクライアントワークステーションに資格ができたため、ユーザーはマスターサーバーからログアウトし、クライアント自体から仕事を開始できます。この作業はローカルでもリモートでも可能です。

  4. クライアントに新しいドメイン名を設定します。

    クライアントのドメイン名を設定する (変更する) 方法については、「ワークステーションのドメインを変更する」を参照し、次の手順 5 に戻ります。

  5. クライアントのスイッチ構成ファイルをチェックします。

    クライアントが NIS+ バージョンの nsswitch.conf ファイルを使用していることを確認します。これによって、クライアント情報の 1 次ソースが NIS+ テーブルということが確認できます。NIS+ スイッチファイルの詳細は、「NIS+ 用デフォルトスイッチファイル」をご覧ください。

  6. nsswitch.conf ファイルに何らかの変更を加えた場合 (または、新規にファイルにコピーした場合) 、必ず次の表のように入力して nscd を停止してから再起動する必要があります。

    client1# cp /etc/nsswitch.nisplus /etc/nsswitch.conf 
    client1# sh /etc/init.d/nscd stop 
    client1# sh /etc/init.d/nscd start
    

    (第 1 章「ネームサービススイッチの設定」では、この時点でキーサーバーを停止して、再起動するよう説明していますが、同じ操作を手順 9 で行うため、この場合は停止および再起動の必要はありません。)

  7. NIS+ のファイルを削除し、プロセスを終了します。

    作業しているワークステーションが、すでに NIS+ のサーバーまたはクライアントとして使用されていて、まだ実行中の場合、/var/nis ディレクトリに存在するファイルすべてを削除し、キャッシュマネージャを停止します。

    client1# ls /var/nis 
    NIS_COLD_START NIS_SHARED_CACHE 
    client1# rm -rf /var/nis/* 
    client1# ps -ef | grep nis_cachemgr  
    root 295 260 10 15:26:58 pts/0 0:00 grep nis_cachemgr  
    root 286 1 57 15:21:55 ? 0:01 /usr/sbin/nis_cachemgr 
    client1# kill -9 286
    

    /var/nis 内に残されたファイル、またはキャッシュマネージャによって保存されたディレクトリオブジェクトは、この手順によって完全に消去されます。したがって、この構成プロセスで生成された新しい情報と重複することはありません。/var/nis 内に管理スクリプトが格納されている場合、ルートドメインの設定が終了するまでは、これらを一時的に他の場所に格納しておくこともできます。

  8. クライアントを初期設定します。

    クライアントの初期設定は、ホスト名、コールドスタートファイル、またはブロードキャストのいずれかを使用して行うことができます。3 つの方法のうち、いずれかを選択して実行します。クライアントの初期設定が終了したら、手順 9 に進みます。

  9. keyserv デーモンを終了してから再起動します。

    この手順では、非公開鍵をキーサーバー上に格納します。

    1. keyserv デーモンを終了します。

      この手順によって、キーサーバーが保持していたクライアントに関するスイッチ情報も更新されます。

    2. /etc/.rootkey ファイルを削除します。

    3. キーサーバーを再起動します。

      次の例では、手順 9 の内容を示しています。

      client1# ps -e | grep keyserv  
      root 145 1 67 16:34:44 ? keyserv 
      client1# kill 145 
      client1# rm -f /etc/.rootkey 
      client1# keyserv
      
    4. keylogin -r を実行します。

      この手順では、クライアントの非公開鍵をキーサーバーに格納します。また、クライアント上のスーパーユーザーが NIS+ を使用するために keylogin を行わなくてもすむように、/etc/.rootkey にコピーを保存します。-r オプションを付けて keylogin を実行します。パスワードの入力を求められたら、クライアントのスーパーユーザーパスワードを入力します。このパスワードは、クライアントの DES 資格を作成するために与えられたパスワードと同じでなければなりません。

      client1# keylogin -r  
      Password: 
      Wrote secret key into /etc/.rootkey
    5. クライアントを再起動します。