Resource management

一般的なKubernetesクラスターでは、ポッドは無制限のリソースで実行されます。デフォルトでは、必要なだけCPUとRAMを使用できます。

CloudNativePGを使用すると、管理者は、マニフェストのresources セクションを介して、クラスターのポッドによるリソース使用を制御および管理できます。

  • requests 初期要件

  • limits 最大使用量、リソースニーズが動的に増加した場合

たとえば、次のように32MiB 128MiBまでスケーラブルなRAMの初期量と50mのCPU 100mまでスケーラブルを要求できます。

resources:
  requests:
    memory: "32Mi"
    cpu: "50m"
  limits:
    memory: "128Mi"
    cpu: "100m"

メモリ要求と制限はコンテナに関連付けられますが、ポッドにメモリ要求と制限があると考えると便利です。ポッドのメモリ要求は、ポッド内のすべてのコンテナのメモリ要求の合計です。

ポッドのスケジューリングは、制限ではなく要求にもとづいています。ポッドのメモリ要求を満たすだけの十分な使用可能なメモリがノードにある場合にのみ、ポッドはノードで実行されるようにスケジュールされます。

リソースごとに、コンテナを優先度の高い順に3つのサービス品質QoSクラスに分割します。

  • 保証

  • バースト可能

  • ベストエフォート

詳細については、 Configure Quality of Service for Pods を参照してください。

Kubernetesドキュメントのセクション。

PostgreSQLワークロードの場合、「保証」QoSを設定することをお勧めします。

注釈

サービス品質が「保証」に設定されている場合、CloudNativePGは、 PostgreSQL documentation に従って、 postmaster プロセスの`PG_OOM_ADJUST_VALUE` を`0` に設定します。これにより、 postmaster は`-997` の低いアウトオブメモリOOMスコアを維持できますが、その子プロセスは`0` のOOMスコア調整で実行されます。その結果、OOMキラーがトリガーされると、postmaster より前に子プロセスを終了します。この動作は、PostgreSQLインスタンスをできるだけ長く生かし続けるのに役立ち、エビクションが発生した場合のクリーンシャットダウン手順を有効にします。

Kubernetesのリソース関連の問題を回避するには、クラスターの作成中に「リソース不足」処理のベストプラクティスを参照できます。

  • マニフェストファイルのリソースセクションでメモリとCPUの必要な値を指定します。この方法により、OOM Killed およびCPU throttle または実行中のインスタンスに関するその他のリソース関連の問題を回避できます。

  • クラスターのポッドを「保証」QoSクラスに割り当てるには、メモリとCPUの両方の制限と要求を同じ値に設定する必要があります。

  • ポッドリソースと一貫して必要なPostgreSQLメモリパラメーターを指定しますVMまたは物理マシンのシナリオで行うように、以下を参照してください。

  • nodeSelectorを使用して、専用ノードにデータベースサーバーポッドをセットアップします。 APIリファレンスページの “affinityconfiguration" リソースの「nodeSelector」および「tolerations」フィールドを参照してください。

次のマニフェストの例を参照できます。

apiVersion: postgresql.cnpg.io/v1
kind: Cluster
metadata:
  name: postgresql-resources
spec:

  instances: 3

  postgresql:
    parameters:
      shared_buffers: "256MB"

  resources:
    requests:
      memory: "1024Mi"
      cpu: 1
    limits:
      memory: "1024Mi"
      cpu: 1

  storage:
    size: 1Gi

上記の例では、 256MB の値でshared_buffers パラメーターを指定しました。つまり、データをキャッシュするためにPostgreSQLサーバーに専用のメモリの量です。このパラメーターのデフォルト値は定義されていない場合の128MB です。

shared_buffers の適切な開始値は、システム内のメモリの25%です。例えば shared_buffers が256 MBの場合、コンテナメモリサイズの推奨値は1 GBです。これは、ポッド内ですべてのコンテナが合計1 GBのメモリを持つことを意味し、Kubernetesが常に保持し、コンテナができることを意味します予想通りに動作します。詳細については、 Resource Consumption を参照してください。

PostgreSQLドキュメントのセクション。

注釈

リソース管理の詳細については、 Managing Compute Resources for Containers を参照してください。

Kubernetesドキュメントのページ。