ホームページ システムチュートリアル Linux DBA が PostgreSQL の新たな問題を発見

DBA が PostgreSQL の新たな問題を発見

Jan 13, 2024 am 09:06 AM
linux Linuxチュートリアル レッドハット Linuxシステム Linuxコマンド Linux 認定 レッドハットリナックス Linuxビデオ

DBA が PostgreSQL の新たな問題を発見

いつものように、新しいクラスターをアップグレードまたは初期化するユーザーは、パフォーマンスが向上します (例: 並列インデックス スキャンの向上、マージ ジョインと関連のないサブクエリ、より高速な集計、リモート サーバーのジョインと集計に関するインテリジェンスの向上)。これらはすべて、しかし、この記事では、そのままでは機能せず、実際にその恩恵を受けるにはいくつかの手順を踏む必要があるものについて話したいと思います。以下で強調表示されている機能は DBA の観点からまとめられており、開発者の観点からの変更点をカバーする記事が間もなく公開される予定です。

アップグレードに関する注意事項

最初に、既存のセットアップからアップグレードするためのヒントをいくつか示します。9.6 以前から移行するときに問題を引き起こす可能性のある小さなことがいくつかあります。そのため、実際のアップグレードを行う前に、必ず別のコピーでアップグレードをテストしてください。考えられるすべての問題についてはリリース ノートを参照してください。最も顕著な欠陥は次のとおりです:

「xlog」を含むすべての関数は、「xlog」の代わりに「wal」を使用するように名前が変更されました。

後者の名前は通常のサーバー ログと混同される可能性があるため、これは「念のため」の変更です。サードパーティのバックアップ/レプリケーション/HA ツールを使用している場合は、それらが最新であることを確認してください。

サーバーログ (エラーメッセージ/警告など) を保持する pg_log フォルダーの名前が「log」に変更されました。

ログ解析または grep スクリプト (存在する場合) が機能することを必ず確認してください。

デフォルトでは、クエリは最大 2 つのバックグラウンド プロセスを使用します。

CPU の数が少ないマシンで postgresql.conf 設定のデフォルト値 10 を使用すると、並列処理がデフォルトで有効になっているため、リソース使用量が急増する可能性があります。これは良いことです。クエリの高速化。以前の動作が必要な場合は、max_Parallel_workers_per_gather を 0 に設定します。

デフォルトでは、ローカルホストのレプリケーション接続が有効になっています。

テストなどの作業を簡略化するために、localhost およびローカル Unix ソケット レプリケーション接続が pg_hba.conf の「trust」モード (パスワードなし) で有効になりました。したがって、他の非 DBA ユーザーが実稼働マシンにアクセスできる場合は、必ず構成を変更してください。

DBA の観点から見た私のお気に入り

論理レプリケーション

待望のこの機能では、単一のテーブル、テーブルの一部、またはすべてのテーブルのみをコピーする場合、パフォーマンスの低下を最小限に抑えた簡単なセットアップが必要です。これは、後続のメジャー バージョンをダウンタイムなしでアップグレードできることも意味します。これまでは (Postgres 9.4 が必要)、これはサードパーティの拡張機能または低速トリガーベースのソリューションを使用することで可能でした。私にとって、これがベスト 10 の機能です。

パーティションの宣言

パーティションを管理する以前の方法では、挿入を正しいテーブルに再ルーティングするためのトリガーの継承と作成が必要でしたが、パフォーマンスへの影響は言うまでもなく面倒でした。現在サポートされているのは、「範囲」および「リスト」パーティショニング スキームです。一部のデータベース エンジンで「ハッシュ」パーティショニングが不足している場合は、式で「リスト」パーティショニングを使用して同じ機能を実現できます。

利用可能なハッシュインデックス

ハッシュ インデックスは WAL に記録されるため、クラッシュ セーフになり、パフォーマンスが向上し、単純な検索では大規模なデータに対する標準の B ツリー インデックスよりも高速になります。より大きなインデックス サイズもサポートされています。

列間のオプティマイザー統計

このような統計は、値が実際に何らかの形で相互に依存していることを示すために、一連のテーブル列に対して手動で作成する必要があります。これは、返されるデータが非常に少ないとプランナが判断する低速クエリ (確率の積から得られる数値が非常に小さい場合が多い) に対処し、結果的に大量のデータでパフォーマンスが低下します (たとえば、「ネストされたループ」結合を選択するなど)。

レプリカ上の並列スナップショット

pg_dump で複数のプロセス (-jobs フラグ) を使用して、スタンバイ サーバーでのバックアップを大幅に高速化できるようになりました。

並列処理ワーカーの動作をより適切に調整する

max_Parallel_workers および min_Parallel_table_scan_size/min_Parallel_index_scan_size パラメーターを参照してください。後者の 2 つのデフォルト値 (8MB、512KB) を少し増やすことをお勧めします。

ツールを簡単に使用できる新しい組み込み監視ロール

新しいロール pg_monitor、pg_read_all_settings、pg_read_all_stats、および pg_stat_scan_tables により、以前はスーパーユーザー アカウントまたは SECURITY DEFINER ラッパー関数を使用して実行する必要があったさまざまな監視タスクを簡単に実行できるようになります。

より安全なレプリカ生成のための一時的な (セッションごとの) レプリケーション スロット

