SAP ERP

El conector de SAP ERP te permite realizar operaciones de inserción, eliminación, actualización y lectura en los datos de SAP ERP.

Ediciones compatibles

El conector de SAP ERP puede comunicarse con los sistemas SAP R/3 mediante los siguientes métodos:

  • Interfaz de programación de aplicaciones empresariales (BAPI)
  • Llamadas a funciones remotas (RFC)
  • Tablas de SAP
  • Consultas de SAP
  • Mensajes de IDoc
Se admiten las siguientes conexiones:
  • SAP ECC
  • SAP ERP
  • SAP R/3
  • SAP S/4HANA on-premise
  • Versión de SAP JCo.

    Este conector requiere que se proporcionen dos archivos JCo durante la creación de la conexión: sapjco3.jar y libsapjco3.so (para Unix). Puedes descargar la versión JCo 3.1.5 desde el sitio de SAP Connectors.

  • Si el sistema SAP admite una conexión RFC y las RFC requeridas están disponibles, la conexión al sistema SAP funciona. Es posible que también se admitan otras ediciones que admitan conexiones RFC.

Se puede acceder al siguiente contenido de SAP desde el conector de SAP ERP:

Tablas de SAP: Las tablas de SAP se exponen como vistas automáticamente a través de la propiedad de conexión TableMode. Especifica las tablas de SAP con las que deseas trabajar con la propiedad de conexión de Views, que anula TableMode. SAP no recomienda modificar las tablas directamente. En su lugar, se recomienda usar BAPIs para modificar los datos tabulares. No se admite la modificación directa de las tablas de SAP.

BAPI y RFC: Las BAPI y las RFC se exponen directamente como procedimientos almacenados. De forma predeterminada, todas las RFC que comienzan con la palabra clave BAPI se muestran como un procedimiento almacenado disponible.

IDoc: Los archivos de documentos intermedios (IDoc) son objetos de SAP que transportan datos de transacciones comerciales de un sistema a otro en forma de mensaje electrónico. Los IDocs transfieren datos de SAP a sistemas que no son de SAP a través de sistemas de intercambio electrónico de datos (EDI).

Para obtener más información sobre estos términos, consulta el Glosario de SAP.

Antes de comenzar

Antes de usar el conector de SAP ERP, realiza las siguientes tareas:

  • En tu proyecto de Google Cloud, haz lo siguiente:
    • Asegúrate de que la conectividad de red esté configurada. Para obtener información sobre los patrones de red, consulta Conectividad de red.
    • Otorga el rol de IAM roles/connectors.admin al usuario que configure el conector.
    • Otorga los siguientes roles de IAM a la cuenta de servicio que deseas usar para el conector:
      • roles/secretmanager.viewer
      • roles/secretmanager.secretAccessor
      • roles/storage.objectViewer

      Una cuenta de servicio es un tipo de Cuenta de Google especial que representa a un usuario no humano que debe autenticarse y tener autorización para acceder a los datos de las APIs de Google. Si no tienes una cuenta de servicio, debes crear una. Para obtener más información, consulta Crea una cuenta de servicio.

    • Habilita los siguientes servicios:
      • secretmanager.googleapis.com (API de Secret Manager)
      • connectors.googleapis.com (API de conectores)

      Para comprender cómo habilitar servicios, consulta Habilita servicios.

    Si estos servicios o permisos no se habilitaron antes para tu proyecto, se te solicitará que los habilites cuando configures el conector.

  • Si habilitas la suscripción a eventos, debes configurar el SDK de ABAP. Para obtener información sobre la configuración del SDK de ABAP, consulta Descripción general del SDK de ABAP para Google Cloud.

Configura el conector

