この記事では、主に Linux での PostgreSQL と PostGIS のインストールと使用方法を紹介し、注意が必要な点を分析して説明しますので、必要な方はぜひ参考にしてください。
PostgreSQL と PostGIS をインストールする
PostgreSQL と PostGIS はすでに人気のあるオープン ソース プロジェクトであり、主要な Linux ディストリビューションの yum または apt パッケージに含まれています。たとえば、Ubuntu の場合は、次のパッケージをインストールするだけです:
$ sudo apt-get install postgresql-client postgresql postgis -y
RedHat シリーズの場合、インストールしてください:
$ sudo yum install postgresql-server postgresql postgis
初期インストール後、postgres という名前のデータベースと postgres という名前のデータベース ユーザーが生成されます。デフォルト。ここで、postgres という名前の Linux システム ユーザーも生成されることに注意してください。今後PostgreSQLを運用する際には、この新しく作成したpostgresユーザーで運用する必要があります。
PostgreSQLの設定
ソースコードからインストールする場合
ソースコードからインストールすることは推奨されません。ソースコードからインストールしようとしましたが、面倒すぎて、さまざまなmake installでエラーが発生します。最後にrpmを使ってインストールしました。しかし、時間をかけて調査し、無事にインストールできたので、記録しておきます。ただし、エラーが発生する可能性があるため、ソース コードからインストールしたい場合は、ロールバックする準備をしてください。
ソースのコンパイルと make install インストールを使用している場合、このセクションでは追加の設定が必要です。
CentOSシリーズのインストールにも必要なようですが…
デフォルトのmake install後のPostgreSQLインストールディレクトリは/usr/local/pgsql/
まず、このリンクの参考によれば、環境変数を設定する必要があります
$ set $PGDATA = "/usr/local/pgsql/database"
しかし、pg_ctl startを実行すると、エラーが表示されます:
pg_ctl: directory "/usr/local/pgsql/database" is not a database cluster directory
この場合、実際のデータベースを作成するには、公式PostGreSQLドキュメントの手順に従う必要があります。 :
PostgreSQL: ドキュメント: 9.1: データベースクラスターの作成
まず、postgres という名前のユーザーアカウントを作成します
$ usradd postgres $ sudo chown postgres /usr/local/pgsql/database
次に、このアカウントを入力してデータベースを作成します
$ sudo su postgres $ initdb -D /usr/local/pgsql/database/
今回、シェルは次のように出力します:
The files belonging to this database system will be owned by user "postgres". This user must also own the server process. The database cluster will be initialized with locale "C". The default database encoding has accordingly been set to "SQL_ASCII". The default text search configuration will be set to "english". Data page checksums are disabled. fixing permissions on existing directory /usr/local/pgsql/database ... ok creating subdirectories ... ok selecting default max_connections ... 100 selecting default shared_buffers ... 128MB selecting dynamic shared memory implementation ... posix creating configuration files ... ok creating template1 database in /usr/local/pgsql/database/base/1 ... ok initializing pg_authid ... ok initializing dependencies ... ok creating system views ... ok loading system objects' descriptions ... ok creating collations ... ok creating conversions ... ok creating dictionaries ... ok setting privileges on built-in objects ... ok creating information schema ... ok loading PL/pgSQL server-side language ... ok vacuuming database template1 ... ok copying template1 to template0 ... ok copying template1 to postgres ... ok syncing data to disk ... ok WARNING: enabling "trust" authentication for local connections You can change this by editing pg_hba.conf or using the option -A, or --auth-local and --auth-host, the next time you run initdb. Success. You can now start the database server using: pg_ctl -D /usr/local/pgsql/database/ -l logfile start
おめでとうございます、次へ PostgreSQL を起動できます:
pg_ctl -D /usr/local/pgsql/database/ -l /usr/local/pgsql/database/psql.log start
PostgreSQL がインストールされたら、postgres アカウントを入力して PostgreSQL コンソールに入ります:
$ sudo su postgres $ psql
Thisこれは、システム ユーザー postgres が同じ名前のデータベース ユーザーとしてデータベースにログインするのと同等です。そうでない場合は、psql を実行するたびにパラメーターでユーザーを指定する必要があり、これは忘れがちです。
psql でパスワードを設定します - ここで設定するパスワードは postgres システム アカウントのパスワードではなく、データベース内のユーザー パスワードであることに注意してください:
postgres=# \password postgres
次に、プロンプトに従ってパスワードを入力します。
ソース コードから PostGIS をインストールします
ソース コードから PostgreSQL をインストールすることを選択した場合は、まずインストールした PostgreSQL のバージョンを確認する必要があります
次に、PostGIS Web ページにアクセスして PostGIS のバージョンを確認しますに相当します。
最後に、PostGISのバージョンに応じて対応するソースをダウンロードします
最後のインポートが非常に面倒なので、作者はこの段階で行き詰ってしまい、最終的にソースコードからのインストールを断念しました…
PostGIS拡張機能をインポートします
postgresql と postgis によると、バージョンに応じて、パスは若干異なります。これは主にパスにバージョン情報が含まれているためです:
$ sudo su postgres $ createdb template_postgis $ createlang plpgsql template_postgis $ psql -d template_postgis -f /usr/share/postgresql/9.5/contrib/postgis-2.2/postgis.sql $ psql -d template_postgis -f /usr/share/postgresql/9.5/contrib/postgis-2.2/spatial_ref_sys.sql
上記の操作では、「template_postgis」という空のデータベースが作成されました。このデータベースは空で、postgres ユーザーに属します。このデータベースが「テンプレート」と呼ばれる理由は、このデータベースが導出に使用されることを意味します。
対応する PostGIS パスが異なる可能性があります。失敗した場合は、上記のパスの近くで試して、いくつかの .sql ファイルを見つけて試してください。
.shp ファイルを PostGIS データベースに変換します
.shp を .sql ファイルに変換します
まず、変換する必要がある .shp ファイルが /tmp/demo であると仮定します。 shp を使用し、次の操作を実行します:
$ sudo su postgres $ cd /tmp $ shp2pgsql -W GBK -s 3857 ./demo.shp entry > demo.sql
ここで、最後の文の各部分の意味を説明する必要があります:
- -W GBK: .shp ファイルに中国語の文字が含まれている場合は、これを追加してくださいオプション
- -s 3857: ファイルの参照座標系を指定します。私の .shp ファイルは EPSG:3857 を使用します
- ./demo.shp: .shp ファイルのパス
- エントリ: インポートされるデータベース テーブルの名前を表します - この .shp ファイルがそれぞれを表すと仮定しますエントリーなので「エントリー」と名付けました
- demo.sql
- .sql ファイルを取得したら、それを PostgreSQL データベースに直接インポートできます。
PostGIS データベースを作成します
ここでは前のテンプレートを使用する必要があります。
sudo su postgres psql CREATE DATABASE newdb WITH TEMPLATE originaldb OWNER dbuser;
- newdb: 新しいデータベース名
- originaldb: 以前の template_postgis です
dbuser:你的账户名,我一般使用 postgres
导入 .sql 文件
sudo su postgres psql \c newdb \i demo.sql \d
可以看到,.sql 文件已经被导入了。
设置数据库权限
OK,现在我们在本机(服务器 IP 假设是 192.168.1.111)用以下命令登录 psql,会发现一段输出:
$ psql -h 192.168.1.111 -p 5432 psql: could not connect to server: Connection refused Is the server running on host "100.94.110.105" and accepting TCP/IP connections on port 5432?
这是因为 PostgreSQL 默认不对外开放权限,只对监听环回地址。要修改的话,需要找到 postgresql.conf 文件,修改值 listen_addresses:
listen_addresses = '*'
相关推荐:
以上がLinux に PostgreSQL と PostGIS をインストールして使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Linuxシステムの5つの柱は次のとおりです。1。Kernel、2。SystemLibrary、3。Shell、4。FileSystem、5。SystemTools。カーネルはハードウェアリソースを管理し、基本的なサービスを提供します。システムライブラリは、アプリケーション用の事前コンパイルされた機能を提供します。シェルは、ユーザーがシステムと対話するインターフェイスです。ファイルシステムはデータを整理して保存します。また、システムツールはシステム管理とメンテナンスに使用されます。

