Habilitar la autenticación de Cassandra

De forma predeterminada, Cassandra se instala sin habilitar la autenticación. Eso significa que cualquier persona puede acceder a Cassandra. Puedes habilitar la autenticación después de instalar Edge o como parte del proceso de instalación.

Si decides habilitar la autenticación en Cassandra, utiliza las siguientes credenciales predeterminadas:

  • nombre de usuario = 'Cassandra'
  • contraseña = 'cassandra'

Puedes usar la cuenta, establecer una contraseña diferente o crear un usuario nuevo de Cassandra. Agrega, quita y modifica usuarios con las instrucciones CREATE/ALTER/DROP USER de Cassandra.

Para obtener más información, consulta Comandos de shell de Cassandra SQL.

Habilitar la autenticación de Cassandra durante la instalación

Puedes habilitar la autenticación de Cassandra en el momento de la instalación. Sin embargo, aunque puedes habilitar la autenticación cuando instalas Cassandra, no puedes cambiar el nombre de usuario y la contraseña predeterminados. Debes realizar ese paso de forma manual después de que se complete la instalación de Cassandra.

Para habilitar la autenticación de Cassandra en el momento de la instalación, incluye la propiedad CASS_AUTH en el archivo de configuración de todos los nodos de Cassandra:

CASS_AUTH=y # The default value is n.

Los siguientes componentes de Edge acceden a Cassandra:

  • Servidor de administración
  • Procesadores de mensajes
  • Routers
  • Servidores Qpid
  • Servidores de Postgres

Por lo tanto, cuando instales estos componentes, deberás establecer las siguientes propiedades en el archivo de configuración para especificar las credenciales de Cassandra:

CASS_USERNAME=cassandra
CASS_PASSWORD=cassandra

Puedes cambiar las credenciales de Cassandra después de instalarlo. Sin embargo, si ya instalaste el servidor de administración, los procesadores de mensajes, los routers, los servidores Qpid o los servidores Postgres, también debes actualizar esos componentes para usar las credenciales nuevas.

Para cambiar las credenciales de Cassandra después de instalarlo, haz lo siguiente:

  1. Accede a cualquier nodo de Cassandra con la herramienta de cqlsh y las credenciales predeterminadas. Solo tienes que cambiar la contraseña en un nodo, y se transmitirá a todos los nodos de Cassandra en el anillo:
    /opt/apigee/apigee-cassandra/bin/cqlsh cassIP 9042 -u cassandra -p cassandra

    Donde:

    1. cassIP es la dirección IP del nodo de Cassandra.
    2. 9042 es el puerto de Cassandra predeterminado.
    3. El usuario predeterminado es cassandra.
    4. La contraseña predeterminada es cassandra. Si ya cambiaste la contraseña, usa la actual. Si la contraseña contiene caracteres especiales, enciérrala entre comillas simples.
  2. Ejecuta el siguiente comando en el mensaje de cqlsh> para actualizar la contraseña:
    ALTER USER cassandra WITH PASSWORD 'NEW_PASSWORD';
  3. Sal de la herramienta cqlsh, como se muestra en el siguiente ejemplo:
    exit
  4. Si aún no instalaste el servidor de administración, los procesadores de mensajes, los routers, los servidores Qpid o los servidores Postgres, configura las siguientes propiedades en el archivo de configuración y, luego, instala esos componentes:
    CASS_USERNAME=cassandra
    CASS_PASSWORD=NEW_PASSWORD
  5. Si ya instalaste el servidor de administración, los procesadores de mensajes, los routers, los servidores Qpid o los servidores Postgres, consulta Restablece contraseñas perimetrales para conocer el procedimiento a fin de actualizar esos componentes y usar la contraseña nueva.

Habilitar la autenticación de Cassandra posterior a la instalación

Para habilitar la autenticación, sigue estos pasos:

  • Actualiza todos los componentes de Edge que se conectan a Cassandra con el nombre de usuario y la contraseña de Cassandra.
  • En todos los nodos de Cassandra, habilita la autenticación.
  • Configurar el nombre de usuario y la contraseña de Cassandra en cualquier nodo Solo tienes que cambiar las credenciales en un nodo de Cassandra y estas se transmitirán a todos los nodos de Cassandra del anillo.