Para configurar el conector, debes crear una conexión a tu fuente de datos (sistema de backend). Una conexión es específica de una fuente de datos. Significa que, si tienes muchas fuentes de datos, debes crear una conexión independiente para cada fuente. Para crear una conexión, sigue estos pasos:

  1. En la consola de Cloud, ve a la página Conectores de Integration > Conexiones y, luego, selecciona o crea un proyecto de Google Cloud.

    Ir a la página Conexiones

  2. Haz clic en + Crear nuevo para abrir la página Crear conexión.
  3. En la sección Ubicación, elige la ubicación para la conexión.
    1. Región: selecciona una ubicación de la lista desplegable.

      Para obtener la lista de todas las regiones compatibles, consulta Ubicaciones.

    2. Haz clic en Siguiente.
  4. En la sección Detalles de la conexión, completa lo siguiente:
    1. Conector: Selecciona SAP ERP en la lista desplegable de conectores disponibles.
    2. Versión del conector: selecciona la versión del conector de la lista desplegable de versiones disponibles.
    3. En el campo Nombre de la conexión, ingresa un nombre para la instancia de conexión.

      Los nombres de las conexiones deben cumplir con los siguientes criterios:

      • Los nombres de las conexiones pueden usar letras, números o guiones.
      • Las letras deben estar en minúsculas.
      • Los nombres de las conexiones deben comenzar con una letra y terminar con una letra o un número.
      • Los nombres de las conexiones no pueden superar los 49 caracteres.
      • En el caso de los conectores que admiten la suscripción a eventos, los nombres de las conexiones no pueden comenzar con el prefijo "goog".
    4. De manera opcional, ingresa una Descripción para la conexión.
    5. De manera opcional, habilita Cloud Logging y, luego, selecciona un nivel de registro. De forma predeterminada, el nivel de registro se establece en Error.
    6. Cuenta de servicio: Selecciona una cuenta de servicio que tenga los roles necesarios.
    7. Para usar la conexión para suscripciones a eventos, selecciona Habilitar la suscripción a eventos. Si lo haces, se mostrarán las siguientes opciones:
      • Habilitar la suscripción a eventos con entidad y acciones: Selecciona esta opción para usar la conexión en operaciones de suscripción a eventos y de conector (entidades y acciones).
      • Habilitar solo la suscripción a eventos: Selecciona esta opción para usar la conexión solo para la suscripción a eventos. Si seleccionas esta opción, haz clic en Siguiente y, luego, configura la suscripción al evento.
    8. Cliente: Es el cliente que se autentica en el sistema SAP.
    9. ID del sistema: El ID del sistema o R3Name del sistema SAP es una cadena con un máximo de tres caracteres. A menudo, se usa en conexiones de balanceo de cargas.
    10. Número de sistema: Es el número con el que se define el sistema de destino. Se usa cuando se configura la propiedad de conexión del host.
    11. ID del proyecto: Es el ID del proyecto de Google Cloud en el que reside el bucket de GCS que contiene el archivo JAR de JCo de SAP.
    12. Bucket: Es el nombre del bucket que contiene los archivos sapjco3.jar y libsapjco3.so.
    13. ID del objeto del archivo jar de Jaco: Es el ID del objeto del archivo jar de JCo.
    14. ID del objeto libsapjco3: Es el ID del objeto del archivo jar libsapjco3.
    15. Modo de tabla: Selecciona la tabla de SAP que se mostrará como una vista.
    16. Función de lectura de tablas: Es el nombre de la función que se usará para leer tablas. Para obtener más información, consulta Cómo usar una función de tabla de lectura personalizada.
    17. ID del sistema: El ID del sistema o el R3Name del sistema SAP. Puedes ingresar un máximo de 3 caracteres.
    18. Modo de consulta: Selecciona qué tablas de SAP se deben mostrar como vistas.
    19. Vistas navegables: Ingresa una lista separada por comas de las vistas que se mostrarán. Por ejemplo, ViewA,ViewB,ViewC
    20. Idioma: Establece esta propiedad en el idioma que especifiques cuando accedas a SAP. Esta propiedad es un código ISO 639-1 para el idioma que usa el sistema SAP. De forma predeterminada, se usará EN.
    21. Entradas de servicio: Son las entradas de servicio que se usarán para la conexión.
    22. Modo SNC: Selecciona esta opción para habilitar SNC para la autenticación entre los conectores de integración y tu sistema SAP. Si seleccionas esta opción, especifica los siguientes detalles:
      • ID del objeto SNC_LIB: Es el ID del objeto de la biblioteca de SNC.
      • Nombre del PSE: Es el nombre del archivo de entorno de seguridad personal (PSE) que se aplica al bucket. Un archivo PSE almacena el par de claves pública y privada, así como los certificados X.509 en una estructura ASN.1.
      • Contraseña de SNC: Selecciona el Secret de Secret Manager de la contraseña de la biblioteca de SNC.
      • Versión del Secret: Selecciona la versión del Secret.
      • Nombre de SNC: Ingresa un nombre para la conexión de SNC.
      • SNC qop: Selecciona un nivel de protección. Los siguientes son los niveles admitidos:
        • 1: Aplica solo la autenticación.
        • 2: Aplica la protección de integridad. Esto también incluye la protección de autenticación.
        • 3: Aplicar protección de la privacidad Esto también incluye la protección de integridad y autenticación.
        • 8: Aplica la protección predeterminada.
        • 9: Aplica la protección máxima.
      • Nombre del socio de SNC: Ingresa el nombre de SNC del servidor de aplicaciones.
    23. Esquema de conexión: Especifica si te conectas a un sistema SAP con un servidor de mensajes (servidor de grupos) o un servidor de aplicaciones. Para obtener información sobre los requisitos previos que debes cumplir para conectarte a un sistema SAP con un servidor de mensajes, consulta Tipo de conexión de servidor de mensajes (servidor de grupos).

      Si seleccionas GroupServer, debes especificar los siguientes detalles:

      • Servidor de mensajes: Especifica el servidor de mensajes cuando te conectes a un sistema SAP que use el balanceo de cargas.
      • Servicio de servidor de mensajes: Es el servicio de servidor de mensajes al que deseas conectarte.
      • Grupo: Es el grupo de acceso que se usa. Debes especificar esto solo cuando te conectes a un sistema SAP que use el balanceo de cargas.

      Si te conectas a un sistema SAP con un servidor de mensajes (servidor de grupos), no es necesario que especifiques la dirección del host en la sección Destinos.

    24. De manera opcional, configura los parámetros de nodo de conexión:

      • Cantidad mínima de nodos: Ingresa la cantidad mínima de nodos de conexión.
      • Cantidad máxima de nodos: Ingresa la cantidad máxima de nodos de conexión.

      Un nodo es una unidad (o réplica) de una conexión que procesa transacciones. Se requieren más nodos para procesar más transacciones para una conexión y, del mismo modo, se requieren menos para procesar menos transacciones. Para comprender cómo los nodos afectan el precio del conector, consulta Precios de nodos de conexión. Si no ingresas ningún valor, se establecen de forma predeterminada los nodos mínimos en 2 (para una mejor disponibilidad) y los nodos máximos se establecen en 50.

    25. De forma opcional, haz clic en + AGREGAR ETIQUETA para agregar una etiqueta a la conexión en forma de un par clave-valor.
    26. Haz clic en Siguiente.
  5. En la sección Destinos, ingresa los detalles del host remoto (sistema de backend) al que deseas conectarte. Si te conectas a un sistema SAP con el servidor de mensajes, no necesitas especificar la dirección del host.
    1. Tipo de destino: Selecciona un Tipo de destino.
      • Selecciona Dirección de host en la lista para especificar el nombre de host o la dirección IP del destino.
      • Si deseas establecer una conexión privada a tus sistemas de backend, selecciona Adjunto de extremo en la lista y, luego, selecciona el archivo adjunto de extremo requerido en la lista Adjunto de extremo.

      Si deseas establecer una conexión pública a tus sistemas de backend con seguridad adicional, puedes configurar direcciones IP salientes estáticas para tus conexiones y, luego, configurar tus reglas de firewall para incluir en la lista de entidades permitidas solo las direcciones IP estáticas específicas.

      Para ingresar destinos adicionales, haz clic en +Agregar destino.

    2. Haz clic en Siguiente.
  6. En la sección Autenticación, ingresa los detalles de autenticación.
    1. Selecciona un Tipo de autenticación y, luego, ingresa los detalles relevantes.

      La conexión de SAP ERP admite los siguientes tipos de autenticación:

      • Autenticación basada en certificados X509
      • Nombre de usuario y contraseña
    2. Para comprender cómo configurar estos tipos de autenticación, consulta Configura la autenticación.

    3. Haz clic en Siguiente.
  7. Si habilitaste la suscripción a eventos, aparecerá la sección Detalles de la suscripción a eventos en la página de creación de la conexión. Para comprender cómo configurar los detalles de la suscripción a eventos, consulta Cómo configurar la suscripción a eventos.
  8. Revisa: Revisa tus detalles de conexión y autenticación.
  9. Haz clic en Crear.

