From 23ceb93f072d284ac8e42d914a758131cd1fd14b Mon Sep 17 00:00:00 2001 From: Daniel Helm Date: Mon, 9 Sep 2024 14:02:36 -0500 Subject: [PATCH] add node affinity section --- .../guides/digital-ocean-alt-gas-token.mdx | 49 ++++++++++++++++--- 1 file changed, 43 insertions(+), 6 deletions(-) diff --git a/src/content/docs/en/sdk/guides/digital-ocean-alt-gas-token.mdx b/src/content/docs/en/sdk/guides/digital-ocean-alt-gas-token.mdx index 673802fe4..d09b66e81 100644 --- a/src/content/docs/en/sdk/guides/digital-ocean-alt-gas-token.mdx +++ b/src/content/docs/en/sdk/guides/digital-ocean-alt-gas-token.mdx @@ -35,9 +35,9 @@ This guide is intended for chain owners and those that aren't DevOps professiona Because AltGas token introduces another element of complexity, we will use it here as well. ## Getting your machine ready @@ -473,12 +473,49 @@ Right now, this doesn't work on DigitalOcean. We haven't debugged it yet, but we As long as you setup the databases in the `scrollsdk setup db-init` step, you can run `helm upgrade -i blockscout blockscout --values blockscout/values/production.yaml` -{/* ### Test Optimized Machine configurations +### Optimize Machine Configuration with Node Affinity + +As you work with your network, you might want to be more selective about the pools you provide to services. + +One example is that the `l2-sequencer` may want additional CPU-resources and the `coordinator-api` has RAM requirements far greater than other services. + +If you'd like to give this a try, create a new "Node Pool" in DigitalOcean -- perhaps selecting "CPU Intensive - 8vCPU 16 GB RAM" and naming it "pool-sequencer". + +Now, in your `l2-sequencer/values/production-1.yaml` file, add the following section: + +```yaml +affinity: + nodeAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + nodeSelectorTerms: + - matchExpressions: + - key: doks.digitalocean.com/node-pool + operator: In + values: + - pool-sequencer +resources: + requests: + memory: "450Mi" + cpu: "80m" + limits: + memory: "14Gi" + cpu: "7.5" +``` + +Here, we're adding asking it to only select nodes that are in the "pool-sequencer" and increasing the resources of the pod to allow up to 7.5 CPU cores. -If you want to modify your pools, you may want to have certain machines with extra CPU (say, for the sequencer) or RAM (for the coordinator-api), without paying for all machines in the cluster to have these characteristics. +To apply this, run: -DigitalOcean makes this pretty easy. +```bash +helm upgrade -i l2-sequencer l2-sequencer --values l2-sequencer/values/production-1.yaml +``` + +For more info, see the Kubernetes page on [Assigning Pods to Nodes](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/). + +{/* ### Add Redundancy! -Soon, we'll add more information about quickly adding Replicas. */} \ No newline at end of file +Soon, we'll add more information about quickly adding Replicas. + +*/} \ No newline at end of file