Configura un servidor NTP externo

En esta página, se describe cómo configurar un servidor NTP externo para el dispositivo aislado de Google Distributed Cloud (GDC).

Estos pasos solo son necesarios si deseas sincronizar el dispositivo con una fuente de tiempo externa.

Antes de comenzar

Para sincronizar el dispositivo con un servidor NTP externo, configura el dispositivo y, luego, instala el software.

Configura la retransmisión de NTP

  1. Determina la dirección IP que debe usar el dispositivo aislado de GDC para acceder a tu servidor NTP. Es posible que debas ajustar las reglas de firewall para permitir el tráfico.

  2. Con el archivo kubeconfig raíz, edita el CR ntprelay en el clúster del plano de administración y agrega la sección upstreamServers.

    kubectl edit ntprelay bi-ntp-relay -n gpc-system
    ntprelay.system.private.gdc.goog/bi-ntp-relay edited
    kubectl get ntprelay bi-ntp-relay -n gpc-system -oyaml
    

    El archivo YAML resultante tiene una sección .spec actualizada que incluye la IP, como se muestra en el siguiente ejemplo:

    apiVersion: system.private.gdc.goog/v1alpha1
    kind: NTPRelay
    metadata:
      creationTimestamp: "2025-05-16T08:44:21Z"
      generation: 2
      name: bi-ntp-relay
      namespace: gpc-system
      resourceVersion: "10871409"
      uid: 6cde8e65-791c-4bc6-9a8b-d5c9bf103f8b
    spec:
      upstreamServers:
      - 192.0.2.030
    
  3. Verifica la hora en cada nodo:

    Espera tres minutos para que se sincronicen y, luego, ejecuta el siguiente comando en el clúster del plano de control con el kubeconfig raíz:

    kubectl get pods -l app.kubernetes.io/name=ntp -n ntp-system -o name | xargs -P 0 -I {} kubectl exec {} -n ntp-system -- date; echo
    

    El resultado muestra la hora de cada nodo, que coincide con la hora de tu servidor NTP. El resultado es similar al siguiente:

    Defaulted container "ntp-image" out of: ntp-image, ntp-node-exporter
    Defaulted container "ntp-image" out of: ntp-image, ntp-node-exporter
    Defaulted container "ntp-image" out of: ntp-image, ntp-node-exporter
    Thu Nov  6 19:39:34 UTC 2025
    Thu Nov  6 19:39:34 UTC 2025
    Thu Nov  6 19:39:34 UTC 2025
    

Cómo depurar problemas de conectividad

Si la hora no coincide, ejecuta el siguiente comando en el clúster del plano de control con el kubeconfig raíz para depurar la conectividad con el servidor NTP:

kubectl get pods -l app.kubernetes.io/name=ntp -n ntp-system -o name | xargs -I {} kubectl exec {} -n ntp-system -- sh -c "chronyc sources -v; echo; chronyc ntpdata"; echo

El resultado de una conexión en buen estado se ve de la siguiente manera. La IP del servidor externo comienza con ^*. En los datos de la fuente (como Remote address : 192.0.2.026), TX es la cantidad de paquetes enviados y RX es la cantidad de paquetes recibidos. Si RX es 0, esto indica un problema de conectividad. Verifica tu firewall para ver si las solicitudes de NTP se están procesando:

  .-- Source mode  '^' = server, '=' = peer, '#' = local clock.
/ .- Source state '*' = current best, '+' = combined, '-' = not combined,
| /             'x' = may be in error, '~' = too variable, '?' = unusable.
||                                                 .- xxxx [ yyyy ] +/- zzzz
||      Reachability register (octal) -.           |  xxxx = adjusted offset,
||      Log2(Polling interval) --.      |          |  yyyy = measured offset,
||                                \     |          |  zzzz = estimated error.
||                                 |    |           \
MS Name/IP address         Stratum Poll Reach LastRx Last sample
===============================================================================
^* 192.0.2.026                   1   6    17    43   +286ns[  +36us] +/- 1160us
=? 192.0.2.029                 0   6     0     -     +0ns[   +0ns] +/-    0ns
=? 192.0.2.051                 0   6     0     -     +0ns[   +0ns] +/-    0ns
=? 192.0.2.059            0   6     0     -     +0ns[   +0ns] +/-    0ns

Remote address  : 192.0.2.026 (ACC03AF1)
Remote port     : 123
Local address   : 192.0.2.029 (0AA800D5)
Leap status     : Normal
Version         : 4
Mode            : Symmetric passive
Stratum         : 2
Poll interval   : 10 (1024 seconds)
Precision       : -25 (0.000000030 seconds)
Root delay      : 0.000381 seconds
Root dispersion : 0.000397 seconds
Reference ID    : ACC03BDF ()
Reference time  : Thu Nov 06 19:36:31 2025
Offset          : -0.000002443 seconds
Peer delay      : 0.000202604 seconds
Peer dispersion : 0.000000053 seconds
Response time   : 0.000097758 seconds
Jitter asymmetry: -0.37
NTP tests       : 111 111 1111
Interleaved     : No
Authenticated   : No
TX timestamping : Daemon
RX timestamping : Kernel
Total TX        : 67
Total RX        : 67
Total valid RX  : 67
Total good RX   : 67