Configura la autenticación

Ingresa los detalles según la autenticación que desees usar.

  • Autenticación basada en X509Certificate
    • X509Certificate: Es el certificado X509 que se usa para acceder.
    • Versión del Secret: Selecciona la versión del Secret.
  • Nombre de usuario y contraseña
    • Username: Nombre de usuario para el conector
    • Password: El Secret de Secret Manager que contiene la contraseña asociada con el conector.

Configura la suscripción a eventos

Si habilitas la suscripción a eventos, debes configurar el SDK de ABAP. Para obtener información sobre la configuración del SDK de ABAP, consulta Descripción general del SDK de ABAP para Google Cloud.

Ingresa los siguientes valores en la sección Event Subscription Details:

  1. Selecciona cualquiera de los siguientes tipos de autenticación para el objeto de escucha de eventos.
  2. Ingresa el nombre del campo de tipo de evento. En este campo, se identifica el tipo de evento asociado con la solicitud de evento entrante.
    {
    "event_type": "user.created",
    ...
    // other request fields
    ...
    }
  3. Selecciona Habilitar conectividad privada para obtener una conectividad segura entre tu aplicación de backend y tu conexión. Si seleccionas esta opción, debes realizar pasos de configuración adicionales después de crear la conexión. Para obtener más información, consulta Conectividad privada para la suscripción a eventos.
  4. Ingresa la configuración de mensajes no entregados. Si configuras el buzón de mensajes no entregados, la conexión escribirá los eventos sin procesar en el tema de Pub/Sub especificado. Ingresa los siguientes detalles:
    1. ID del proyecto de buzón de destino: Es el ID del proyecto de Google Cloud en el que configuraste el tema de buzón de destino de Pub/Sub.
    2. Tema de mensajes no entregados: Es el tema de Pub/Sub en el que deseas escribir los detalles del evento no procesado.

Muestras de configuración de conexión

En las siguientes secciones, se enumeran los valores de muestra de los diversos campos cuando creas la conexión con SAP ERP y los parámetros necesarios para los diferentes tipos de conexión.

Cómo conectarse a un sistema SAP distribuido

Si te conectas a un sistema SAP distribuido, como un sistema que usa el balanceo de cargas, debes especificar las siguientes propiedades de conexión adicionales. Un administrador puede obtener estas propiedades de conexión en la pestaña Connection del diálogo System Entry Properties del sistema SAP.

  • ID del sistema: Especifica el valor que obtuviste de la propiedad SystemId. El ID del sistema es el ID del sistema/R3Name del sistema SAP. El ID del sistema es una cadena con un máximo de tres caracteres.
  • Servidor de mensajes: Cuando te conectas a un sistema SAP que usa el balanceo de cargas, debes especificar el campo Servidor de mensajes. Establece esta propiedad en el valor que obtuviste de la propiedad MessageServer en el sistema SAP. Además, agrega al principio del valor del campo Message Server el valor de la casilla SAProuter.
  • Grupo: Establece esta propiedad en el valor que obtuviste de la propiedad Grupo o servidor. La propiedad Group especifica el grupo de acceso que se usa. El valor predeterminado es PUBLIC.

Cómo conectarse a un servidor de aplicaciones personalizado

Si te conectas a un sistema SAP con un servidor de aplicaciones dedicado o personalizado, debes especificar las siguientes propiedades de conexión adicionales. Un administrador puede obtener estas propiedades de conexión desde el sistema SAP.

  • ID del sistema: Especifica el valor que obtuviste de la propiedad SystemId. Este es el ID del sistema o el R3Name del sistema SAP. El ID del sistema es una cadena con un máximo de tres caracteres.
  • Host: Especifica el valor que obtuviste del servidor de aplicaciones.

    Especifica el nombre de host del sistema de destino. Este valor puede ser un nombre de host normal, una dirección IP o una dirección del router de SAP.

  • Número de sistema: Especifica el valor que obtuviste de la propiedad SystemNumber.

    La propiedad SystemNumber define el sistema de destino.

Cómo configurar conexiones de red seguras

Si el administrador configuró la comunicación de red segura (SNC), debes establecer las siguientes propiedades adicionales. Desde el sistema SAP, puedes obtener las siguientes propiedades de cadena de conexión de SNC en la pestaña Red del diálogo Propiedades de entrada del sistema.

  • Modo SNC: Si la casilla de verificación "Activate Secure Network Connections" está habilitada en SAP, establece la propiedad de conexión del modo SNC como "True". De lo contrario, establece la propiedad de conexión del modo SNC en False.

    La propiedad de conexión SNCMode es un valor booleano que determina si usas SNC. El valor predeterminado es False.

  • SNC PartnerName: SNC PartnerName especifica el nombre de SNC del servidor de aplicaciones. Por ejemplo: p:CN=IDS, OU=IT, O=CSW, C=DE
  • Nombre del SNC: Opcional. La propiedad SNCName especifica el nombre de la conexión SNC. Establece esta propiedad para asegurarte de que se use el nombre de SNC correcto para la conexión.
  • SNC Qop: Establece esta propiedad en la opción seleccionada en la sección Configuración de red segura. Por ejemplo, si se selecciona la opción de integridad, establece la propiedad SNCQop en 3.

    La propiedad SNCQop especifica el nivel (o la calidad) de la protección de datos. Si no se especifica esta propiedad, se establece el número entero -1 para esta propiedad. Los valores válidos son 1, 2, 3, 8 o 9, que corresponden a los niveles de protección.

  • ID del objeto SNC_Lib: Establece esta propiedad en la ruta de acceso y el nombre de archivo de tu biblioteca de SNC. Especifica la ruta de acceso completa a la biblioteca de seguridad que usas, como C:\Secude\secude.xll..

Tipo de conexión de ApplicationServer

