Agrega nodos de ZooKeeper

Edge para nube privada v. 4.17.09

En este documento, se describe cómo agregar tres nodos nuevos de ZooKeeper a una instalación existente de Edge para nube privada.

Puedes agregar uno o dos nodos de ZooKeeper a una instalación de Edge existente. Sin embargo, debes asegurarte de tener siempre una cantidad impar de nodos votantes de ZooKeeper, como se describe a continuación.

Configuración de Edge existente

Todas las topologías de Edge compatibles con un sistema de producción especifican que se deben usar tres nodos de ZooKeeper. Los tres nodos se especifican en las propiedades ZK_HOSTS y ZK_CLIENT_HOSTS en el archivo de configuración, como se muestra a continuación:

IP1=10.10.0.1
IP2=10.10.0.2
IP3=10.10.0.3
HOSTIP=$(hostname -i)
ADMIN_EMAIL=opdk@google.com 
APIGEE_ADMINPW=Secret123
LICENSE_FILE=/tmp/license.txt 
MSIP=$IP1 
USE_LDAP_REMOTE_HOST=n 
LDAP_TYPE=1
APIGEE_LDAPPW=secret 
MP_POD=gateway
REGION=dc-1 
ZK_HOSTS="$IP1 $IP2 $IP3" 
ZK_CLIENT_HOSTS="$IP1 $IP2 $IP3" 
CASS_HOSTS="$IP1:1,1 $IP2:1,1 $IP3:1,1" 
SKIP_SMTP=n
SMTPHOST=smtp.example.com 
SMTPUSER=smtp@example.com  
SMTPPASSWORD=smtppwd       

Donde:

  • ZK_HOSTS especifica las direcciones IP o los nombres de DNS de los nodos de ZooKeeper. Las direcciones IP o los nombres de DNS deben aparecer en el mismo orden en todos los nodos de ZooKeeper. En un entorno de varios centros de datos, enumera todos los nodos de ZooKeeper de ambos centros de datos.
  • ZK_CLIENT_HOSTS especifica las direcciones IP o los nombres de DNS de los nodos de ZooKeeper que usa este centro de datos. Las direcciones IP o los nombres de DNS deben aparecer en el mismo orden en todos los nodos de ZooKeeper.

    En una única instalación de centro de datos, estos son los mismos nodos que especifica ZK_HOSTS. En un entorno de varios centros de datos, enumera solo los nodos de ZooKeeper de este centro de datos.

Modifica el archivo de configuración para agregar los tres nodos nuevos de ZooKeeper

En este ejemplo, los tres nodos nuevos de ZooKeeper están en las siguientes direcciones IP:

  • 10.10.0.14
  • 10.10.0.15
  • 10.10.0.16

Primero, debes actualizar el archivo de configuración de Edge para agregar los nodos nuevos:

IP1=10.10.0.1
IP2=10.10.0.2
IP3=10.10.0.3
# Add the new node IP addresses.
IP14=10.10.0.14
IP15=10.10.0.15
IP16=10.10.0.16
HOSTIP=$(hostname -i)
ADMIN_EMAIL=opdk@google.com 
...
# Update ZK_HOSTS to add each new node after an existing nodes. 
ZK_HOSTS="$IP1 $IP2 $IP3 $IP14 $IP15 $IP16:observer" 
# Update ZK_Client_HOSTS to add each new node after an existing nodes. 
ZK_CLIENT_HOSTS="$IP1 $IP2 $IP3 $IP14 $IP15 $IP16" 

Marca el último nodo en ZK_HOSTS con el modificador ":observar". Los nodos sin el modificador “:observar” se denominan “votantes”. Debes tener un número impar de "votantes" en tu configuración. Por lo tanto, en esta configuración, tienes 5 votantes de ZooKeeper y un observador.

Asegúrate de agregar los nodos a ZK_HOSTS y ZK_CLIENT_HOSTS en el mismo orden. Sin embargo, omite el modificador “:observar” cuando configures ZK_CLIENT_HOSTS.

Configura Edge

Después de editar el archivo de configuración, debes realizar todas las tareas que se indican a continuación.

Instala ZooKeeper en los nodos nuevos

  1. Instala apigee-setup en el primer nodo, como se describe en Instala la utilidad apigee-setup de Edge.
  2. Instala ZooKeeper en el primer nodo con los siguientes comandos:
    >/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper install
    > /opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper setup-f updatedConfigFile
  3. Repite los pasos 1 y 2 para los nodos nuevos de ZooKeeper restantes.

Vuelve a configurar los nodos existentes de ZooKeeper

En los nodos de ZooKeeper existentes, haz lo siguiente:

  1. Vuelve a ejecutar el comando de configuración con el perfil “-p c” y el nuevo archivo de configuración:
    > /opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper setup -f updatedConfigFile

Reinicia todos los nodos de Zookeeper

En todos los nodos de ZooKeeper:

  1. Reinicia el nodo:
    >/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper restart

    Debes reiniciar todos los nodos de ZooKeeper, pero el orden de reinicio no importa.

Vuelve a configurar el nodo del servidor de administración

En el nodo del servidor de administración, haz lo siguiente:

  1. Ejecuta el comando de configuración:
    > /opt/apigee/apigee-service/bin/apigee-service perimetral-management-server setup -f updatedConfigFile
  2. Reinicia el servidor de administración:
    > /opt/apigee/apigee-service/bin/apigee-service Edge-management-server restart

Reconfigura todos los routers

En todos los nodos del router:

  1. Ejecuta el comando de configuración:
    > /opt/apigee/apigee-service/bin/apigee-service Edge-router setup -f updatedConfigFile
  2. Reinicia el router:
    > /opt/apigee/apigee-service/bin/apigee-service perimetral-router reiniciación

Reconfigura todos los procesadores de mensajes

En todos los nodos de Message Processor, haz lo siguiente:

  1. Ejecuta el comando de configuración:
    /opt/apigee/apigee-service/bin/apigee-service perimetral-message-processor setup -f updatedConfigFile
  2. Reinicia el procesador de mensajes:
    > /opt/apigee/apigee-service/bin/apigee-service Edge-message-processor reiniciar

Reconfigura todos los nodos de Qpid

En todos los nodos de Qpid:

  1. Ejecuta el comando de configuración:
    > /opt/apigee/apigee-service/bin/apigee-service Edge-qpid-server setup -f updatedConfigFile
  2. Reiniciar Qpid:
    > /opt/apigee/apigee-service/bin/apigee-service perimetral-qpid-server restart

Vuelve a configurar todos los nodos de Postgres

En todos los nodos de Postgres:

  1. Ejecuta el comando de configuración:
    > /opt/apigee/apigee-service/bin/apigee-service perimetral-postgres-server setup -f updatedConfigFile
  2. Reinicia Postgres:
    > /opt/apigee/apigee-service/bin/apigee-service perimetral-postgres-server restart

Valida la instalación

Puedes validar la instalación de los nuevos nodos de ZooKeeper enviando comandos al puerto 2181 con netcat (nc) o telnet. Para obtener más información sobre los comandos de ZooKeeper, consulta: http://zookeeper.apache.org/doc/r3.1.2/zookeeperAdmin.html#sc_zkCommands.

Para validar, haz lo siguiente:

  1. Si no está instalado en el nodo de ZooKeeper, instala nc:
    > sudo yum install nc
  2. Ejecuta el siguiente comando nc:
    > echo stat | nc localhost 2181
  3. Repite los pasos 1 y 2 en cada nodo de ZooKeeper.
    En la línea Modo del resultado para los nodos, se debe designar un nodo como observador, un nodo como líder y el resto como seguidores.