×
Community Blog Enable ARMS Prometheus for a Registered Kubernetes Cluster

Enable ARMS Prometheus for a Registered Kubernetes Cluster

This article describes how to enable ARMS Prometheus for a registered Kubernetes cluster by deploying the application in Alibaba Cloud ACK.

By Liusheng

You can use Application Real-Time Monitoring Service (ARMS) Prometheus to manage Kubernetes clusters deployed across regions in a unified manner. This article describes how to enable ARMS Prometheus for a registered Kubernetes cluster by deploying the application in Alibaba Cloud Container Service for Kubernetes (ACK).

Prerequisites

You need to a registered Kubernetes cluster through ACK. Please see Create a Registered Cluster and Enable it for a Local Data Center Cluster for more information.

Step 1: Configure RAM Permissions for the arms-prometheus Component

Note: If you connect to a registered cluster over an internal network, skip this step. If you want to connect to a registered cluster over a public network, you must configure an AccessKey pair to access cloud services in the registered cluster before installing components in it.

Run the following command to check whether the cluster is connected over the internal network:

kubectl -n kube-system get deploy ack-cluster-agent -o=jsonpath='{.spec.template.spec.containers[0].env[?(@.name=="INTERNAL_ENDPOINT")].value}'

If the output is true, it is an internal network.

If the output is false, it is a public network. You need to use the following methods to configure the AccessKey.

Method 1: onectl CLI (Recommended)

Please visit this article for more information.

After onectl is configured, run the following command to automatically configure and install the arms-prometheus component:

onectl addon install ack-arms-prometheus

Method 2: Custom Configuration

1.  Create a RAM user. Please see Create a RAM User for more information.

2.  Create a permission policy. Please see Create a Custom Policy for more information.

The following permissions are required for the arms-prometheus component:

{
    "Version": "1",
    "Statement": [
        {
            "Action": [
                "arms:Describe*",
                "arms:List*",
                "arms:Get*",
                "arms:Search*",
                "arms:Check*",
                "arms:Query*"
            ],
            "Resource": "*",
            "Effect": "Allow"
        }
    ]
}

3.  Add permissions to the RAM user. Please see Grant permissions to a RAM user for more information.

4.  Create an AccessKey pair for the RAM user. Please see Create an AccessKey Pair for more information.

5.  Use the AccessKey pair to create a Secret named alibaba-addon-secret in the registered cluster. Run the following command to create a Secret for the Logtail component:

kubectl -n arms-prom create secret generic alibaba-addon-secret --from-literal='access-key-id=<your AccessKey ID>' --from-literal='access-key-secret=<your AccessKey Secret>'

Step 2: Install the arms-prometheus Component

  1. Log on to the ACK console
  2. On the left-side navigation pane of the ACK console, click Clusters
  3. On the Clusters page, find the cluster you want to manage and choose More> Manage System Components in the Actions column
  4. Click the Logs and Monitoring tab. In the ack-arms-prometheus Components section, click Install
  5. In the Note dialog box, click OK

Step 3: Verify That the Components Work Properly

After the installation, you can log on to the Prometheus console. Click the Prometheus instance named after the registered cluster. On the details page of the Prometheus instance, you can view monitoring data and create alert rules. Please see ARMS Prometheus Monitoring and Create a Prometheus Monitoring Alert for more information.

How to Switch ARMS-Prometheus to Collect Data from the cadvisor Port 10250

The arms-promethues component collects data from the cadvisor port 10255 by default. If only the kubelet port 10250 is enabled for your cluster, perform the following steps:

1.  Deploy and configure ServiceMonitor in the cluster:

apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
  annotations:
    arms.prometheus.io/discovery: 'true'
  name: arms-prom-cadvisor-10250
  namespace: arms-prom
spec:
  endpoints:
    - bearerTokenFile: /var/run/secrets/kubernetes.io/serviceaccount/token
      honorLabels: true
      port: https-metrics
      relabelings:
        - sourceLabels:
            - __metrics_path__
          targetLabel: metrics_path
      scheme: https
      tlsConfig:
        caFile: /var/run/secrets/kubernetes.io/serviceaccount/ca.crt
        insecureSkipVerify: true
    - bearerTokenFile: /var/run/secrets/kubernetes.io/serviceaccount/token
      honorLabels: true
      path: /metrics/cadvisor
      port: https-metrics
      relabelings:
        - sourceLabels:
            - __metrics_path__
          targetLabel: metrics_path
      scheme: https
      tlsConfig:
        caFile: /var/run/secrets/kubernetes.io/serviceaccount/ca.crt
        insecureSkipVerify: true
    - bearerTokenFile: /var/run/secrets/kubernetes.io/serviceaccount/token
      honorLabels: true
      path: /metrics/probes
      port: https-metrics
      relabelings:
        - sourceLabels:
            - __metrics_path__
          targetLabel: metrics_path
      scheme: https
      tlsConfig:
        caFile: /var/run/secrets/kubernetes.io/serviceaccount/ca.crt
        insecureSkipVerify: true
  jobLabel: k8s-app
  namespaceSelector:
    matchNames:
      - kube-system
  selector:
    matchLabels:
      k8s-app: kubelet

2.  Verify data:

Wait for about 15s to 1min. Log on to the ARMS Prometheus console. Go to the Prometheus instance page.

On the left-side Service Discovery > Targets page, check whether the_cadvisor_10250 collection task already exists and whether the collection task status is normal.

Three sets of cadvisor data collection tasks will appear:

1

0 1 0
Share on

Alibaba Container Service

154 posts | 28 followers

You may also like

Comments

Alibaba Container Service

154 posts | 28 followers

Related Products