Para la conectividad del servidor de aplicaciones, Private Service Connect y el balanceador de cargas deben configurarse con la IP del sistema SAP y el puerto 33XX en el grupo de extremos de red (NEG) y la verificación de estado. Donde XX es el número de sistema o instancia del sistema SAP que se usa. En la siguiente tabla, se enumeran los valores de configuración de muestra para el tipo de conexión ApplicationServer. Consulta la interfaz de creación de conexiones en la consola para conocer los campos obligatorios y opcionales.

Nombre del campo Valor de muestra
Región us-central1
Conector SAP ERP
Versión del conector 1
Nombre del conector saperp-applicationserver-conn
Descripción N/A
Cuenta de servicio xxxxxxxxx-compute@developer.gserviceaccount.com
Cliente 800
Número de sistema 00
ID del proyecto xxxx-gcp-project
Bucket sap-erp-bucket
ID del objeto Jco Jar sapjco3.jar
ID del objeto libsapjco3 libsapjco3.so
Modo de mesa TransparentApplication/TransparentCustomer/TransparentSystem/Pooled/Cluster/None
Cómo leer la función de tabla Z_CUSTOM_READ_TABLE
Esquema de conexión ApplicationServer
ID del sistema SA1
Modo de consulta N/A
Vistas explorables N/A
Nivel de verbosidad 5
Cantidad mínima de nodos 2
Cantidad máxima de nodos 50
Dirección del host 10.30.X.XX o la cadena de router de un sistema SAP externo
Autenticación Contraseña de usuario
Nombre de usuario 12345
Contraseña xyz@12345
versions 1

Tipo de conexión del servidor de mensajes (servidor de grupos)

Antes de conectarte a un sistema SAP con un servidor de mensajes (servidor de grupos), asegúrate de que se cumplan los siguientes requisitos previos:
  • Private Service Connect y el balanceador de cargas deben configurarse con la IP del sistema SAP en los puertos 33XX y 36XX en el grupo de extremos de red (NEG) y la verificación de estado. Donde XX es el número de sistema o instancia del sistema SAP que se usa.
  • Debes crear una zona de DNS en Cloud DNS y asignar el archivo adjunto del extremo del servidor de aplicaciones, que está configurado en el puerto 33XX con el nombre de host del sistema SAP.
  • Puedes conectarte a un sistema SAP con un servidor de mensajes (servidor de grupo) solo si este muestra la dirección del nombre de dominio completamente calificado (FDQN) del servidor de aplicaciones. No puedes conectarte a un sistema SAP con un servidor de mensajes (servidor de grupo) si este muestra la dirección IP.
  • El servidor de mensajes debe responder con el DNS de los servidores de aplicaciones a los que la aplicación debe conectarse cuando lo solicite.
  • El DNS de los servidores de aplicaciones debe ser único y no debe usarse en ningún otro sistema de SAP.
  • En la aplicación de SAP, las IP de los archivos adjuntos de extremos para los servidores de aplicaciones y los servidores de mensajes se deben mantener en los parámetros gw/alternative_hostnames.
    1. Ve a Tcode - RZ10 y crea una entrada para el parámetro "gw/alternative_hostname" en el perfil de la instancia.
    2. Establece el valor del parámetro "ms/lg_with_hostname" en 1. Esto garantiza que el servidor de mensajes use nombres de host para identificarse y comunicarse con los servidores de aplicaciones.
    3. Reinicia la aplicación de SAP para que los parámetros sean efectivos.

En la siguiente tabla, se muestran los valores de configuración de muestra para el tipo de conexión Group Server:

Nombre del campo Valor de muestra
Región us-central1
Conector SAP ERP
Versión del conector 1
Nombre del conector saperp-groupserver-conn
Descripción N/A
Cuenta de servicio SA-compute@developer.gserviceaccount.com
Cliente 800
Número de sistema 00
ID del proyecto Google-cloud-project
Bucket sap-erp-bucket
ID del objeto Jco Jar sapjco3.jar
ID del objeto libsapjco3 libsapjco3.so
Modo de mesa TransparentApplication/TransparentCustomer/TransparentSystem/Pooled/Cluster/None
Grupo PÚBLICO
Servidor de mensajes 10.30.X.XX
Cómo leer la función de tabla Z_CUSTOM_READ_TABLE
Esquema de conexión GroupServer
ID del sistema SA1
Modo de consulta N/A
Vistas explorables N/A
Nivel de verbosidad 5
Cantidad mínima de nodos 2
Cantidad máxima de nodos 50
Autenticación Contraseña de usuario
Nombre de usuario NOMBRE DE USUARIO
Contraseña CONTRASEÑA
versions 1

Tipo de conexión de certificado X509

Para las comunicaciones de red seguras (SNC) con conectividad X509, Private Service Connect y el balanceador de cargas deben configurarse con la IP del sistema SAP y el puerto 48XX en el grupo de extremos de red (NEG) y la verificación de estado. Donde XX es el número de sistema o instancia del sistema SAP que se usa. En la siguiente tabla, se enumeran los valores de configuración de muestra para el tipo de conexión X509 certificate. Consulta la interfaz de creación de conexiones en la consola para conocer los campos obligatorios y opcionales.

Nombre del campo Valor de muestra
Región us-central1
Conector SAP ERP
Versión del conector 1
Nombre del conector saperp-X509Certificate-conn
Descripción N/A
Cuenta de servicio xxxxxxxxx-compute@developer.gserviceaccount.com
Cliente 800
Número de sistema 00
ID del proyecto xxxx-gcp-project
Bucket sap-erp-bucket
ID del objeto Jco Jar sapjco3.jar
ID del objeto libsapjco3 libsapjco3.so
Modo de mesa TransparentApplication/TransparentCustomer/TransparentSystem/Pooled/Cluster/None
ID del objeto SNC_LIB libsapcrypto.so
Nombre de la PSE para crear el archivo cred_v2 EHP8_GCP_SA1.pse
Cómo leer la función de tabla Z_CUSTOM_READ_TABLE
Esquema de conexión ApplicationServer
ID del sistema SA1
Contraseña de SNC xyz@gcp
Modo SNC Es un valor booleano que determina si usas SNC. Establece esta opción como "true" para usar SNC.
Nombre del SNC p:CN=EHP8_GCP_SA1, OU=IT, O=CSW, C=DE
Qop de SNC 3
SNC PartnerName p:CN=SA1, OU=I0020070395, OU=SAP Web AS, O=SAP Trust Community, C=DE
Modo de consulta N/A
Vistas explorables N/A
Nivel de verbosidad 5
Cantidad mínima de nodos 2
Cantidad máxima de nodos 50
Dirección del host 10.30.X.XX o la cadena de router del sistema SAP externo
Autenticación Autenticación basada en X509Certificate
X509Certificate El certificado X509 se puede especificar con una ruta de acceso a un archivo que contiene un certificado X509 en formato PEM, un blob PEM que comienza con el encabezado "-----BEGIN ..." o un blob PEM sin el encabezado "-----BEGIN ...".
versions 1