Linux Systemsでは、起動時に特定のキーを押すか、「sudosystemctlrescue」などのコマンドを使用することにより、メンテナンスモードを入力できます。メンテナンスモードを使用すると、管理者は、ファイルシステムの修復、パスワードのリセット、セキュリティの脆弱性など、干渉なしにシステムメンテナンスとトラブルシューティングを実行できます。

Linuxの初心者は、ファイル管理、ユーザー管理、ネットワーク構成などの基本操作をマスターする必要があります。 1)文件管理:使用mkdir、タッチ、ls rm 3)ネットワーク構成:ifconfig、echo、およびufwコマンドを使用します。これらの操作はLinuxシステム管理の基礎であり、それらをマスターすることでシステムを効果的に管理できます。

この記事では、LinuxのSudo特権を管理する方法について説明します。重要な焦点は、 /etc /sudoersの安全性とアクセスを制限することです。

この記事では、Google Authenticatorを使用してLinux上のSSH用の2要素認証(2FA)のセットアップ、インストール、構成、およびトラブルシューティング手順の詳細に関するガイドを提供します。 Enhanced Secなど、2FAのセキュリティ利益を強調しています

この記事では、Linuxシステムのパフォーマンスを監視するためにTop、HTOP、およびVMSTATを使用して、効果的なシステム管理のための独自の機能とカスタマイズオプションを詳述することについて説明します。

記事では、APT、Yum、およびDNFを使用してLinuxでソフトウェアパッケージの管理を行い、インストール、更新、および削除をカバーしています。さまざまな分布に対する機能と適合性を比較します。

この記事では、パターンマッチング、ファイル検索、テキスト操作、グレップ、SED、awkなどのツールの詳細、ファイル検索、テキスト操作のためにLinuxで正規表現(Regex)を使用する方法について説明します。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。