Usa el siguiente procedimiento para actualizar todos los componentes de Edge que se comunican con Cassandra con las credenciales nuevas. Ten en cuenta que debes realizar este paso antes de actualizar las credenciales de Cassandra:

  1. En el nodo del servidor de administración, ejecuta el siguiente comando:
    /opt/apigee/apigee-service/bin/apigee-service edge-management-server
      store_cassandra_credentials -u cassandra_username -p cassandra_password

    De manera opcional, puedes pasar un archivo al comando que contiene el nombre de usuario y la contraseña nuevos:

    apigee-service edge-management-server store_cassandra_credentials  -f configFile

    En el ejemplo anterior, configFile contiene lo siguiente:

    CASS_USERNAME=cassandra_username # Default is cassandra
    CASS_PASSWORD='cassandra_password' # Default is cassandra; wrap in single quotes if it includes special chars

    Este comando reinicia automáticamente el servidor de administración.

  2. Para cada uno de los siguientes servicios, repite el paso 1:
    • Todos los procesadores de mensajes
    • Todos los routers
    • Todos los servidores de Qpid (edge-qpid-server)
    • Servidores de Postgres (edge-postgres-server)

    Cuando repitas el paso 1 para cada servicio, reemplaza edge-management-server en el comando anterior con el nombre del servicio adecuado. Por ejemplo, cuando ejecutes el paso para un servicio de router, usa el siguiente comando:

    /opt/apigee/apigee-service/bin/apigee-service edge-router
      store_cassandra_credentials -u cassandra -p cassandra

Usa el siguiente procedimiento para habilitar la autenticación de Cassandra y configurar el nombre de usuario y la contraseña:

  1. Accede al primer nodo de Cassandra.
  2. Ejecuta el siguiente comando:
    /opt/apigee/apigee-service/bin/apigee-service apigee-cassandra
      enable_cassandra_authentication -e y

    Este comando habilita la autenticación y reinicia Cassandra.

  3. Repite los pasos 1 y 2 en todos los nodos de Cassandra.
  4. Accede a cualquier nodo de Cassandra con la herramienta de cqlsh y las credenciales predeterminadas. Solo tienes que cambiar la contraseña en un nodo de Cassandra y se transmitirá a todos los nodos de Cassandra del anillo:
    /opt/apigee/apigee-cassandra/bin/cqlsh cassIP 9042 -u cassandra -p cassandra

    Ubicación

    • cassIP es la dirección IP del nodo de Cassandra.
    • 9042 es el puerto de Cassandra.
    • El usuario predeterminado es cassandra.
    • La contraseña predeterminada es cassandra. Si ya cambiaste la contraseña, usa la actual.
  5. Ejecuta el siguiente comando en el mensaje de cqlsh> para actualizar la contraseña:
    ALTER USER cassandra WITH PASSWORD 'NEW_PASSWORD';
  6. Ejecuta el siguiente comando en el mensaje cqlsh> para asegurarte de que el espacio de claves siempre esté disponible.

    Para un solo centro de datos:

    ALTER KEYSPACE system_auth WITH replication = {'class': 'NetworkTopologyStrategy', 'dc-1': '3'};

    Para dos centros de datos:

    ALTER KEYSPACE system_auth WITH replication = {'class': 'NetworkTopologyStrategy', 'dc-1': '3', 'dc-2': '3'};
  7. Sal de la herramienta cqlsh:
    exit
  8. Ejecuta nodetool repair para asegurarte de que el cambio se propague a todos los nodos de Cassandra, como se muestra en el siguiente ejemplo:
    /opt/apigee/apigee-cassandra/bin/nodetool [-u username -pw 'password'] repair system_auth

    Solo tienes que pasar tu nombre de usuario y contraseña si habilitaste la autenticación JMX para Cassandra.