Limitaciones del sistema

El conector de SAP ERP puede procesar 7 transacciones por segundo por nodo y limita las transacciones que superen este límite. De forma predeterminada, los conectores de integración asignan 2 nodos (para una mejor disponibilidad) a una conexión.

Para obtener información sobre los límites aplicables a Integration Connectors, consulta Límites.

Usa la conexión de SAP ERP en una integración

Después de crear la conexión, estará disponible en la integración de Apigee y en la integración de aplicaciones. Puedes usar la conexión en una integración a través de la tarea Connectors.

  • Para comprender cómo crear y usar la tarea Connectors en la integración de Apigee, consulta Tarea Connectors.
  • Para comprender cómo crear y usar la tarea Connectors en Application Integration, consulta Tarea Connectors.

Entidades, operaciones y acciones

Todos los Integration Connectors proporcionan una capa de abstracción para los objetos de la aplicación conectada. Solo puedes acceder a los objetos de una aplicación a través de esta abstracción. La abstracción se expone como entidades, operaciones y acciones.

  • Entidades: Una entidad puede considerarse como un objeto o una colección de propiedades en la aplicación o servicio conectados. La definición de una entidad difiere de conector a conector. Por ejemplo, en un conector de bases de datos, las tablas son las entidades; en un conector de servidor de archivos, las carpetas son las entidades; en un conector de sistema de mensajería, las colas son las entidades.

    Sin embargo, es posible que un conector no admita o tenga ninguna entidad, en cuyo caso la lista Entities estará vacía.

  • Operaciones: Una operación es la actividad que puedes realizar en una entidad. Puedes realizar cualquiera de las siguientes operaciones en una entidad:

    Cuando se selecciona una entidad de la lista disponible, se genera una lista de operaciones disponibles para esa entidad. Para obtener una descripción detallada de las operaciones, consulta las operaciones de entidades de la tarea de conectores. Sin embargo, si un conector no admite ninguna de las operaciones de entidad, estas operaciones no compatibles no se incluyen en la lista Operations.

  • Acción: Una acción es una función de primera clase que está disponible para la integración mediante la interfaz de Conectores. Una acción te permite realizar cambios en una entidad o entidades y variar de un conector a otro. Por lo general, una acción tendrá algunos parámetros de entrada y un parámetro de salida. Sin embargo, es posible que un conector no admita ninguna acción, en cuyo caso la lista Actions estará vacía.

Acciones

En esta sección, se proporciona información sobre las RFC y se enumeran las acciones que admite el conector. Para comprender cómo configurar las acciones, consulta Ejemplos de acciones.

Usa RFC

En esta sección, se proporciona información sobre las RFC requeridas y su uso.

RFCs obligatorias

Si alguna de las RFC requeridas no está disponible, es posible que algunas o todas las funciones no funcionen. El código T SE37 se puede usar para ver los módulos de funciones disponibles en SAP.

El conector de SAP ERP usa las siguientes RFC.

  • 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

Cómo leer datos de gran tamaño

En esta sección, se describe el enfoque que debes seguir para leer datos grandes desde tu backend de SAP.

El conector de SAP ERP usa la función SAP RFC_READ_TABLE para obtener datos de las tablas de SAP, y esta función tiene un tamaño fijo de 512 bytes. Puede almacenar en búfer cada fila de datos y, por lo tanto, no puedes seleccionar más columnas que la cantidad que cabría en este búfer. Si seleccionas más de 512 bytes, se producirá la excepción DATA_BUFFER_EXCEEDED cuando ejecutes la integración, lo que indica que superaste el tamaño máximo de búfer permitido por fila y que debes seleccionar menos columnas.

Para solucionar este problema, puedes incluir el código de un Custom RFC_READ_TABLE, que es similar al SAP RFC_READ_TABLE, pero con un búfer más grande para abordar el problema de DATA_BUFFER_EXCEEDED.

Usa una función de lectura de tabla personalizada

El conector admite un Custom RFC_READ_TABLE similar al SAP RFC_READ_TABLE, pero tiene un búfer más grande para abordar el problema de DATA_BUFFER_EXCEEDED.

Crea una RFC_READ_TABLE personalizada en tu backend de SAP

Sigue los pasos que se indican a continuación para usar la RFC_READ_TABLE personalizada de muestra.

  1. Usa la función RFC_READ_TABLE como plantilla para la función nueva: selecciona el código de transacción SE37 y el grupo de funciones SDTX, y copia RFC_READ_TABLE en un grupo de funciones nuevo o en tu grupo de funciones de trabajo. En este ejemplo, RFC_READ_TABLE se copia en Z_CUSTOM_RFC_TABLE.
  2. En la pestaña Attributes de la página SAP, selecciona Remote Enabled Module.
  3. En la pestaña Tablas, establece el parámetro DATA en CHAR8000 (es posible que debas hacer clic con el botón derecho y, luego, en Display -> Change).
  4. En la pestaña Source Code, ingresa el código de RFC de la tabla de lectura personalizada. Como referencia, consulta sample Z_CUSTOM_RFC_TABLE_function.txt.
  5. Haz clic en Guardar.
  6. Define las importaciones, las tablas y las excepciones como se documenta en la tabla de lectura personalizada proporcionada.
  7. Activa el módulo de la función.

Tabla de lectura personalizada para ABAP 7.52

