ERP da SAP
Com o conector do SAP ERP, você pode executar operações de inserção, exclusão, atualização e leitura nos dados do SAP ERP.
Edições compatíveis
O conector do ERP da SAP pode se comunicar com os sistemas SAP R/3 usando os seguintes métodos:
- Interface de programação de aplicativos empresariais (BAPIs)
- Chamadas de função remotas (RFCs)
- Tabelas SAP
- Consultas SAP
- Mensagens do IDoc
- SAP ECC
- ERP da SAP
- SAP R/3
- SAP S/4HANA on-premise
- Versão do SAP JCo.
Esse conector exige dois arquivos JCo para a criação da conexão:
sapjco3.jar
elibsapjco3.so
(para Unix). Faça o download da versão 3.1.5 do JCo no site dos conectores SAP.
Se o sistema SAP oferecer suporte a uma conexão RFC e os RFCs necessários estiverem disponíveis, a conexão com o sistema SAP vai funcionar. Outras edições que oferecem suporte a conexões RFC também podem ser compatíveis.
Tabelas SAP:as tabelas SAP são expostas como visualizações automaticamente pela propriedade de conexão TableMode. Especifique as tabelas SAP com que você quer trabalhar usando a propriedade de conexão das visualizações, que substitui o modo de tabela. A SAP não recomenda modificar as tabelas diretamente. Em vez disso, é recomendável usar BAPIs para modificar dados tabulares. Não é possível modificar diretamente as tabelas do SAP.
BAPIs e RFCs:BAPIs e RFCs são expostos diretamente como procedimentos armazenados. Por padrão, todos os RFCs que começam com a palavra-chave BAPI são mostrados como um procedimento armazenado disponível.
IDoc:os arquivos de documento intermediário (IDoc) são objetos SAP que transportam dados de transações comerciais de um sistema para outro na forma de uma mensagem eletrônica. Os IDocs transferem dados do SAP para sistemas não SAP por meio de sistemas de troca eletrônica de dados (EDI).
Para mais informações sobre esses termos, consulte o glossário da SAP.
Antes de começar
Antes de usar o conector do SAP ERP, faça o seguinte:
- No seu projeto do Google Cloud, faça o seguinte:
- Verifique se a conectividade de rede está configurada. Para informações sobre padrões de rede, consulte Conectividade de rede.
- Conceda a função IAM roles/connectors.admin ao usuário que está configurando o conector.
- Conceda os seguintes papéis de IAM à conta de serviço que você quer usar para o conector:
roles/secretmanager.viewer
roles/secretmanager.secretAccessor
roles/storage.objectViewer
Uma conta de serviço é um tipo especial de Conta do Google destinada a representar um usuário não humano que precisa ser autenticado e autorizado a acessar dados nas APIs do Google. Se você não tiver uma conta de serviço, será necessário criar uma. Para mais informações, consulte Como criar uma conta de serviço.
- Ative os seguintes serviços:
secretmanager.googleapis.com
(API Secret Manager)connectors.googleapis.com
(API Connectors)
Para entender como ativar os serviços, consulte Como ativar serviços.
Se esses serviços ou permissões não tiverem sido ativados no seu projeto, você precisará ativá-los ao configurar o conector.
Se você ativar a assinatura de eventos, será necessário configurar o SDK ABAP. Para informações sobre como configurar o SDK do ABAP, consulte Visão geral do SDK do ABAP para Google Cloud.
Configurar o conector
Para configurar o conector, crie uma conexão com a fonte de dados (sistema de back-end). Uma conexão é específica a uma fonte de dados. Isso significa que, se você tiver muitas fontes de dados, precisará criar uma conexão separada para cada uma. Para criar uma conexão, siga estas etapas:
- No console do Cloud, acesse a página Integration Connectors > Conexões e selecione ou crie um projeto do Google Cloud.
- Clique em + Criar novo para abrir a página Criar conexão.
-
Na seção Local, escolha o local da conexão.
- Região: selecione um local na lista suspensa.
Para conferir a lista de todas as regiões com suporte, consulte Locais.
- Clique em Próxima.
- Região: selecione um local na lista suspensa.
- Na seção Detalhes da conexão, faça o seguinte:
- Conector: selecione SAP ERP na lista suspensa de conectores disponíveis.
- Versão do conector: selecione a versão do conector na lista suspensa de versões disponíveis.
- No campo Nome da conexão, insira um nome para a instância de conexão
Os nomes de conexão precisam atender aos seguintes critérios:
- Os nomes de conexões podem usar letras, números ou hifens.
- As letras precisam ser minúsculas.
- Os nomes das conexões precisam começar com uma letra e terminar com uma letra ou um número.
- Os nomes das conexões não podem ter mais de 49 caracteres.
- Para conectores que oferecem suporte à assinatura de eventos, os nomes de conexão não podem começar com o prefixo "goog".
- Se quiser, insira uma Descrição para a conexão.
- Como opção, ative o Cloud Logging e selecione um nível de registro. Por padrão, o nível de registro é definido como
Error
. - Conta de serviço: selecione uma conta de serviço que tenha os papéis necessários.
- Para usar a conexão para assinaturas de eventos, selecione Ativar assinatura de eventos. Ao selecionar
essa opção, as seguintes opções são exibidas:
- Ativar a assinatura de eventos com entidade e ações: selecione essa opção para usar a conexão nas operações de assinatura de eventos e conector (entidades e ações).
- Ativar somente a assinatura de eventos: selecione essa opção para usar a conexão somente para a assinatura de eventos. Se você selecionar essa opção, clique em Próxima e, em seguida, em Configurar assinatura de evento.
- Cliente: o cliente que faz a autenticação no sistema SAP.
- ID do sistema: o ID do sistema ou R3Name do sistema SAP é uma string com no máximo três caracteres. Ele é usado com frequência em conexões de balanceamento de carga.
- Número do sistema: o número pelo qual o sistema de destino é definido. Usado ao definir a propriedade de conexão do host.
- ID do projeto: o ID do projeto do Google Cloud em que o bucket do GCS que contém o JAR do SAP JCo reside.
- Bucket: o nome do bucket que contém os arquivos sapjco3.jar e libsapjco3.so.
- ID do objeto do jar do Jaco: ID do objeto do jar do Jaco.
- ID do objeto libsapjco3: ID do objeto do jar libsapjco3.
- Modo de tabela: selecione a tabela da SAP que será mostrada como uma visualização.
- Função de leitura de tabela: nome da função a ser usada para ler tabelas. Para mais informações, consulte Usar uma função de tabela de leitura personalizada.
- ID do sistema: o ID do sistema ou o R3Name do sistema SAP. Você pode inserir no máximo três caracteres.
- Modo de consulta: selecione quais tabelas do SAP devem ser mostradas como visualizações.
-
Visualizações pesquisáveis: insira uma lista separada por vírgulas das visualizações que serão exibidas.
Por exemplo,
ViewA,ViewB,ViewC
. - Language: defina essa propriedade como o idioma especificado ao fazer login no SAP. Essa propriedade é um código ISO 639-1 para o idioma usado pelo sistema SAP. Por padrão, o inglês será usado.
- Entradas de serviço: as entradas de serviço a serem usadas para a conexão.
-
Modo SNC: selecione essa opção para ativar o SNC para autenticação entre os Integration Connectors e seu sistema SAP. Se você selecionar essa opção, especifique os seguintes detalhes:
- ID do objeto SNC_LIB: ID do objeto da biblioteca SNC.
- Nome do PSE: nome do arquivo de ambiente de segurança pessoal (PSE, na sigla em inglês) aplicável ao bucket. Um arquivo PSE armazena o par de chaves pública e privada, bem como certificados X.509 em uma estrutura ASN.1.
- Senha SNC: selecione a chave secreta do Secret Manager da senha da biblioteca SNC.
- Versão do secret: selecione a versão do secret.
- Nome da SNC: insira um nome para a conexão da SNC.
-
SNC qop: selecione um nível de proteção. Confira os níveis compatíveis:
- 1: aplicar apenas a autenticação.
- 2: aplique a proteção de integridade. Isso também inclui a proteção de autenticação.
- 3: aplique a proteção de privacidade. Isso também inclui proteção de integridade e autenticação.
- 8: aplique a proteção padrão.
- 9: aplique a proteção máxima.
- Nome do parceiro do SNC: insira o nome do SNC do servidor de aplicativos.
-
Esquema de conexão: especifique se você está se conectando a um sistema SAP com um servidor de mensagens (servidor de grupo) ou um servidor de aplicativos. Para informações sobre os pré-requisitos que você precisa atender para se conectar a um sistema SAP com um servidor de mensagens, consulte Tipo de conexão do servidor de mensagens (servidor de grupo).
Se você selecionar GroupServer, especifique os seguintes detalhes:
- Servidor de mensagens: especifique o servidor de mensagens ao se conectar a um sistema SAP que usa balanceamento de carga.
- Serviço do servidor de mensagens: o serviço do servidor de mensagens ao qual você quer se conectar.
- Grupo: o grupo de logon usado. Você só precisa especificar isso ao se conectar a um sistema SAP que usa balanceamento de carga.
Se você estiver se conectando a um sistema SAP com um servidor de mensagens (servidor de grupo), não será necessário especificar o endereço do host na seção Destinos.
- Opcionalmente, defina as Configurações do nó de conexão:
- Número mínimo de nós: digite o número mínimo de nós de conexão.
- Número máximo de nós: digite o número máximo de nós de conexão.
Um nó é uma unidade (ou réplica) de uma conexão que processa transações. Mais nós são necessários para processar mais transações para uma conexão e, por outro lado, menos nós são necessários para processar menos transações. Para entender como os nós afetam os preços do conector, consulte Preços dos nós de conexão. Se você não inserir qualquer valor, por padrão, os nós mínimos serão definidos como 2 (para melhor disponibilidade) e os nós máximos serão definidos como 50.
- Outra opção é clicar em + ADICIONAR MARCADOR para adicionar um rótulo à conexão na forma de um par de chave-valor.
- Clique em Próxima.
- Na seção Destinos, insira os detalhes do host remoto (sistema de back-end) ao qual você quer se conectar. Se você estiver se conectando a um sistema SAP com o servidor de mensagens, não será necessário especificar o endereço do host.
- Tipo de destino: selecione um Tipo de destino.
- Selecione Endereço do host na lista para especificar o nome do host ou o endereço IP do destino.
- Para estabelecer uma conexão particular com seus sistemas de back-end, selecione Anexo de endpoint na lista e depois selecione o anexo de endpoint necessário na lista Anexo de endpoint.
Se você quiser estabelecer uma conexão pública com seus sistemas de back-end com mais segurança, considere configurar endereços IP estáticos de saída para suas conexões e, em seguida, configurar as regras do firewall para permitir apenas os endereços IP estáticos específicos.
Para inserir outros destinos, clique em +Adicionar destino.
- Clique em Próxima.
- Tipo de destino: selecione um Tipo de destino.
-
Na seção Autenticação, insira os detalhes da autenticação.
- Selecione um Tipo de autenticação e insira os detalhes relevantes.
Os seguintes tipos de autenticação são compatíveis com a conexão do SAP ERP:
- Autenticação com base no certificado X509
- Nome de usuário e senha
- Clique em Próxima.
Para entender como configurar esses tipos de autenticação, consulte Configurar autenticação.
- Selecione um Tipo de autenticação e insira os detalhes relevantes.
- Se você tiver ativado a assinatura de eventos, a seção Detalhes da assinatura de eventos vai aparecer na página de criação de conexões. Para entender como configurar os detalhes da assinatura de eventos, consulte Configurar a assinatura de eventos.
- Revisão: revise os detalhes de conexão e autenticação.
- Clique em Criar.
Configurar a autenticação
Digite os detalhes com base na autenticação que você quer usar.
-
Autenticação baseada em certificado X509
- X509Certificate: o certificado X509 usado para fazer login.
- Versão do secret: selecione a versão do secret.
-
Nome de usuário e senha
- Nome de usuário: nome de usuário para o conector
- Senha: a senha do Secret Manager que contém a senha associada ao conector.
Configurar para assinatura de eventos
Se você ativar a assinatura de eventos, será necessário configurar o SDK ABAP. Para informações sobre como configurar o SDK do ABAP, consulte Visão geral do SDK do ABAP para Google Cloud.
Insira os seguintes valores na seção Detalhes da assinatura do evento:
-
Selecione um dos seguintes tipos de autenticação para o listener de eventos.
- Autenticação do Google. Se você ativar essa opção, siga as etapas em Autenticar usando JSON Web Tokens para configurar a autenticação para o SDK do ABAP. Além disso, verifique se a conta de serviço tem o papel roles/connectors.listener, cujo token de acesso é usado para autenticação.
- Autenticação de chave de API. Se você selecionar essa opção, precisará ter criado uma chave de API e salvo a chave como um secret do Secret Manager. Para mais informações, consulte Criar uma chave de API.
-
Insira o nome do campo do tipo de evento. Esse campo identifica o tipo de evento associado à
solicitação de evento recebida.
{ "event_type": "user.created", ... // other request fields ... }
- Selecione Ativar conectividade particular para ter uma conexão segura entre o aplicativo de back-end e a conexão. Se você selecionar essa opção, será necessário realizar outras etapas de configuração depois de criar a conexão. Para mais informações, consulte Conectividade particular para assinatura de eventos.
- Insira a configuração de mensagens inativas. Se você configurar a letra inativa, a conexão vai gravar
os eventos não processados no tópico do Pub/Sub especificado. Digite os seguintes detalhes:
- ID do projeto de caixa de destino : o ID do projeto do Google Cloud em que você configurou o tópico de caixa de destino do Pub/Sub.
- Tópico de mensagem morta : o tópico do Pub/Sub em que você quer gravar os detalhes do evento não processado.
Exemplos de configuração de conexão
As seções a seguir listam os valores de exemplo para os vários campos ao criar a conexão do SAP ERP e os parâmetros necessários para os diferentes tipos de conexão.
Como se conectar a um sistema SAP distribuído
Se você se conectar a um sistema SAP distribuído, como um sistema que usa balanceamento de carga, será necessário especificar as propriedades de conexão adicionais a seguir. Um administrador pode acessar essas propriedades de conexão na guia "Conexão" da caixa de diálogo "Propriedades de entrada do sistema" no sistema SAP.
- ID do sistema: especifique o valor que você obteve da propriedade SystemId. O ID do sistema é o ID do sistema/R3Name do sistema SAP. O ID do sistema é uma string com no máximo três caracteres.
- Servidor de mensagens: ao se conectar a um sistema SAP que usa balanceamento de carga, é necessário especificar o campo "Servidor de mensagens". Defina essa propriedade como o valor que você obteve da propriedade MessageServer no sistema SAP. Além disso, adicione o valor do campo "Servidor de mensagens" ao valor da caixa "SAProuter".
- Grupo: defina essa propriedade como o valor que você obteve da propriedade "Grupo/Servidor". A propriedade "Group" especifica o grupo delogon que está sendo usado. O valor padrão é PÚBLICO.
Como se conectar a um servidor de aplicativo personalizado
Se você se conectar a um sistema SAP com um servidor de aplicativos dedicado ou personalizado, especifique as propriedades de conexão adicionais a seguir. Um administrador pode extrair essas propriedades de conexão do sistema SAP.
- ID do sistema: especifique o valor que você obteve da propriedade SystemId. Esse é o ID do sistema ou o R3Name do sistema SAP. O ID do sistema é uma string com no máximo três caracteres.
- Host: especifique o valor que você obteve do servidor de aplicativos.
Especifica o nome do host do sistema de destino. Esse valor pode ser um nome de host normal, um endereço IP ou um endereço de roteador SAP.
- Número do sistema: especifique o valor que você obteve da propriedade SystemNumber.
A propriedade SystemNumber define o sistema de destino.
Como configurar conexões de rede seguras
Se o administrador tiver configurado a comunicação segura de rede (SNC, na sigla em inglês), você precisará definir as propriedades adicionais a seguir. No sistema SAP, é possível acessar as seguintes propriedades da string de conexão SNC na guia "Rede" da caixa de diálogo "Propriedades de entrada do sistema".
- Modo SNC: se a caixa de seleção "Ativar conexões de rede seguras" estiver ativada no SAP, defina a propriedade de conexão do modo SNC como "True". Caso contrário, defina a propriedade de conexão do modo SNC como "False".
A propriedade de conexão SNCMode é um valor booleano que determina se você está usando o SNC. O valor padrão é "False".
- SNC PartnerName: especifica o nome do SNC do servidor de aplicativos. Por exemplo: p:CN=SDI, OU=IT, O=CSW, C=DE
- Nome do SNC: opcional. A propriedade SNCName especifica o nome da conexão SNC. Defina essa propriedade para garantir que o nome correto do SNC seja usado na conexão.
- SNC Qop: defina essa propriedade como a opção selecionada na seção "Configurações de rede segura". Por exemplo, se a opção "Integrity" estiver selecionada, defina a propriedade SNCQop como 3.
A propriedade SNCQop especifica o nível (ou a qualidade) da proteção de dados. Se essa propriedade não for especificada, o número inteiro -1 será definido para ela. Os valores válidos são 1, 2, 3, 8 ou 9, que correspondem aos níveis de proteção.
- ID do objeto SNC_Lib: defina essa propriedade como o caminho e o nome do arquivo da sua biblioteca SNC. Especifique o caminho completo para a biblioteca de segurança que você está usando, como
C:\Secude\secude.xll.
.
Tipo de conexão do ApplicationServer
Para a conectividade do servidor de aplicativos, o Private Service Connect e o balanceador de carga precisam ser configurados com o IP do sistema SAP e a porta 33XX no grupo de endpoints da rede (NEG) e na verificação de integridade. Em que XX é o número do sistema ou da instância do sistema SAP usado. A tabela a seguir lista os valores de configuração de exemplo para o tipo de conexão ApplicationServer
. Consulte a interface de criação de conexão no console para saber quais são os campos obrigatórios e opcionais.
Nome do campo | Valor de amostra |
---|---|
Região | us-central1 |
Conector | ERP da SAP |
Versão do conector | 1 |
Nome do conector | saperp-applicationserver-conn |
Descrição | NA |
Conta de serviço | xxxxxxxxx-compute@developer.gserviceaccount.com |
Cliente | 800 |
Número do sistema | 00 |
ID do projeto | xxxx-gcp-project |
Bucket | sap-erp-bucket |
ID do objeto Jco Jar | sapjco3.jar |
ID do objeto libsapjco3 | libsapjco3.so |
Modo de tabela | TransparentApplication/TransparentCustomer/TransparentSystem/Pooled/Cluster/None |
Função de leitura de tabela | Z_CUSTOM_READ_TABLE |
Esquema de conexão | ApplicationServer |
ID do sistema | SA1 |
Modo de consulta | NA |
Visualizações navegáveis | NA |
Nível de verbosidade | 5 |
Número mínimo de nós | 2 |
Número máximo de nós | 50 |
Endereço do host | 10.30.X.XX ou string do roteador de um sistema SAP externo. |
Autenticação | Senha de usuário inválida. |
Nome de usuário | 12345 |
Senha | xyz@12345 |
versões | 1 |
Tipo de conexão do servidor de mensagens (servidor de grupo)
Antes de se conectar a um sistema SAP com um servidor de mensagens (servidor de grupo), verifique se os seguintes pré-requisitos são atendidos:- O Private Service Connect e o balanceador de carga precisam ser configurados com o IP do sistema SAP nas portas 33XX e 36XX no grupo de endpoints da rede (NEG) e na verificação de integridade. Em que XX é o número do sistema ou da instância do sistema SAP usado.
- Você precisa criar uma zona de DNS no Cloud DNS e mapear o anexo de endpoint do servidor de aplicativos, que é configurado na porta 33XX com o nome de host do sistema SAP.
- Só é possível se conectar a um sistema SAP com um servidor de mensagens (servidor de grupo) se ele retornar o endereço do nome de domínio totalmente qualificado (FQDN) do servidor de aplicativos. Não é possível se conectar a um sistema SAP com um servidor de mensagens (servidor de grupo) se ele retornar o endereço IP.
- O servidor de mensagens precisa responder com o DNS dos servidores de aplicativos que o aplicativo precisa conectar quando o aplicativo solicitar.
- O DNS dos servidores de aplicativos precisa ser exclusivo e não pode ser usado por nenhum outro sistema SAP.
- No aplicativo SAP, os IPs de anexo de endpoint para os servidores de aplicativos e de mensagens precisam ser mantidos nos parâmetros gw/alternative_hostnames.
- Acesse Tcode - RZ10 e faça uma entrada para o parâmetro "gw/alternative_hostname" no perfil da instância.
- Defina o valor do parâmetro "ms/lg_with_hostname" como 1. Isso garante que o servidor de mensagens use nomes de host para identificar e se comunicar com os servidores de aplicativos.
- Reinicie o aplicativo SAP para que os parâmetros entrem em vigor.
A tabela a seguir lista os valores de configuração de exemplo para o tipo de conexão Group Server
:
Nome do campo | Valor de amostra |
---|---|
Região | us-central1 |
Conector | ERP da SAP |
Versão do conector | 1 |
Nome do conector | saperp-groupserver-conn |
Descrição | NA |
Conta de serviço | SA-compute@developer.gserviceaccount.com |
Cliente | 800 |
Número do sistema | 00 |
ID do projeto | Google-cloud-project |
Bucket | sap-erp-bucket |
ID do objeto Jco Jar | sapjco3.jar |
ID do objeto libsapjco3 | libsapjco3.so |
Modo de tabela | TransparentApplication/TransparentCustomer/TransparentSystem/Pooled/Cluster/None |
Grupo | PÚBLICO |
Servidor de mensagens | 10.30.X.XX |
Função de leitura de tabela | Z_CUSTOM_READ_TABLE |
Esquema de conexão | GroupServer |
ID do sistema | SA1 |
Modo de consulta | NA |
Visualizações navegáveis | NA |
Nível de verbosidade | 5 |
Número mínimo de nós | 2 |
Número máximo de nós | 50 |
Autenticação | Senha de usuário inválida. |
Nome de usuário | NOME DE USUÁRIO |
Senha | SENHA |
versões | 1 |
Tipo de conexão do certificado X509
Para comunicações de rede seguras (SNC, na sigla em inglês) com conectividade X509, o Private Service Connect e o balanceador de carga precisam ser configurados com o IP do sistema SAP e a porta 48XX no grupo de endpoints da rede (NEG) e na verificação de integridade. Em que XX é o número do sistema ou da instância do sistema SAP usado. A tabela a seguir lista os valores de configuração de exemplo para o tipo de conexão X509 certificate
. Consulte a interface de criação de conexão no console para saber quais são os campos obrigatórios e opcionais.
Nome do campo | Valor de amostra |
---|---|
Região | us-central1 |
Conector | ERP da SAP |
Versão do conector | 1 |
Nome do conector | saperp-X509Certificate-conn |
Descrição | NA |
Conta de serviço | xxxxxxxxx-compute@developer.gserviceaccount.com |
Cliente | 800 |
Número do sistema | 00 |
ID do projeto | xxxx-gcp-project |
Bucket | sap-erp-bucket |
ID do objeto Jco Jar | sapjco3.jar |
ID do objeto libsapjco3 | libsapjco3.so |
Modo de tabela | TransparentApplication/TransparentCustomer/TransparentSystem/Pooled/Cluster/None |
ID do objeto SNC_LIB | libsapcrypto.so |
Nome do PSE para criar o arquivo cred_v2 | EHP8_GCP_SA1.pse |
Função de leitura de tabela | Z_CUSTOM_READ_TABLE |
Esquema de conexão | ApplicationServer |
ID do sistema | SA1 |
Senha SNC | xyz@gcp |
Modo SNC | Um booleano que determina se você está usando o SNC. Defina como "true" para usar o SNC. |
Nome do SNC | p:CN=EHP8_GCP_SA1, OU=IT, O=CSW, C=DE |
SNC Qop | 3 |
SNC PartnerName | p:CN=SA1, OU=I0020070395, OU=SAP Web AS, O=SAP Trust Community, C=DE |
Modo de consulta | NA |
Visualizações navegáveis | NA |
Nível de verbosidade | 5 |
Número mínimo de nós | 2 |
Número máximo de nós | 50 |
Endereço do host | 10.30.X.XX ou string do roteador do sistema SAP externo. |
Autenticação | Autenticação baseada em certificado X509 |
X509Certificate | O certificado X509 pode ser especificado usando um caminho de arquivo que aponte para um arquivo que contenha um certificado X509 no formato PEM, um blob PEM que comece com o cabeçalho "-----BEGIN ..." ou um blob PEM sem o cabeçalho "-----BEGIN ...". |
versões | 1 |
Limitações do sistema
O conector do ERP do SAP pode processar 7 transações por segundo, por nó, e limita todas as transações além desse limite. Por padrão, os Integration Connectors alocam dois nós (para melhor disponibilidade) para uma conexão.
Para informações sobre os limites aplicáveis aos Integration Connectors, consulte Limites.
Usar a conexão do SAP ERP em uma integração
Depois de criar a conexão, ela fica disponível na integração da Apigee e Application Integration. É possível usar a conexão em uma integração pela tarefa de conectores.
- Para entender como criar e usar a tarefa "Connectors" na integração da Apigee, consulte Tarefa Connectors.
- Para entender como criar e usar a tarefa "Conectores" na Application Integration, consulte Tarefa "Conectores".
Entidades, operações e ações
Todos os Integration Connectors fornecem uma camada de abstração para os objetos do aplicativo conectado. Só é possível acessar os objetos de um aplicativo por esta abstração. A abstração é exposta a você como entidades, operações e ações.
- Entidade: uma entidade pode ser considerada um objeto ou um conjunto de propriedades no aplicativo ou serviço conectado. A definição de uma entidade difere de um conector para
outro. Por exemplo, em um conector de banco de dados, as tabelas são as entidades, em um conector de servidor de arquivos, as pastas são as entidades e, em um conector de sistema de mensagens, as filas são as entidades.
No entanto, é possível que um conector não aceite ou não tenha entidades. Nesse caso, a lista
Entities
estará vazia. - Operação: uma operação é a atividade que pode ser realizada em uma entidade. É possível executar
qualquer uma das seguintes operações em uma entidade:
Selecionar uma entidade na lista disponível gera uma lista de operações disponíveis para ela. Para uma descrição detalhada das operações, consulte as operações de entidades da tarefa "Conectores". No entanto, se um conector não oferecer suporte a nenhuma das operações de entidade, essas operações sem suporte não serão listadas na lista
Operations
. - Ação: uma ação é uma função de primeira classe disponibilizada para a integração por meio da interface do conector. Uma ação permite fazer alterações em uma ou mais entidades e varia de um conector para outro. Normalmente, uma ação tem alguns parâmetros de entrada e um parâmetro
de saída. No entanto, é possível que o conector não ofereça suporte a nenhuma ação. Nesse caso, a lista
Actions
estará vazia.
Ações
Esta seção fornece informações sobre os RFCs e lista as ações compatíveis com o conector. Para entender como configurar as ações, consulte Exemplos de ação.
Como usar RFCs
Esta seção fornece informações sobre os RFCs obrigatórios e como usá-los.
RFCs obrigatórios
Se algum dos RFCs necessários não estiver disponível, algumas ou todas as funcionalidades podem não funcionar. O código T-SE37 pode ser usado para conferir os módulos de função disponíveis no SAP.
As RFCs a seguir são usadas pelo conector do SAP ERP.
- DDIF_FIELDINFO_GET
- RFC_GET_FUNCTION_INTERFACE
- RFC_GET_STRUCTURE_DEFINITION
- RFC_GET_SYSTEM_INFO
- RFC_GET_UNICODE_STRUCTURE
- RFC_READ_TABLE
- SLDAG_CHECK_FOR_UNICODE
Ler dados grandes
Esta seção descreve a abordagem que você precisa seguir para ler grandes volumes de dados do back-end do SAP.
O conector do ERP do SAP usa a função SAP RFC_READ_TABLE
para extrair dados das tabelas do SAP. Essa função tem um tamanho fixo de 512 bytes. Ele pode armazenar em buffer cada linha de dados e, portanto,
não é possível selecionar mais colunas do que caberia nesse buffer. Se você selecionar mais de 512 bytes, a exceção DATA_BUFFER_EXCEEDED
vai ocorrer ao executar a integração, indicando que você excedeu o tamanho máximo de buffer permitido por linha e precisa selecionar menos colunas.
Para resolver esse problema, inclua o código de um
Custom RFC_READ_TABLE
, que é semelhante ao SAP RFC_READ_TABLE
, mas com um buffer maior para resolver o
problema DATA_BUFFER_EXCEEDED
.
Usar uma função personalizada de leitura de tabela
O conector oferece suporte a um Custom RFC_READ_TABLE
semelhante ao
SAP RFC_READ_TABLE
, mas com um buffer maior para
resolver o problema DATA_BUFFER_EXCEEDED
.
Crie uma RFC_READ_TABLE personalizada no back-end do SAP
Siga as etapas abaixo para usar o exemplo de RFC_READ_TABLE personalizado.
- Use a função
RFC_READ_TABLE
como modelo para a nova função: selecione o código de transação SE37 e o grupo de funções SDTX e copieRFC_READ_TABLE
para um novo grupo de funções ou para o grupo de funções em uso. Neste exemplo,RFC_READ_TABLE
é copiado paraZ_CUSTOM_RFC_TABLE
. - Na guia Atributos da página SAP, selecione Módulo ativado remotamente.
- Na guia Tabelas, defina o parâmetro
DATA
comoCHAR8000
. Talvez seja necessário clicar com o botão direito do mouse e depois em Exibir -> Alterar. - Na guia Source Code, insira o código RFC de leitura personalizada. Para referência, consulte exemplo Z_CUSTOM_RFC_TABLE_function.txt.
- Clique em Salvar.
- Defina as importações, tabelas e exceções conforme documentado na tabela de leitura personalizada fornecida.
- Ative o módulo de função.
Tabela de leitura personalizada para ABAP 7.52
Se você estiver usando o ABAP 7.52 ou mais recente, consulte o exemplo Z_CUSTOM_RFC_TABLE_function_ABAP752.txt.
A função de exemplo foi projetada para o ABAP versão 7.52 e mais recentes. Ela é semelhante à função Z_CUSTOM_RFC_TABLE
,
mas aproveita as novas palavras-chave disponíveis no ABAP 7.52 para executar a paginação no
banco de dados em vez de no script ABAP. Isso torna a paginação muito mais eficiente
e melhora o desempenho ao trabalhar com tabelas grandes. É recomendável usar o
Z_CUSTOM_RFC_TABLE_752 RFC
sempre que possível.
Acesso à função RFC_READ_TABLE
Esta seção fornece informações sobre a função que será atribuída a um usuário do SAP para acessar a função RFC_READ_TABLE. Essa função é um módulo de função ativada remotamente que permite acesso de leitura genérico a tabelas arbitrárias.
Para que as tabelas sejam listadas em "Entidades" ao configurar a tarefa "Conectores do SAP ERP", use a função RFC_READ_TABLE no nível de conexão do SAP ERP e autorize o acesso à função RFC_READ_TABLE do R/3.
A autorização S_TABU_DIS foi adicionada para a atividade 03 (tela) e o grupo de autorização "SC" para a função RFC_READ_TABLE.
Confira a seguir algumas das limitações técnicas de RFC_READ_TABLE:
- Somente tabelas com tipos de dados simples podem ser lidas. Não há suporte para campos STRING ou XSTRING.
- A largura máxima da linha é de 512 caracteres.
- O número de registros retornados é limitado pelos limites de memória.
Ação BAPI_MATERIAL_SAVEDATA
Essa ação permite que você realize tarefas específicas. Por exemplo, é possível usá-lo para criar ou alterar dados de material mestre no SAP ERP.
Parâmetros de entrada da ação BAPI_MATERIAL_SAVEDATA
Nome do parâmetro | Tipo de dados | Obrigatório | Descrição |
---|---|---|---|
HEADDATA | String | Sim | O parâmetro de entrada HEADDATA. |
CLIENTDATA | String | Sim | O parâmetro de entrada CLIENTDATA. |
CLIENTDATAX | String | Sim | O parâmetro de entrada CLIENTDATAX. |
MATERIALDESCRIPTION | String | Sim | A tabela MATERIALDESCRIPTION. |
Parâmetros de saída da ação BAPI_MATERIAL_SAVEDATA
Essa ação retorna o status 200 (OK) se for bem-sucedida.
Para saber como configurar a ação BAPI_MATERIAL_SAVEDATA
, consulte Exemplos de ação.
Ação ZFM_GCP_MULTIDATA_TAB
Essa ação permite que os usuários realizem tarefas específicas. Por exemplo, é possível criar dados de vários tipos no SAP ERP.
Parâmetros de entrada da ação ZFM_GCP_MULTIDATA_TAB
Nome do parâmetro | Tipo de dados | Obrigatório | Descrição |
---|---|---|---|
ReturnTables | String | Sim | Uma lista separada por vírgulas que especifica quais tabelas no módulo de função precisam ser geradas. Se não for especificado, todas as tabelas retornadas serão geradas. |
T_TABLE | String | Sim | A tabela T_TABLE. |
IM_INPUT_1 | String | Sim | O parâmetro de entrada IM_INPUT_1. |
IM_INPUT_2 | String | Sim | O parâmetro de entrada IM_INPUT_2. |
Parâmetros de saída da ação ZFM_GCP_MULTIDATA_TAB
Essa ação retorna o status 200 (OK) se for bem-sucedida.
Para saber como configurar a ação ZFM_GCP_MULTIDATA_TAB
,
consulte Exemplos de ação.
Ação PushIDoc
Essa ação permite que você realize tarefas específicas. Por exemplo, é possível transferir dados do SAP para um sistema externo.
Parâmetros de entrada da ação PushIDoc
Nome do parâmetro | Tipo de dados | Obrigatório | Descrição |
---|---|---|---|
FileType | String | Sim | O tipo de arquivo.Os valores permitidos são XML e IDoc. |
Modo | String | Sim | O modo de transferência.Os valores permitidos são "Sync" e "ASync". |
Conteúdo | String | Sim | Conteúdo do arquivo. |
Parâmetros de saída da ação PushIDoc
Essa ação retorna o status 200 (OK) se for bem-sucedida.
Para saber como configurar a ação PushIDoc
,
consulte Exemplos de ação.
Ação ExecuteCustomQuery
Essa ação permite executar uma consulta personalizada.
Para criar uma consulta salva, siga estas etapas:
- Siga as instruções detalhadas para adicionar uma tarefa de conectores.
- Quando você configurar a tarefa do conector, selecione Ações no tipo de ação que você quer realizar.
- Na lista Ação, selecione Executar consulta personalizada e clique em Concluído.
- Expanda a seção Entrada de tarefas e faça o seguinte:
- No campo Tempo limite após, digite o número de segundos de espera até que a consulta seja executada.
Valor padrão:
180
segundos - No campo Número máximo de linhas, digite o número máximo de linhas a serem retornadas do banco de dados.
Valor padrão:
25
. - Para atualizar a consulta personalizada, clique em Editar script personalizado. A caixa de diálogo Editor de script é aberta.
- Na caixa de diálogo Editor de script, insira a consulta SQL e clique em Salvar.
É possível usar um ponto de interrogação (?) em uma instrução SQL para representar um único parâmetro que precisa ser especificado na lista de parâmetros de consulta. Por exemplo, a seguinte consulta SQL seleciona todas as linhas da tabela
Employees
que correspondem aos valores especificados na colunaLastName
:SELECT * FROM Employees where LastName=?
- Se você usou pontos de interrogação na consulta SQL, adicione o parâmetro clicando em + Adicionar nome do parâmetro para cada ponto de interrogação. Ao executar a integração, esses parâmetros substituem os pontos de interrogação (?) na consulta SQL sequencialmente. Por exemplo, se você tiver adicionado três pontos de interrogação (?), deverá adicionar três parâmetros em ordem de sequência.
Para adicionar parâmetros de consulta, faça o seguinte:
- Na lista Tipo, selecione o tipo de dados do parâmetro.
- No campo Valor, insira o valor do parâmetro.
- Para adicionar vários parâmetros, clique em + Adicionar parâmetro de consulta.
- No campo Tempo limite após, digite o número de segundos de espera até que a consulta seja executada.
Se a execução for bem-sucedida, essa ação vai retornar o status 200 (OK) com um corpo de resposta que tem os resultados da consulta.
Exemplos de ação
Exemplo: criar um registro
Este exemplo cria um registro de material usando a ação BAPI_MATERIAL_SAVEDATA.
- Na caixa de diálogo
Configure connector task
, clique emActions
. - Selecione a ação
BAPI_MATERIAL_SAVEDATA
e clique em Concluído. - Na seção Entrada da tarefa da tarefa Connectors, clique em
connectorInputPayload
e insira um valor semelhante ao seguinte no campoDefault Value
:{ "HEADDATA": "{\"MATERIAL\":\"000000000000009001\",\"IND_SECTOR\":\"M\",\"MATL_TYPE\":\"HALB\",\"BASIC_VIEW\":\"X\"}", "CLIENTDATA" : "{\"MATL_GROUP\":\"00107\",\"BASE_UOM\":\"KG\"}", "CLIENTDATAX" : "{\"MATL_GROUP\":\"X\",\"BASE_UOM\":\"X\"}", "MATERIALDESCRIPTION" : "{\"LANGU\":\"E\",\"MATL_DESC\":\"Classification Google\"}" }
Se a ação for bem-sucedida, o
parâmetro de resposta connectorOutputPayload
da tarefa BAPI_MATERIAL_SAVEDATA
terá um valor semelhante a este:
[{ "RETURN_TYPE": "S", "RETURN_ID": "MM", "RETURN_NUMBER": 356, "RETURN_MESSAGE": "The material 9001 has been created or extended", "RETURN_LOG_NO": "", "RETURN_LOG_MSG_NO": 0, "RETURN_MESSAGE_V1": "9001", "RETURN_FIELD": "", "RETURN_SYSTEM": "T90CLNT090", "RESULT_TABLE": null }]
Exemplo: atualizar um registro
Este exemplo atualiza um registro de material usando a ação BAPI_MATERIAL_SAVEDATA.
- Na caixa de diálogo
Configure connector task
, clique emActions
. - Selecione a ação
BAPI_MATERIAL_SAVEDATA
e clique em Concluído. - Na seção Entrada da tarefa da tarefa Connectors, clique em
connectorInputPayload
e insira um valor semelhante ao seguinte no campoDefault Value
:{ "HEADDATA": "{\"MATERIAL\":\"000000000000009000\",\"IND_SECTOR\":\"A\",\"MATL_TYPE\":\"FHMI\",\"BASIC_VIEW\":\"X\"}", "CLIENTDATA": "{\"MATL_GROUP\":\"013\",\"BASE_UOM\":\"ST\"}", "CLIENTDATAX": "{\"MATL_GROUP\":\"X\",\"BASE_UOM\":\"X\"}", "MATERIALDESCRIPTION": "{\"LANGU\":\"E\",\"MATL_DESC\":\"Classification Googlecloud\"}" }
Se a ação for bem-sucedida, o parâmetro de resposta connectorOutputPayload
da tarefa BAPI_MATERIAL_SAVEDATA
terá um valor semelhante a este:
[{ "RETURN_TYPE": "S", "RETURN_ID": "MM", "RETURN_NUMBER": 356, "RETURN_MESSAGE": "The material 9000 has been created or extended", "RETURN_LOG_NO": "", "RETURN_LOG_MSG_NO": 0, "RETURN_MESSAGE_V1": "9000", "RETURN_PARAMETER": "", "RETURN_ROW": 0, "RETURN_FIELD": "", "RETURN_SYSTEM": "T90CLNT090", "RESULT_TABLE": null }]
Exemplo: excluir um registro
Neste exemplo, um registro de material é excluído usando a ação BAPI_MATERIAL_SAVEDATA.
- Na caixa de diálogo
Configure connector task
, clique emActions
. - Selecione a ação
BAPI_MATERIAL_SAVEDATA
e clique em Concluído. - Na seção Entrada da tarefa da tarefa Connectors, clique em
connectorInputPayload
e insira um valor semelhante ao seguinte no campoDefault Value
:{ "HEADDATA": "{\"MATERIAL\":\"000000000000009000\",\"BASIC_VIEW\":\"X\"}", "CLIENTDATA": "{\"DEL_FLAG\":\"X\"}", "CLIENTDATAX": "{\"DEL_FLAG\":\"X\"}" }
Se a ação for bem-sucedida, o parâmetro de resposta connectorOutputPayload
da tarefa BAPI_MATERIAL_SAVEDATA
terá um valor semelhante a este:
[{ "RETURN_TYPE": "S", "RETURN_ID": "MM", "RETURN_NUMBER": 356, "RETURN_LOG_NO": "", "RETURN_LOG_MSG_NO": 0, "RETURN_MESSAGE_V1": "9000", "RETURN_PARAMETER": "", "RETURN_ROW": 0, "RETURN_FIELD": "", "RETURN_SYSTEM": "T90CLNT090", "RESULT_TABLE": null }]
Exemplo: criar dados de vários tipos
Este exemplo cria dados de vários tipos usando a ação ZFM_GCP_MULTIDATA_TAB.
- Na caixa de diálogo
Configure connector task
, clique emActions
. - Selecione a ação
ZFM_GCP_MULTIDATA_TAB
e clique em Concluído. - Na seção Entrada da tarefa da tarefa Connectors, clique em
connectorInputPayload
e insira um valor semelhante ao seguinte no campoDefault Value
:{ "T_TABLE": "{\"ZACCP\":\"111\",\"ZCHAR\":\"CHARACTER1\",\"ZCLNT\":\"100\",\"ZCUKY\":\"INR\",\"ZCURR\": 200,\"ZDATS\": \"20231213\",\"ZINT1\": 45,\"ZINT2\":54,\"ZDEC\": 0.12,\"ZFLTP\": 1234,\"ZLANG\":\"E\",\"ZNUMC\":\"110\",\"ZPREC\": 3,\"ZQUAN\": 188.0,\"ZRAW\":\"01010008010101050401\",\"ZTIMS\": \"103056\",\"ZUNIT\":\"11\",\"ZINT4P\": 45,\"ZINT4\": 54,\"ZLRAW\":\"0101000801010105040100030101010300040000\"}", "IM_INPUT_1": "{\"ZACCP\":\"222\",\"ZCHAR\":\"CHARACTER1\",\"ZCLNT\":\"100\",\"ZCUKY\":\"INR\",\"ZCURR\": 200,\"ZDATS\": \"20231213\",\"ZINT1\": 45,\"ZINT2\":54,\"ZDEC\": 0.12,\"ZFLTP\": 1234,\"ZLANG\":\"E\",\"ZNUMC\":\"110\",\"ZPREC\": 3,\"ZQUAN\": 188.0,\"ZRAW\":\"01010008010101050401\",\"ZTIMS\": \"103056\",\"ZUNIT\":\"11\",\"ZINT4P\": 45,\"ZINT4\": 54,\"ZLRAW\":\"0101000801010105040100030101010300040000\"}", "IM_INPUT_2": "{\"ZSTRING\": \"HI Google\",\"ZSSTRING\": \"HI Google How are you\"}" }
Se a ação for bem-sucedida, o parâmetro de resposta connectorOutputPayload
da tarefa ZFM_GCP_MULTIDATA_TAB
terá um valor semelhante a este:
[{ "EX_OUTPUT_1_ZACCP": 222, "EX_OUTPUT_1_ZCHAR": "CHARACTER1", "EX_OUTPUT_1_ZCLNT": "100", "EX_OUTPUT_1_ZCUKY": "INR", "EX_OUTPUT_1_ZCURR": 200, "EX_OUTPUT_1_ZDATS": "2023-12-13", "EX_OUTPUT_1_ZRAW": "01010008010101050401", "EX_OUTPUT_1_ZTIMS": "10:30:56", "EX_OUTPUT_1_ZUNIT": "11", "EX_OUTPUT_1_ZINT4P": 45, "EX_OUTPUT_1_ZINT4": 54, "EX_OUTPUT_1_ZLRAW": "0101000801010105040100030101010300040000\u0000", "EX_OUTPUT_2_ZSTRING": null, "EX_OUTPUT_2_ZSSTRING": null, "RESULT_TABLE": null, "T_TABLE_ZACCP": null, "T_TABLE_ZCHAR": null, "T_TABLE_ZCLNT": null, "T_TABLE_ZQUAN": null, "T_TABLE_ZRAW": null, "T_TABLE_ZTIMS": null, "T_TABLE_ZUNIT": null },{ "EX_OUTPUT_1_ZACCP": null, "EX_OUTPUT_1_ZCHAR": null, "EX_OUTPUT_1_ZCLNT": null, "EX_OUTPUT_1_ZCUKY": null, "EX_OUTPUT_1_ZRAW": null, "T_TABLE_ZLANG": null, "T_TABLE_ZNUMC": null, "T_TABLE_ZPREC": null, "T_TABLE_ZQUAN": null, "T_TABLE_ZRAW": null, "T_TABLE_ZTIMS": null, "T_TABLE_ZUNIT": null },{ "EX_OUTPUT_1_ZACCP": null, "EX_OUTPUT_1_ZCHAR": null, "EX_OUTPUT_1_ZCLNT": null, "EX_OUTPUT_1_ZCUKY": null, "EX_OUTPUT_1_ZCURR": null, "EX_OUTPUT_1_ZDATS": null, "EX_OUTPUT_1_ZDEC": null, "EX_OUTPUT_1_ZQUAN": null, "T_TABLE_ZNUMC": 110, "T_TABLE_ZPREC": 3, "T_TABLE_ZQUAN": 188, "T_TABLE_ZRAW": "01010008010101050401", "T_TABLE_ZTIMS": "10:30:56", "T_TABLE_ZUNIT": "11" }]
Exemplo: enviar um IDoc
Este exemplo envia um IDoc para o ERP do SAP.
- Na caixa de diálogo
Configure connector task
, clique emActions
. - Selecione a ação
PushIDoc
e clique em Concluído. - Na seção Entrada da tarefa da tarefa Connectors, clique em
connectorInputPayload
e insira um valor semelhante ao seguinte no campoDefault Value
:{ "Content": "\n\n\n EDI_DC40\n 800\n 0000000008604824\n 740\n 53\n 2\n \n MATMAS05\n MATMAS\n ZLS_QA23\n LS\n ZLS_QA23\n SAPSA1\n LS\n SA1CLNT800\n 20230218\n 232556\n\n\n 005\n 000000000000000012\n 20170328\n 42039\n 20170727\n 42039\n KLVC\n FERT\n M\n 02\n BG\n 000\n 002\n 0.000\n 0.000\n KGM\n 0.000\n 0001\n 0.000\n 0.000\n 0.000\n 0.000\n 0.000\n", "FileType": "XML", "Mode": "ASync" }
Se a ação for bem-sucedida, o parâmetro de resposta connectorOutputPayload
da tarefa PushIDoc
terá um valor semelhante a este:
[{ "Result": "Success", "Message": "Push IDoc success" }]
Exemplos de operação de entidade
Esta seção mostra como realizar algumas das operações de entidade neste conector.
Exemplo: listar todos os registros
Este exemplo lista todos os registros na entidade T001
.
- Na caixa de diálogo
Configure connector task
, clique emEntities
. - Selecione
T001
na listaEntity
. - Selecione a operação
List
e clique em Concluído. - Opcionalmente, na seção Entrada de tarefa da tarefa Conectores, você pode filtrar seu conjunto de resultados especificando uma cláusula de filtro. Especifique o valor da cláusula de filtro sempre entre aspas simples (").
Exemplo: receber um registro de uma entidade
Este exemplo recebe um registro com o ID especificado da entidade T001
.
- Na caixa de diálogo
Configure connector task
, clique emEntities
. - Selecione
T001
na listaEntity
. - Selecione a operação
Get
e clique em Concluído. - Na seção Entrada da tarefa da tarefa Connectors, clique em EntityId e insira
0001
no campo Valor padrão.Aqui,
0001
é um ID de registro exclusivo na entidadeT001
.
Usar o Terraform para criar conexões
Use o recurso do Terraform para criar uma nova conexão.Para saber como aplicar ou remover uma configuração do Terraform, consulte Comandos básicos do Terraform.
Para conferir um exemplo de modelo do Terraform para criação de conexão, consulte exemplo de modelo.
Ao criar essa conexão usando o Terraform, defina as seguintes variáveis no arquivo de configuração do Terraform:
Nome do parâmetro | Tipo de dados | Obrigatório | Descrição |
---|---|---|---|
cliente | STRING | Verdadeiro | O cliente que está autenticando no sistema SAP. |
grupo | STRING | Falso | O grupo de login em uso. Isso geralmente só precisa ser especificado ao se conectar a um sistema SAP que usa balanceamento de carga. |
message_server | STRING | Falso | O servidor de mensagens precisa ser especificado ao se conectar a um sistema SAP que usa balanceamento de carga. |
read_table_function | STRING | Falso | A função a ser usada para ler dados de tabela. |
connection_scheme | ENUM | Falso | Especifica se você está se conectando a um sistema SAP com um servidor de mensagens (GroupServer) ou sem um (ApplicationServer). Os valores aceitos são: ApplicationServer, GroupServer |
system_id | STRING | Falso | O System Id ou R3Name do sistema SAP é uma string com no máximo três caracteres. Ele é usado com frequência em conexões de balanceamento de carga. |
system_number | STRING | Verdadeiro | O número pelo qual o sistema de destino é definido. Usado ao definir a propriedade de conexão do host. |
project_id | STRING | Verdadeiro | O ID do projeto do Google Cloud em que o bucket do Cloud Storage que contém o JAR do JCo da SAP está localizado. |
bucket | STRING | Verdadeiro | O nome do bucket que contém os arquivos sapjco3.jar e libsapjco3.so |
sapjco3_jar | STRING | Verdadeiro | O ID do objeto para sapjco3.jar |
libsapjco3_so | STRING | Verdadeiro | O ID do objeto para libsapjco3.so |
snc_lib | STRING | Falso | O ID do objeto para a biblioteca SNC |
snc_mode | BOOLEAN | Falso | Um booleano que determina se você está usando o SNC. Defina como "true" para usar o SNC. |
snc_name | STRING | Falso | Uma entrada opcional com o nome da sua conexão SNC. |
snc_qop | ENUM | Falso | A qualidade da proteção da sua conexão SNC.Os valores válidos são 1, 2, 3, 8 ou 9, que correspondem aos seguintes níveis de proteção: 1 Aplique apenas a autenticação. 2 Aplique a proteção da integridade (autenticação). 3 Aplicar proteção de privacidade (integridade e autenticação). 8 Aplique a proteção padrão. 9 Aplique a proteção máxima. Os valores aceitos são: 1, 2, 3, 8, 9 |
snc_partner_name | STRING | Falso | O nome do SNC do servidor de aplicativos. Essa é uma entrada obrigatória ao usar o SNC. |
query_mode | ENUM | Falso | Determina quais tabelas do SAP serão exibidas como visualizações, se houver. Os valores aceitos são: global, local, all, none |
table_mode | ENUM | Falso | Determina quais tabelas do SAP serão exibidas como visualizações, se houver. Os valores aceitos são: TransparentApplication, TransparentCustomer, TransparentSystem, Pooled, Cluster, All, None |
nível de detalhes | STRING | Falso | O nível de detalhamento da conexão varia de 1 a 5. Um nível de detalhamento mais alto registra todos os detalhes de comunicação (solicitação,resposta e certificados SSL). |
Solução de problemas na configuração local do SAP
Se o sistema SAP estiver no local, crie um balanceador de carga de proxy com NEG híbrido.
- Crie um túnel IPSec entre o sistema local e o Google Cloud com sub-redes permitidas.
- Permita a sub-rede de balanceamento de carga e a sub-rede de proxy em firewalls locais.
- Adicione todas as portas necessárias, como 33XX para conexão com o servidor do aplicativo, 36XX para conexão com o servidor de mensagens/LB e 48XX para conexão SNC-X509. Em que XX é o número do sistema ou da instância do sistema SAP. Adicione o IP necessário para o firewall na lista de permissões de entrada do projeto do Google Cloud, como o IP e a porta do LB, o IP e a porta do sistema SAP.
- Configure o balanceador de carga de rede de proxy interno regional usando o NEG híbrido. Para mais informações, consulte Balanceador de carga de rede de proxy interno regional com conectividade de NEG híbrida.
Se você encontrar um erro semelhante ao seguinte após configurar a conectividade de rede,use a solução alternativa abaixo para adicionar o IP de anexo do endpoint à lista de permissões.
Initialization of destination SAP--1910584855 failed: Connect from SAP gateway to RFC server failed connection parameters: TYPE=A DESTINATION=SAP--1910584855 ASHOST=10.128.0.43 SYSNR=00 PCS=1 LOCATION SAP-Gateway on host DELVM05S15.bcone.com / sapgw00 ERROR timeout during allocate TIME Wed Apr 3 17:24:40 2024 RELEASE 754 COMPONENT SAP-Gateway VERSION 2 RC 242 MODULE D:/depot/bas/754_REL/src/krn/si/gw/gwr3cpic.c LINE 2208 DETAIL no connect of TP sapdp00 from host 10.128.0.43 after 20 sec COUNTER 2
Glossário do SAP
SAP:o termo SAP é um termo abrangente para todas as edições SAP com suporte. Isso indica, em geral, o SAP ECC versão 6 ou mais recente. Para que o conector SAP ERP funcione, é necessária uma conexão com uma edição do SAP compatível com o SDK RFC.
Módulo de função:é um tipo de programa ou função no SAP que pode ser usado para executar quase qualquer operação. Esses módulos podem ser testados e gravados no SAP usando o TCode SE37.
RFC:uma chamada de função remota (RFC) é uma chamada para um determinado RFM/FM que pode ser executada por aplicativos externos. Isso inclui o uso de bibliotecas distribuídas pela SAP que são instaladas no servidor SAP e também podem ser baixadas em sap.com. RFMs específicos podem ou não ser mantidos em upgrades do SAP. Há RFMs padrão fornecidos pela SAP, que podem ter diferenças ou não existir em edições mais antigas. Os RFMs personalizados podem (e geralmente são) criados para oferecer suporte a integrações e precisam ser mantidos pelo cliente da SAP. Por convenção, as RFMs personalizadas começam com a letra Z.
BAPI:uma API empresarial (BAPI) é um método de API de um objeto empresarial que, por sua vez, é um módulo de função habilitado para RFC pela SAP para dar acesso às operações de locic empresarial. Por exemplo, há cerca de 60 BAPIs relacionadas apenas ao objeto Customer. Na prática, apenas alguns são usados.
Tabela SAP:é uma tabela que armazena dados no SAP. Eles não são iguais aos objetos de negócios. Por exemplo, não há uma tabela de ordens de compra no SAP. Em vez disso, há muitas tabelas que incluem dados de pedidos de compra, como EBAN, EBKN, EINA, EKPO etc. As tabelas personalizadas por convenção começam com a letra Z.
Consultas SAP:uma consulta SAP é um objeto salvo no SAP que detalha as informações a serem recuperadas de uma ou mais tabelas. Elas são usadas normalmente para gerar relatórios.
Receber ajuda da comunidade do Google Cloud
Poste suas dúvidas e converse sobre esse conector na comunidade do Google Cloud em Fóruns do Cloud.A seguir
- Entenda como suspender e retomar uma conexão.
- Entenda como monitorar o uso do conector.
- Saiba como acessar os registros do conector.