Standard または Advancedのライセンスで利用可能。
このチュートリアルでは、Microsoft Windows サーバー上にある PostgreSQL でエンタープライズ ジオデータベースの使用を開始する例を示します。 このチュートリアルでは、ArcGIS Server と ArcGIS Pro がすでにインストールされており、データベース管理者ログインとジオデータベース管理者ログインの両方の接続情報が存在することを前提としています。
PostgreSQL のインストールと構成
このチュートリアルでは、My Esri で提供されている PostgreSQL のインストールを実行するか、サポートされている PostgreSQL のバージョンを別のソースから取得することができます。 PostgreSQL をインストールしたら、pg_hba.conf ファイルを変更して、リモート接続を受け入れるようにデータベース クラスターを設定します。
PostgreSQL をダウンロードしてインストールします。
- My Esri から PostgreSQL インストールをダウンロードします。
- PostgreSQL をインストールする Windows サーバー上で、セットアップ用の実行可能ファイルを実行します。
英語以外の言語の環境でロケールと照合順序を設定する以外は、インストール ウィザードが提供するデフォルト値を使用できます。
インストール中に、postgres スーパーユーザーのパスワードを指定します。 このパスワードは、データベース クラスターのデータベース管理者パスワードです。このチュートリアルの後で必要になるため、忘れないでください。
PostgreSQL を最初にインストールすると、ローカル サーバーからのみ接続できます。 ネットワーク上の他のコンピューターからアクセスするには、pg_hba.conf ファイルを変更する必要があります。
- PostgreSQL データ ディレクトリにある pg_hba.conf ファイルをテキスト エディターで開きます。
デフォルトの場所は、C:\Program Files\PostgreSQL\<PostgreSQL version>\data です。
- データベースにアクセスするクライアントのアドレスを指定します。
次の例では、orgnetwor.com から接続するすべてのコンピューターが、データベース クラスター上のすべてのデータベースにアクセスできます。
#TYPE DATABASE USER ADDRESS METHOD host all all .orgnetwork.com md5
データベース クラスターのセキュリティを高めるには、アクセスを特定の IP アドレスやアドレスの範囲に制限し、アクセス権を付与するデータベースまたはデータベースのリストを指定するか、接続できるユーザーを指定します。 また、IP アドレスや IP アドレスの範囲へのアクセスを明示的に禁止することもできます。 詳細と例については、PostgreSQL のドキュメントをご参照ください。
- PostgreSQL サービスを再起動します。
再起動するには、[Windows サービス] リストから postgresql-x64 サービスを右クリックして、[再起動] をクリックします。
ST_Geometry ライブラリの PostgreSQL lib ディレクトリへの配置
ジオデータベースで ST_Geometry 空間タイプを使用するか、PostGIS 空間タイプを使用することができます。 このワークフローでは、ST_Geometry を構成します。
ST_Geometry ライブラリ ファイルは、ArcGIS Server インストールの DatabaseSupport フォルダーから取得するか、My Esri からダウンロードできます。
このチュートリアルでは、PostgreSQL は Windows サーバー上にインストールされるため、Windows64 フォルダーにある ST_Geometry ライブラリを使用します。
- Windows エクスプローラーで、ArcGIS クライアントのインストール ディレクトリ内にある Windows の ST_Geometry ライブラリの場所に移動するか、My Esri からファイルをダウンロードします。
- この場所から st_geometry.dll をコピーします。
- データベース サーバー上の PostgreSQL の lib ディレクトリに移動し、ライブラリを貼り付けます。
Windows では、デフォルトの場所は C:\Program Files\PostgreSQL\<PostgreSQL version>\lib です。
ジオデータベースの作成
[エンタープライズ ジオデータベースの作成 (Create Enterprise Geodatabase)] ジオプロセシング ツールを使用して、PostgreSQL にデータベース、sde ユーザー、sde スキーマ、ジオデータベースを作成することができます。
- ArcGIS Desktop クライアントまたは ArcGIS Pro を起動し、[エンタープライズ ジオデータベースの作成 (Create Enterprise Geodatabase)] ツールを開きます。
- PostgreSQL データベース クラスターに postgres スーパーユーザーとして接続するために必要な情報を入力して、データベースと sde ユーザーを作成します。 また、ArcGIS Server サイトを認証した際に生成されたキーコード ファイルも指定する必要があります。
- [実行] をクリックします。
PostgreSQL にデータベース、sde ユーザー、sde スキーマ、ジオデータベースが作成されます。
データを所有するユーザーの作成
ジオデータベースに格納されるデータは、sde ユーザー以外のユーザーが所有する必要があります。 [データベース ユーザーの作成 (Create Database User)] ジオプロセシング ツールを使用して、PostgreSQL データベース クラスター内にユーザー、新しいデータベース内にスキーマを作成します。
ただし、ユーザーを作成するには、まずデータベース管理者としてジオデータベースに接続する必要があります。 この場合には、[エンタープライズ ジオデータベースの作成 (Create Enterprise Geodatabase)] ツールで sde ユーザーにはスーパーユーザー ステータスが付与されているため、postgres スーパーユーザーまたは sde ユーザーとして接続できます。
データベース接続を作成し、postgres または sde ユーザーとしてログインします。
- [カタログ] ビューで [データベース] フォルダーを右クリックして [新規データベース接続] をクリックし、データベースに接続します。
[データベース接続] ダイアログ ボックスが表示されます。
- 新しいデータベースに PostgreSQL スーパーユーザーとして接続するために必要な情報を入力します。
この接続ファイルはジオプロセシング ツールで使用するため、[ユーザー名とパスワードを保存する] をオンにする必要があります。 ただし、ツールの実行後は、接続ファイル内でこのオプションをオフにして、別のユーザーとして接続するか、この接続ファイルを削除し、他のユーザーがこのファイルにアクセスして、ジオデータベースにデータベース管理者としてログインできないようにする必要があります。
- [OK] をクリックして、接続を作成します。
新しい接続ファイルは、[データベース接続] の下に表示されます。
これで、[データベース ユーザーの作成 (Create Database User)] ツールを実行できます。
- [データベース ユーザーの作成 (Create Database User)] を開きます。
- 新しい接続ファイルを [データベース ユーザーの作成 (Create Database User)] ツールの [入力データベース ワークスペース] テキスト ボックスにドラッグします。
- [データベース ユーザー] テキスト ボックスに新しいユーザーの名前、[データベース ユーザー パスワード] テキスト ボックスに新しいユーザーのパスワードを入力します。
- [実行] をクリックします。
PostgreSQL に新しいユーザー名とスキーマが作成され、パブリック ロールにスキーマの USAGE 権限が自動的に付与されます。
新しく作成したユーザーとして接続
これで新しいジオデータベースにデータを追加できるユーザーができたので、そのユーザーでデータベースに接続します。 最も簡単な方法は、前に作成した接続ファイルを変更することです。
既存のデータベース接続を開き、ユーザー名とパスワードを変更します。
- データベース接続を右クリックし、[接続プロパティ] をクリックします。
- [ユーザー名] と [パスワード] の値を新しいユーザーのものに変更します。
- [OK] をクリックして、新しいユーザーとして接続します。
これで、この接続を使用してデータをジオデータベースに追加できるようになりました。