Si usas ABAP 7.52 o una versión posterior, consulta el ejemplo Z_CUSTOM_RFC_TABLE_function_ABAP752.txt. La función de ejemplo está diseñada para ABAP versión 7.52 y posteriores. Es similar a la función Z_CUSTOM_RFC_TABLE, pero aprovecha las palabras clave disponibles recientemente en ABAP 7.52 para realizar la paginación dentro de la base de datos en lugar de hacerlo en la propia secuencia de comandos de ABAP. Esto hace que la paginación sea mucho más eficiente y mejora el rendimiento cuando se trabaja con tablas grandes. Se recomienda usar Z_CUSTOM_RFC_TABLE_752 RFC cuando sea posible.

Acceso a la función RFC_READ_TABLE

En esta sección, se proporciona información sobre el rol que se debe asignar a un usuario de SAP para acceder a la función RFC_READ_TABLE. Esta función es un módulo de función habilitado de forma remota que permite el acceso de lectura genérico a tablas arbitrarias.

Para que las tablas aparezcan en Entidades mientras configuras la tarea de conectores de SAP ERP, debes usar la función RFC_READ_TABLE en el nivel de conexión de SAP ERP y tener autorización para acceder a la función RFC_READ_TABLE de R/3.

Se agregó la autorización S_TABU_DIS para la actividad 03 (visualización) y el grupo de autorización "SC" para la función RFC_READ_TABLE.

Las siguientes son algunas de las limitaciones técnicas de RFC_READ_TABLE:

  • Solo se pueden leer tablas con tipos de datos simples. No se admiten los campos STRING ni XSTRING.
  • El ancho máximo de línea es de 512 caracteres.
  • La cantidad de registros que se devuelven está limitada por los umbrales de memoria.

Acción BAPI_MATERIAL_SAVEDATA

Esta acción te permite realizar tareas específicas. Por ejemplo, puedes usarlo para crear o cambiar datos maestros de materiales en SAP ERP.

Parámetros de entrada de la acción BAPI_MATERIAL_SAVEDATA

Nombre del parámetro Tipo de datos Obligatorio Descripción
HEADDATA String El parámetro de entrada HEADDATA.
CLIENTDATA String El parámetro de entrada CLIENTDATA.
CLIENTDATAX String El parámetro de entrada CLIENTDATAX.
MATERIALDESCRIPTION String La tabla MATERIALDESCRIPTION

Parámetros de salida de la acción BAPI_MATERIAL_SAVEDATA

Esta acción muestra el estado 200 (OK) si se realiza correctamente.

Para ver ejemplos sobre cómo configurar la acción BAPI_MATERIAL_SAVEDATA, consulta Ejemplos de acciones.

Acción ZFM_GCP_MULTIDATA_TAB

Esta acción permite a los usuarios realizar tareas específicas. Por ejemplo, puedes crear datos de varios tipos de datos en SAP ERP.

Parámetros de entrada de la acción ZFM_GCP_MULTIDATA_TAB

Nombre del parámetro Tipo de datos Obligatorio Descripción
ReturnTables String Es una lista separada por comas que especifica qué tablas del módulo de funciones se deben mostrar. Si no se especifica, se mostrarán todas las tablas que se devuelvan.
T_TABLE String La tabla T_TABLE.
IM_INPUT_1 String El parámetro de entrada IM_INPUT_1.
IM_INPUT_2 String El parámetro de entrada IM_INPUT_2.

Parámetros de salida de la acción ZFM_GCP_MULTIDATA_TAB

Esta acción muestra el estado 200 (OK) si se realiza correctamente.

Para ver ejemplos sobre cómo configurar la acción ZFM_GCP_MULTIDATA_TAB, consulta Ejemplos de acciones.

Acción de PushIDoc

Esta acción te permite realizar tareas específicas. Por ejemplo, puedes transferir datos de SAP a un sistema externo.

Parámetros de entrada de la acción PushIDoc

Nombre del parámetro Tipo de datos Obligatorio Descripción
FileType String Es el tipo de archivo.Los valores permitidos son XML, IDoc.
Modo String Es el modo de transferencia.Los valores permitidos son Sync y ASync.
Contenido String Contenido del archivo.

Parámetros de salida de la acción PushIDoc

Esta acción muestra el estado 200 (OK) si se realiza correctamente.

Para ver ejemplos sobre cómo configurar la acción PushIDoc, consulta Ejemplos de acciones.

Acción ExecuteCustomQuery

Esta acción te permite ejecutar una consulta personalizada.

Para crear una consulta personalizada, sigue estos pasos:

  1. Sigue las instrucciones detalladas para agregar una tarea de conectores.
  2. Cuando configures la tarea del conector, en el tipo de acción que deseas realizar, selecciona Acciones.
  3. En la lista Acción, selecciona Ejecutar consulta personalizada y, luego, haz clic en Listo.

    imagen que muestra la acción execute-custom-query imagen que muestra la acción execute-custom-query

  4. Expande la sección Task input y haz lo siguiente:
    1. En el campo Timeout after, ingresa la cantidad de segundos que se espera hasta que se ejecute la consulta.

      Valor predeterminado: 180 segundos.

    2. En el campo Cantidad máxima de filas, ingresa la cantidad máxima de filas que se mostrarán desde la base de datos.

      Valor predeterminado: 25.

    3. Para actualizar la consulta personalizada, haz clic en Editar secuencia de comandos personalizada. Se abrirá el diálogo Editor de secuencia de comandos.

      imagen que muestra custom-sql-query imagen que muestra custom-sql-query

    4. En el diálogo Editor de secuencia de comandos, ingresa la consulta de SQL y haz clic en Guardar.

      Puedes usar un signo de interrogación (?) en una sentencia SQL para representar un solo parámetro que se debe especificar en la lista de parámetros de consulta. Por ejemplo, la siguiente consulta de SQL selecciona todas las filas de la tabla Employees que coinciden con los valores especificados para la columna LastName:

      SELECT * FROM Employees where LastName=?

    5. Si usaste signos de interrogación en tu consulta de SQL, debes agregar el parámetro haciendo clic en + Agregar nombre de parámetro para cada signo de interrogación. Mientras se ejecuta la integración, estos parámetros reemplazan los signos de interrogación (?) en la consulta SQL de forma secuencial. Por ejemplo, si agregaste tres signos de interrogación (?), debes agregar tres parámetros en orden de secuencia.

      imagen que muestra add-query-param imagen que muestra add-query-param

      Para agregar parámetros de consulta, haz lo siguiente:

      1. En la lista Tipo, selecciona el tipo de datos del parámetro.
      2. En el campo Valor, ingresa el valor del parámetro.
      3. Para agregar varios parámetros, haz clic en + Agregar parámetro de consulta.