B ツリー インデックスの有効性をチェックするための新しい Contrib 拡張機能

これら 2 つのスマート チェックは、ページレベルの検証ではカバーされない構造的な不一致とコンテンツを検出します。近い将来、さらに深く掘り下げられることを期待しています。

Psql クエリ ツールが基本的なブランチ (if/elif/else) をサポートするようになりました

たとえば、次の例では、多数のバージョン固有のスクリプトではなく、特定のバージョン ブランチ (pg_stat* ビューなどの異なる列名を持つ) を持つ単一のメンテナンス/監視スクリプトが有効になります。

リーリー

今回はここまでです!もちろん、リストされていないものは他にもたくさんあるため、専任の DBA の場合は、リリース レコードをより包括的に確認することを強くお勧めします。このリリースに貢献してくれた 300 人以上の人々に感謝します。

以上がDBA が PostgreSQL の新たな問題を発見の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

マルチスレッドをC言語で実装する4つの方法 マルチスレッドをC言語で実装する4つの方法 Apr 03, 2025 pm 03:00 PM

言語のマルチスレッドは、プログラムの効率を大幅に改善できます。 C言語でマルチスレッドを実装する4つの主な方法があります。独立したプロセスを作成します。独立して実行される複数のプロセスを作成します。各プロセスには独自のメモリスペースがあります。擬似マルチスレッド:同じメモリ空間を共有して交互に実行するプロセスで複数の実行ストリームを作成します。マルチスレッドライブラリ:pthreadsなどのマルチスレッドライブラリを使用して、スレッドを作成および管理し、リッチスレッド操作機能を提供します。 Coroutine:タスクを小さなサブタスクに分割し、順番に実行する軽量のマルチスレッド実装。

web.xmlを開く方法 web.xmlを開く方法 Apr 03, 2025 am 06:51 AM

web.xmlファイルを開くには、次の方法を使用できます。テキストエディター(メモ帳やテキストエディットなど)を使用して、統合開発環境(EclipseやNetBeansなど)を使用してコマンドを編集できます(Windows:Notepad web.xml; Mac/Linux:Open -A Textedit Web.xml)

PythonインタープリターはLinuxシステムで削除できますか? PythonインタープリターはLinuxシステムで削除できますか? Apr 02, 2025 am 07:00 AM

Linux Systemsに付属するPythonインタープリターを削除する問題に関して、多くのLinuxディストリビューションは、インストール時にPythonインタープリターをプリインストールし、パッケージマネージャーを使用しません...

Linuxは何に最適なものですか? Linuxは何に最適なものですか? Apr 03, 2025 am 12:11 AM

Linuxは、サーバー管理、組み込みシステム、デスクトップ環境として最適です。 1)サーバー管理では、LinuxはWebサイト、データベース、アプリケーションをホストするために使用され、安定性と信頼性を提供します。 2)組み込みシステムでは、Linuxは柔軟性と安定性のため、スマートホームおよび自動車電子システムで広く使用されています。 3)デスクトップ環境では、Linuxは豊富なアプリケーションと効率的なパフォーマンスを提供します。

Debian Hadoopの互換性はどうですか Debian Hadoopの互換性はどうですか Apr 02, 2025 am 08:42 AM

DebianLinuxは、その安定性とセキュリティで知られており、サーバー、開発、デスクトップ環境で広く使用されています。現在、DebianとHadoopとの直接的な互換性に関する公式の指示が不足していますが、この記事では、DebianシステムにHadoopを展開する方法について説明します。 Debianシステムの要件:Hadoop構成を開始する前に、DebianシステムがHadoopの最小動作要件を満たしていることを確認してください。これには、必要なJavaランタイム環境(JRE)とHadoopパッケージのインストールが含まれます。 Hadoop展開手順:Hadoopをダウンロードして解凍:公式ApachehadoopのWebサイトから必要なHadoopバージョンをダウンロードして解決します

Debian文字列は、複数のブラウザと互換性があります Debian文字列は、複数のブラウザと互換性があります Apr 02, 2025 am 08:30 AM

「DebianStrings」は標準的な用語ではなく、その特定の意味はまだ不明です。この記事は、ブラウザの互換性について直接コメントすることはできません。ただし、「DebianStrings」がDebianシステムで実行されているWebアプリケーションを指す場合、そのブラウザの互換性はアプリケーション自体の技術アーキテクチャに依存します。ほとんどの最新のWebアプリケーションは、クロスブラウザーの互換性に取り組んでいます。これは、次のWeb標準と、適切に互換性のあるフロントエンドテクノロジー(HTML、CSS、JavaScriptなど)およびバックエンドテクノロジー(PHP、Python、Node.jsなど)を使用することに依存しています。アプリケーションが複数のブラウザと互換性があることを確認するには、開発者がクロスブラウザーテストを実施し、応答性を使用する必要があることがよくあります

GOを使用してOracleデータベースに接続するときにOracleクライアントをインストールする必要がありますか? GOを使用してOracleデータベースに接続するときにOracleクライアントをインストールする必要がありますか? Apr 02, 2025 pm 03:48 PM

GOを使用してOracleデータベースに接続するときにOracleクライアントをインストールする必要がありますか? GOで開発するとき、Oracleデータベースに接続することは一般的な要件です...

See all articles