Você instala várias instâncias do SSO da Apigee para alta disponibilidade em dois cenários:
- Em um único ambiente de data center, instale duas instâncias de SSO da Apigee para criar uma alta ambiente de disponibilidade, ou seja, o sistema continuará funcionando se um dos provedores de SSO da Apigee módulos ficam inativos.
- Em um ambiente com dois data centers, instale o SSO da Apigee em ambos para que o sistema continuará funcionando se um dos módulos SSO da Apigee ficar inativo.
Instale dois módulos SSO da Apigee no mesmo data center
Você implanta duas instâncias do SSO da Apigee em nós diferentes, em um único data center para oferecer suporte alta disponibilidade. Nesse caso:
- As duas instâncias do SSO da Apigee precisam estar conectadas ao mesmo servidor do Postgres. A Apigee recomenda usando um servidor Postgres dedicado para SSO da Apigee e não o mesmo servidor Postgres que você instalado com o Edge.
- As duas instâncias do SSO da Apigee precisam usar o mesmo par de chaves JWT especificado pelo
SSO_JWT_SIGNING_KEY_FILEPATH
eSSO_JWT_VERIFICATION_KEY_FILEPATH
no arquivo de configuração. Consulte Instalar e configurar o SSO da Apigee para mais informações sobre como definir essas propriedades. - Você precisa de um balanceador de carga na frente das duas instâncias do SSO da Apigee:
- O balanceador de carga precisa oferecer suporte à adesão do cookie gerada pelo aplicativo, e a sessão
cookie precisa ser nomeado como
JSESSIONID
. - Configure o balanceador de carga para executar uma verificação de integridade TCP ou HTTP no SSO da Apigee. Para TCP,
Use o URL do SSO da Apigee:
http_or_https://edge_sso_IP_DNS:9099
Especifique a porta conforme definido pelo SSO da Apigee. A porta 9099 é o padrão.
Para HTTP, inclua
/healthz
:http_or_https://edge_sso_IP_DNS:9099/healthz
- Algumas configurações do balanceador de carga dependem da ativação do HTTPS no SSO da Apigee. Consulte a nas seções a seguir.
- O balanceador de carga precisa oferecer suporte à adesão do cookie gerada pelo aplicativo, e a sessão
cookie precisa ser nomeado como
Acesso HTTP para SSO da Apigee
Se você estiver usando o acesso HTTP ao SSO da Apigee, configure o balanceador de carga para:
- Use o modo HTTP para se conectar ao SSO da Apigee.
Detecte na mesma porta que o SSO da Apigee.
Por padrão, o SSO da Apigee detecta solicitações HTTP na porta 9099. Opcionalmente, você pode usar
SSO_TOMCAT_PORT
para definir a porta SSO da Apigee. Se você usouSSO_TOMCAT_PORT
Para alterar a porta SSO da Apigee para o padrão, verifique se o balanceador de carga detecta essa porta porta
Por exemplo, em cada instância SSO da Apigee, você define a porta como 9033 adicionando o seguinte ao arquivo de configuração:
SSO_TOMCAT_PORT=9033
Depois, configure o balanceador de carga para detectar na porta 9033 e encaminhar solicitações para um perímetro instância de SSO na porta 9033. O URL público do SSO da Apigee nesse cenário é:
http://LB_DNS_NAME:9033
Acesso HTTPS para SSO da Apigee
É possível configurar as instâncias do SSO da Apigee para usar HTTPS. Nesse caso, siga as etapas em
Configure o SSO da Apigee para acesso HTTPS. Conforme
como parte do processo de ativação do HTTPS, defina SSO_TOMCAT_PROFILE
no SSO da Apigee
de configuração do Terraform, conforme mostrado abaixo:
SSO_TOMCAT_PROFILE=SSL_TERMINATION
Também é possível definir a porta usada pelo SSO da Apigee para acesso HTTPS:
SSO_TOMCAT_PORT=9443
Em seguida, configure o balanceador de carga para:
- Use o modo TCP, não o modo HTTP, para se conectar ao SSO da Apigee.
- Detecte na mesma porta que o SSO da Apigee, conforme definido por
SSO_TOMCAT_PORT
.
Em seguida, você vai configurar o balanceador de carga para encaminhar solicitações a uma instância de SSO da Apigee na porta 9433. O URL público do SSO da Apigee nesse cenário é:
https://LB_DNS_NAME:9443
Instalar o SSO da Apigee em vários data centers
Em um ambiente com vários data centers, você instala uma instância de SSO da Apigee em cada um deles. Depois, uma instância SSO da Apigee processa todo o tráfego. Se essa instância do SSO da Apigee ficar inativa, você poderá mude para a segunda instância SSO da Apigee.
Antes de instalar o SSO da Apigee em dois data centers, você precisa do seguinte:
O endereço IP ou nome de domínio do servidor Master Postgres.
Em um ambiente com vários data centers, normalmente é instalado um servidor Postgres em cada um e configurá-las no modo de replicação mestre-em espera. Para este exemplo, data center 1 contém o servidor Master Postgres e o data center 2 contém o modo Standby. Para mais informações, consulte Configurar replicação mestre em espera para Postgres.
- Uma única entrada DNS que aponta para uma instância de SSO da Apigee. Por exemplo, você cria um objeto DNS
entrada no formulário abaixo que aponta para a instância de SSO da Apigee no data center 1:
my-sso.domain.com => apigee-sso-dc1-ip-or-lb
- As duas instâncias do SSO da Apigee precisam usar o mesmo par de chaves JWT especificado pelo
SSO_JWT_SIGNING_KEY_FILEPATH
eSSO_JWT_VERIFICATION_KEY_FILEPATH
no arquivo de configuração. Consulte Instalar e configurar o SSO da Apigee para mais informações sobre como definir essas propriedades.
Ao instalar o SSO da Apigee em cada data center, você configura ambos para usar o Postgres Master no data center 1:
## Postgres configuration
PG_HOST=IP_or_DNS_of_PG_Master_in_DC1
PG_PORT=5432
Você também configura os dois data centers para usar a entrada DNS como o URL acessível publicamente:
# Externally accessible URL of Apigee SSO SSO_PUBLIC_URL_HOSTNAME=my-sso.domain.com # Default port is 9099. SSO_PUBLIC_URL_PORT=9099
Se o SSO da Apigee no data center 1 ficar inativo, será possível alternar para a instância do SSO da Apigee nos dados centro 2:
- Converta o servidor Postgres em espera no data center 2 em mestre, conforme descrito em Como lidar com um failover de banco de dados PostgreSQL.
- Atualize o registro DNS para apontar
my-sso.domain.com
para a instância de SSO da Apigee em data center 2:my-sso.domain.com => apigee-sso-dc2-ip-or-lb
- Atualize o arquivo de configuração do SSO da Apigee no data center 2 para apontar para o novo Postgres Master
servidor no data center 2:
## Postgres configuration PG_HOST=IP_or_DNS_of_PG_Master_in_DC2
- Reinicie o SSO da Apigee no data center 2 para atualizar a configuração:
/opt/apigee/apigee-service/bin/apigee-service apigee-sso restart