Si la ejecución se realiza correctamente, esta acción muestra el estado 200 (OK) con un cuerpo de respuesta que tiene los resultados de la consulta.

Ejemplos de acciones

Ejemplo: Crea un registro

En este ejemplo, se crea un registro de material con la acción BAPI_MATERIAL_SAVEDATA.

  1. En el cuadro de diálogo Configure connector task, haz clic en Actions.
  2. Selecciona la acción BAPI_MATERIAL_SAVEDATA y haz clic en Listo.
  3. En la sección Task Input de la tarea Connectors, haz clic en connectorInputPayload y, luego, ingresa un valor similar al siguiente en el campo Default 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\"}"
    }
  4. Si la acción se realiza correctamente, el parámetro de respuesta connectorOutputPayload de la tarea BAPI_MATERIAL_SAVEDATA tendrá un valor similar al siguiente:

    [{
    "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
    }]

Ejemplo: Actualiza un registro

En este ejemplo, se actualiza un registro de material con la acción BAPI_MATERIAL_SAVEDATA.

  1. En el cuadro de diálogo Configure connector task, haz clic en Actions.
  2. Selecciona la acción BAPI_MATERIAL_SAVEDATA y haz clic en Listo.
  3. En la sección Task Input de la tarea Connectors, haz clic en connectorInputPayload y, luego, ingresa un valor similar al siguiente en el campo Default 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\"}"
    }
  4. Si la acción se realiza correctamente, el parámetro de respuesta connectorOutputPayload de la tarea BAPI_MATERIAL_SAVEDATA tendrá un valor similar al siguiente:

    [{
    "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
    }]

Ejemplo: Borra un registro

En este ejemplo, se borra un registro de material con la acción BAPI_MATERIAL_SAVEDATA.

  1. En el cuadro de diálogo Configure connector task, haz clic en Actions.
  2. Selecciona la acción BAPI_MATERIAL_SAVEDATA y haz clic en Listo.
  3. En la sección Task Input de la tarea Connectors, haz clic en connectorInputPayload y, luego, ingresa un valor similar al siguiente en el campo Default Value:
    {
    "HEADDATA": "{\"MATERIAL\":\"000000000000009000\",\"BASIC_VIEW\":\"X\"}",
    "CLIENTDATA": "{\"DEL_FLAG\":\"X\"}",
    "CLIENTDATAX": "{\"DEL_FLAG\":\"X\"}"
    }
  4. Si la acción se realiza correctamente, el parámetro de respuesta connectorOutputPayload de la tarea BAPI_MATERIAL_SAVEDATA tendrá un valor similar al siguiente:

    [{
    "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
    }]

Ejemplo: Crea datos de varios tipos de datos

En este ejemplo, se crean datos de varios tipos de datos con la acción ZFM_GCP_MULTIDATA_TAB.

  1. En el cuadro de diálogo Configure connector task, haz clic en Actions.
  2. Selecciona la acción ZFM_GCP_MULTIDATA_TAB y haz clic en Listo.
  3. En la sección Task Input de la tarea Connectors, haz clic en connectorInputPayload y, luego, ingresa un valor similar al siguiente en el campo Default 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\"}"
    }
  4. Si la acción se realiza correctamente, el parámetro de respuesta connectorOutputPayload de la tarea ZFM_GCP_MULTIDATA_TAB tendrá un valor similar al siguiente:

    [{
    "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"
    }]

Ejemplo: Cómo enviar un IDoc

En este ejemplo, se envía un IDoc al ERP de SAP.

  1. En el cuadro de diálogo Configure connector task, haz clic en Actions.
  2. Selecciona la acción PushIDoc y haz clic en Listo.
  3. En la sección Task Input de la tarea Connectors, haz clic en connectorInputPayload y, luego, ingresa un valor similar al siguiente en el campo Default 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"
    }
  4. . Si la acción se realiza correctamente, el parámetro de respuesta connectorOutputPayload de la tarea PushIDoc tendrá un valor similar al siguiente:

    [{
    "Result": "Success",
    "Message": "Push IDoc success"
    }]

Ejemplos de operaciones de entidades

En esta sección, se muestra cómo realizar algunas de las operaciones de la entidad en este conector.

Ejemplo: Muestra una lista de todos los registros

