De forma predeterminada, Cassandra instala sin autenticación habilitada. Eso significa que cualquier persona puede acceder Cassandra. Puedes habilitar la autenticación después de instalar Edge o como parte de la instalación. el proceso de administración de recursos.
Puedes agregar, quitar y modificar usuarios con el CREATE/ALTER/DROP USER
de Cassandra.
declaraciones. Para obtener más información, consulta Comandos de shell de Cassandra SQL.
Habilitar la autenticación de Cassandra durante instalación
Puedes habilitar la autenticación de Cassandra en el momento de la instalación.
Para habilitar la autenticación de Cassandra en el momento de la instalación, incluye CASS_AUTH
.
en el archivo de configuración para 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
Cuando instales estos componentes, deberás configurar un nombre de usuario y una contraseña en la de Terraform:
CASS_USERNAME=cassandra_username CASS_PASSWORD=cassandra_password
Puedes cambiar las credenciales de Cassandra después de instalar Cassandra. Sin embargo, si tienes si ya instaló el servidor de administración, los procesadores de mensajes, los routers, los servidores Qpid o Postgres también debe actualizar esos componentes para usar las credenciales nuevas.
Para cambiar las credenciales de Cassandra después de instalar Cassandra, haz lo siguiente:
- Accede a cualquier nodo de Cassandra con la herramienta de
cqlsh
y la configuración predeterminada. credenciales. Solo debes cambiar la contraseña de un nodo y se transmitirá a todos. Nodos de Cassandra en el anillo:/opt/apigee/apigee-cassandra/bin/cqlsh cassIP 9042 -u cassandra_username -p cassandra_password
Aquí:
- cassIP es la dirección IP del nodo de Cassandra.
- 9042 es el puerto de Cassandra predeterminado.
- Ejecuta el siguiente comando en el símbolo del sistema
cqlsh>
para actualizar la contraseña:ALTER USER cassandra_username/var> WITH PASSWORD 'new_cassandra_password';
- Sal de la herramienta
cqlsh
, como se muestra en el siguiente ejemplo:exit
- Si aún no instaló el servidor de administración, los procesadores de mensajes
Los routers, los servidores Qpid o los servidores de Postgres, configuran las siguientes propiedades en
de configuración y, luego, instala los componentes:
CASS_USERNAME=cassandra_username CASS_PASSWORD=new_cassandra_password
- Si ya instalaste el servidor de administración, Procesadores, routers, servidores Qpid o Postgres, consulta Restablece las contraseñas de Edge para conocer el procedimiento para actualizarlas. componentes para usar la contraseña nueva.
Habilitar publicación de autenticación de Cassandra instalación
Para habilitar la autenticación después de una instalación, haz lo siguiente:
- Actualiza todos los componentes de Edge que se conectan a Cassandra con el nombre de usuario y el nombre de usuario de Cassandra. contraseña.
- Habilitar la autenticación en todos los nodos de Cassandra y establecer el nombre de usuario y la contraseña de Cassandra en cualquier nodo. Solo tienes que cambiar la credenciales en un nodo de Cassandra y se transmitirán a todos los nodos de Cassandra en de Google.
Actualiza los componentes de Edge que se conectan a Cassandra
Usa el siguiente procedimiento para actualizar todos los componentes de Edge que se comunican con Cassandra con las credenciales nuevas. Ten en cuenta que realizas este paso antes de actualizar la app de Cassandra credenciales:
- 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 contenga 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.
- Para cada uno de los siguientes servicios, repite el paso 1:
- Todos los procesadores de mensajes
- Todos los routers
- Todos los servidores Qpid (edge-qpid-server)
- Servidores Postgres (edge-postgres-server)
Cuando repitas el paso 1 para cada servicio, reemplaza
edge-management-server
en anterior con el nombre de servicio adecuado. Por ejemplo, cuando ejecutas el paso para En un servicio de router, usa el siguiente comando:/opt/apigee/apigee-service/bin/apigee-service edge-router store_cassandra_credentials -u cassandra -p cassandra
Habilitar autenticación
Usa el siguiente procedimiento para habilitar la autenticación de Cassandra y configurar el nombre de usuario y contraseña:
- Crea un archivo de configuración silencioso con el contenido que se muestra a continuación:
# Specify IP address or DNS name of cassandra node IP1=192.168.1.1 IP2=192.168.1.2 IP3=192.168.1.3 # Must resolve to IP address or DNS name of host HOSTIP=$(hostname -i) # Set to ‘y’ to enable Cassandra authentication. CASS_AUTH=y # Possible values are ‘y/n’ # Cassandra username. If it does not exist, this user would be created as a SUPERUSER CASS_USERNAME=cassandra_username # Default value is cassandra - don't use for production # Cassandra Password. If CASS_USERNAME does not exist, create SUPERUSER with this as password CASS_PASSWORD=cassandra_password # Default value is cassandra - don't use for production # Space-separated IP/DNS names of the Cassandra hosts CASS_HOSTS="$IP1:1,1 $IP2:1,1 $IP3:1,1" # Username of an existing C* user. Only needed if you have disabled or changed details of the default cassandra user(‘cassandra’) CASS_EXISTING_USERNAME=existing_cassandra_username # Password of an existing C* user. Only needed if you have disabled or change password of the default cassandra user(‘cassandra’) CASS_EXISTING_PASSWORD=existing_cassandra_password # Cassandra port CASS_PORT=9042 # The default port is 9042.
Accede al primer nodo de Cassandra y ejecuta el siguiente comando:
apigee-service apigee-cassandra enable_cassandra_authentication -f CONFIG
Si lo deseas, puedes pasar las propiedades como argumentos del comando a la secuencia de comandos, tal como se muestra en el siguiente ejemplo:
CASS_AUTH=y HOSTIP=$(hostname -i) CASS_PORT=9042 CASS_EXISTING_USERNAME=existing_cassandra_username CASS_EXISTING_PASSWORD=existing_cassandra_password CASS_USERNAME=cassandra_username CASS_PASSWORD=cassandra_password CASS_HOSTS="192.168.1.1:1,1 192.168.1.2:1,1 192.168.1.3:1,1" apigee-service apigee-cassandra enable_cassandra_authentication
Notas:
- De forma predeterminada credenciales de Cassandra, el comando anterior habilita la autenticación de Cassandra y los reinicios Cassandra.
- Para credenciales no predeterminadas, el comando también altera el factor de replicación, crea un
superusuario y ejecuta una reparación en
system_auth keyspace
.
- Repite los pasos 1 y 2 en todos los nodos de Cassandra.