En este ejemplo, se enumeran todos los registros de la entidad T001.

  1. En el cuadro de diálogo Configure connector task, haz clic en Entities.
  2. Selecciona T001 en la lista Entity.
  3. Selecciona la operación List y haz clic en Listo.
  4. De forma opcional, en la sección Entrada de tarea de la tarea Conectores, puedes filtrar tu conjunto de resultados especificando una cláusula de filtro. Especifica el valor de la cláusula de filtro siempre entre comillas simples (').

Ejemplo: Cómo obtener un registro de una entidad

En este ejemplo, se obtiene un registro con el ID especificado de la entidad T001.

  1. En el cuadro de diálogo Configure connector task, haz clic en Entities.
  2. Selecciona T001 en la lista Entity.
  3. Selecciona la operación Get y haz clic en Listo.
  4. En la sección Task Input de la tarea Connectors, haz clic en EntityId y, luego, ingresa 0001 en el campo Default Value.

    Aquí, 0001 es un ID de registro único en la entidad T001.

Usa Terraform para crear conexiones

Puedes usar el recurso de Terraform para crear una conexión nueva.

Si deseas obtener más información para aplicar o quitar una configuración de Terraform, consulta los comandos básicos de Terraform.

Para ver una plantilla de Terraform de ejemplo para la creación de conexiones, consulta la plantilla de ejemplo.

Cuando crees esta conexión con Terraform, debes establecer las siguientes variables en tu archivo de configuración de Terraform:

Nombre del parámetro Tipo de datos Obligatorio Descripción
cliente STRING Verdadero El cliente que se autentica en el sistema SAP
grupo STRING Falso El grupo de acceso que se usa Por lo general, solo se debe especificar cuando se conecta a un sistema SAP que usa el balanceo de cargas.
message_server STRING Falso Se debe especificar el servidor de mensajes cuando te conectas a un sistema SAP que usa el balanceo de cargas.
read_table_function STRING Falso Es la función que se usará para leer los datos de la tabla.
connection_scheme ENUM Falso Especifica si te conectas a un sistema SAP con un servidor de mensajes (GroupServer) o sin uno (ApplicationServer). Los valores admitidos son: ApplicationServer, GroupServer
system_id STRING Falso El ID del sistema o R3Name del sistema SAP es una cadena con un máximo de tres caracteres. A menudo, se usa en conexiones de balanceo de cargas.
system_number STRING Verdadero Es el número con el que se define el sistema de destino. Se usa cuando se configura la propiedad de conexión del host.
project_id STRING Verdadero Es el ID del proyecto de Google Cloud en el que reside el bucket de Cloud Storage que contiene el archivo JAR de JCo de SAP.
bucket STRING Verdadero Es el nombre del bucket que contiene los archivos sapjco3.jar y libsapjco3.so.
sapjco3_jar STRING Verdadero El ID de objeto de sapjco3.jar
libsapjco3_so STRING Verdadero El ID del objeto para libsapjco3.so
snc_lib STRING Falso Es el ID del objeto de la biblioteca de SNC.
snc_mode BOOLEAN Falso Es un valor booleano que determina si usas SNC. Establece esta opción como "true" para usar SNC.
snc_name STRING Falso Es una entrada opcional con el nombre de tu conexión de SNC.
snc_qop ENUM Falso Es la calidad de protección de tu conexión SNC.Los valores válidos son 1, 2, 3, 8 o 9, que corresponden a los siguientes niveles de protección: 1 Aplica solo la autenticación. 2 Aplica la protección de la integridad (autenticación). 3 Aplica protección de la privacidad (integridad y autenticación). 8 Aplica la protección predeterminada. 9 Aplica la protección máxima. Los valores admitidos son 1, 2, 3, 8 y 9.
snc_partner_name STRING Falso Es el nombre del SNC del servidor de aplicaciones. Esta es una entrada obligatoria cuando se usa SNC.
query_mode ENUM Falso Determina qué tablas de SAP se mostrarán como vistas, si las hay. Los valores admitidos son: Global, Local, Todos y Ninguno.
table_mode ENUM Falso Determina qué tablas de SAP se mostrarán como vistas, si las hay. Los valores admitidos son: TransparentApplication, TransparentCustomer, TransparentSystem, Pooled, Cluster, All, None
verbosidad STRING Falso Es el nivel de verbosidad de la conexión, que varía de 1 a 5. Un nivel de verbosidad más alto registrará todos los detalles de la comunicación (solicitud,respuesta y certificados SSL).

Soluciona problemas de configuración de SAP en las instalaciones

Si tu sistema SAP está alojado de forma local, debes crear un balanceador de cargas de proxy con NEG híbrido.

  1. Crea un túnel IPsec entre el sistema local y Google Cloud con subredes permitidas.
  2. Permite la subred de balanceo de cargas y la subred de proxy en los firewalls locales.
  3. Agrega todos los puertos necesarios, como 33XX para la conexión del servidor de aplicaciones, 36XX para la conexión del servidor de mensajes o del servidor de balanceo de cargas y 48XX para la conexión SNC-X509. Donde XX es el número de sistema o instancia del sistema SAP. Agrega la IP requerida para el firewall en la lista de entidades permitidas de entrada del proyecto de Google Cloud, como la IP y el puerto del LB, y la IP y el puerto del sistema SAP.
  4. Configura un balanceador de cargas de red del proxy interno regional con NEG híbrido. Para obtener más información, consulta Balanceador de cargas de red de proxy interno regional con conectividad de NEG híbrida.

Si encuentras un error similar al siguiente después de configurar la conectividad de red,usa la solución alternativa que se indica a continuación para incluir en la lista de entidades permitidas la IP del archivo adjunto del extremo.

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
Solución: Agrega la IP del archivo adjunto del extremo de red del conector que creaste en Google Cloud en gw/alternative_hostnames en el nivel del perfil de SAP.

Glosario de SAP

SAP: El término SAP es un término general para todas las ediciones de SAP compatibles. En general, esto indica la versión 6 o posterior de SAP ECC. Para que funcione el conector de SAP ERP, se requiere una conexión a una edición de SAP que admita el SDK de RFC.

Módulo de funciones: Es un tipo de programa o función en SAP que se puede usar para ejecutar casi cualquier operación. Estos módulos se pueden probar y escribir en SAP a través del código T SE37.

RFC: Una llamada a función remota (RFC) es una llamada a un RFM/FM determinado que pueden ejecutar aplicaciones externas. Esto incluye el uso de bibliotecas distribuidas por SAP que se instalan en el servidor de SAP y que también se pueden descargar desde sap.com. Es posible que los RFM específicos se mantengan o no en las actualizaciones de SAP. SAP proporciona RFM estándares que pueden tener diferencias o no existir en ediciones anteriores. Los RFM personalizados se pueden compilar (y, a menudo, se compilan) para admitir integraciones y el cliente de SAP debe mantenerlos. Por convención, los RFM personalizados comienzan con la letra Z.

BAPI: Una API empresarial (BAPI) es un método de API de un objeto empresarial que, a su vez, es un módulo de funciones habilitado para RFC de SAP para brindar acceso a operaciones de lógica empresarial. Por ejemplo, hay alrededor de 60 BAPIs relacionados únicamente con el objeto Customer. En la práctica, por lo general, solo se usan algunos.

Tabla de SAP: Es una tabla que almacena datos en SAP. No son lo mismo que los objetos empresariales. Por ejemplo, no hay una tabla de órdenes de compra en SAP. En cambio, hay muchas tablas que incluyen datos de pedidos de compra, como EBAN, EBKN, EINA, EKPO, etcétera. Por convención, las tablas personalizadas comienzan con la letra Z.

Consultas de SAP: Una consulta de SAP es un objeto guardado en SAP que detalla la información que se recuperará de una o más tablas. Por lo general, se usan para generar informes.

Obtén ayuda de la Comunidad de Google Cloud

Puedes publicar tus preguntas y debatir sobre este conector en la comunidad de Google Cloud en Cloud Forums.

¿Qué sigue?