Evento
Construír aplicacións e axentes de IA
Mar 17, 9 PM - Mar 21, 10 AM
Únete á serie de encontros para construír solucións de IA escalables baseadas en casos de uso do mundo real con compañeiros desenvolvedores e expertos.
Rexistrar agoraEste explorador xa non é compatible.
Actualice a Microsoft Edge para dispoñer das funcionalidades máis recentes, as actualizacións de seguranza e a asistencia técnica.
En este artículo se describe lo que hay que tener en cuenta si desea migrar una aplicación de WebSphere Application Server (WAS) tradicional existente para que se ejecute en máquinas virtuales de Azure. Para obtener una visión general de las soluciones tradicionales WAS disponibles en Azure Marketplace, consulte ¿Cuáles son las soluciones para ejecutar la familia de productos IBM WebSphere en Azure?
Para asegurarse de que la migración se realiza correctamente, antes de empezar, complete los pasos de evaluación e inventario descritos en las secciones siguientes.
Esta guía, y las ofertas de Azure Marketplace correspondientes, son un punto de partida para acelerar la migración de las cargas de trabajo tradicionales de WAS a Azure. Es importante definir el ámbito del trabajo de migración. Por ejemplo, ¿está realizando una migración lift-and-shift estricta de la infraestructura existente a Azure Virtual Machines? Si es así, es posible que se sienta la tentación de realizar algunas mejoras mientras realiza la migración.
En la medida de lo posible, es mejor centrarse en un traslado lift-and-shift, teniendo en cuenta los cambios necesarios que se indican en esta guía. Defina lo que quiere decir con "migración completa" para que sepa cuándo ha alcanzado el objetivo. Cuando haya realizado la "migración completa", puede hacer una instantánea de sus máquinas virtuales, tal y como se describe en Creación de una instantánea de un disco duro virtual. Cuando haya comprobado que puede realizar la restauración correctamente desde la instantánea, puede realizar las mejoras sin miedo a perder el progreso de la migración que ha conseguido hasta ahora.
El primer paso para migrar una aplicación WAS a Azure con éxito es seleccionar el destino de migración más adecuado.
WAS tradicional funciona bien en máquinas virtuales Azure. El destino de la máquina virtual (VM) es la opción más fácil, ya que se asemeja más a una implementación local. La experiencia administrativa y de implementación de las máquinas virtuales es similar a la de las instalaciones locales.
Otra opción es migrar a contenedores convirtiendo la carga de trabajo tradicional de WAS en contenedores de aplicaciones. Puede ejecutar el objetivo de contenedor en Azure Kubernetes Service (AKS) y Red Hat OpenShift en Azure. El inconveniente de esta facilidad es el coste económico.
En general, el coste por minuto de una solución basada en VM es mayor en comparación con los contenedores. Mientras que una solución basada en contenedores cuesta menos de ejecutar, debe restringir su aplicación para que se ajuste a los requisitos de la plataforma de orquestación de contenedores.
Si minimizar el cambio es el factor más importante para su esfuerzo de migración, considere una migración basada en máquinas virtuales. En este caso, consulte Migración de aplicaciones WebSphere a máquinas virtuales de Azure.
Si puede tolerar convertir su aplicación para que se ejecute dentro de contenedores para reducir el coste del tiempo de ejecución, considere una migración basada en AKS o en Red Hat OpenShift en Azure.
Para la migración basada en AKS, puede empezar utilizando el nivel gratis. Obtenga una gestión de clúster gratuita y pague únicamente por las máquinas virtuales, el almacenamiento asociado y los recursos de conexión de red consumidos. En este caso, consulte Migración de aplicaciones WebSphere a Kubernetes Service de Azure.
Para la migración basada en Red Hat OpenShift en Azure, además de los costes de computación e infraestructura, los nodos de aplicación tienen otro coste por el componente de licencia de OpenShift. Este coste se factura en función del número de nodos de aplicación y del tipo de instancia. Use precios a petición o instancias reservadas, lo que mejor satisfaga las necesidades de su carga de trabajo y negocio. En este caso, consulte Migración de aplicaciones WebSphere a Red Hat OpenShift en Azure.
Las guías prácticas de la documentación de Red Hat OpenShift en Azure cubren algunos aspectos relevantes para la migración. Para obtener la lista completa de guías prácticas, consulte la documentación de Red Hat OpenShift en Azure.
IBM y Microsoft se han asociado para incorporar a Azure Marketplace un conjunto de plantillas de soluciones de Azure que ofrecen un punto de partida sólido para la migración a Azure. Para obtener la lista de ofertas, consulte Ejecutar la familia de productos WebSphere y Liberty en Microsoft Azure y, a continuación, elija la que más se ajuste a su implementación actual. Puede consultar el listado de ofertas en el artículo general ¿Qué soluciones existen para ejecutar la familia de productos IBM WebSphere en Azure?
Si ninguna de las ofertas existentes es un buen punto de partida, tendrá que reproducir la implementación a mano con los recursos de Azure Virtual Machines. Puede encontrar la guía paso a paso en Tutorial: Instalar manualmente IBM WebSphere Application Server Network Deployment tradicional en máquinas virtuales de Azure. Para más información, consulte ¿Qué es IaaS?
La versión existente de WAS traditional debe ser compatible con la versión de las ofertas de IaaS. Puede encontrar la información de la versión en la página de resumen de IBM WebSphere Application Server Single Instance en máquinas virtuales de Azure e IBM WebSphere Application Server Cluster en máquinas virtuales de Azure. Si la versión WAS tradicional existente no es compatible con esa versión, tendrá que reproducir la implementación a mano con los recursos de IaaS de Azure. Para más información, consulte ¿Qué es IaaS?
Documente el hardware (memoria, CPU, disco) de los servidores de producción actuales, así como el promedio y máximo del número de solicitudes y el uso de recursos. Esta información se utilizará para elegir el tamaño de las máquinas virtuales. Para obtener más información, consulte Tamaños de Cloud Services.
Antes de la llegada de las tecnologías de "configuración como servicio", como Azure Key Vault, no había un concepto bien definido de "secretos". En su lugar, hay un conjunto dispar de opciones de configuración que funcionaban de forma eficaz como lo que ahora llamamos "secretos". Con los servidores de aplicaciones como WAS, estos secretos se encuentran en muchos archivos y almacenes de configuración diferentes. Compruebe los secretos y las contraseñas en todas las propiedades y los archivos de configuración de los servidores de producción. Los archivos de configuración que contienen contraseñas o credenciales también se pueden encontrar dentro de la aplicación. WAS almacena los datos de configuración en varios documentos en una jerarquía de directorios en cascada. La mayoría de los documentos de configuración tienen contenido XML. Para obtener más información, consulte Documentos de configuración y Conceptos básicos de Azure Key Vault.
Documente todos los certificados usados para los puntos de conexión SSL públicos. Para ver todos los certificados de los servidores de producción, ejecute el siguiente comando:
keytool -list -v -keystore <path to keystore>
Para obtener más información, consulte el documento de IBM Administración de certificados en SSL.
El uso de WAS en máquinas virtuales de Azure requiere una versión específica de Java, por lo que deberá confirmar que la aplicación se ejecuta correctamente con esa versión compatible.
IBM Java 8 incluye la distribución WAS9. Se recomienda usar java JRE proporcionado por IBM. Para obtener más información, consulte Java SE 8 en WebSphere Application Server tradicional V9.
Si desea cambiar a un Java SDK diferente, siga el documento de IBM Cambio del SDK de Java en WebSphere Application Server.
Realice un inventario de todos los recursos de JNDI. Por ejemplo, los orígenes de datos tales como las bases de datos pueden tener un nombre de JNDI asociado que permita a JPA enlazar correctamente instancias de EntityManager
con una base de datos determinada. Para obtener más información sobre recursos JNDI y bases de datos, consulte Fuentes de datos WebSphere en la documentación de IBM. Otros recursos relacionados con JNDI, como los agentes de mensajes JMS, pueden requerir una migración o reconfiguración. Para obtener más información sobre la configuración de JMS, consulte Uso de recursos JMS.
La principal unidad de configuración en WAS es el perfil. Como tal, el archivo resources.xml contiene una gran cantidad de configuración que debe considerar cuidadosamente para la migración. El archivo incluye referencias a más archivos XML que se almacenan en subdirectorios. IBM aconseja que normalmente use la Consola de IBM para configurar los objetos y servicios administrables de WAS, y permita que WAS mantenga la carpeta profiles/profile-name. Para obtener más información, consulte Administración de perfiles en sistemas operativos distribuidos e IBM i.
Inspeccione el archivo deployment.xml o el archivo WEB-INF/web.xml.
Si su aplicación depende de la replicación de sesiones, dispone de las siguientes opciones:
Para todas estas opciones, es una buena idea dominar cómo WAS realiza la replicación del estado de sesión HTTP. Para obtener más información, consulte Administración de beans de sesión en la documentación de IBM.
Si su aplicación usa bases de datos, debe capturar la siguiente información:
Para más información sobre controladores JDBC en WAS, consulte Uso de controladores JDBC con WebSphere Application Server.
Determine cuáles de las siguientes personalizaciones se han realizado y capture lo que se ha hecho.
systemd
para hacer que los componentes de WAS se inicien automáticamente tras un reinicio del servidor?Debe tener en cuenta las consideraciones de migración en función de las respuestas a estas preguntas.
Si su aplicación necesita acceder a cualquiera de los servicios locales, deberá aprovisionar uno de los servicios de conectividad de Azure. Para más información, consulte Connect an on-premises network to Azure (Conexión de una red local a Azure). También tendrá que refactorizar la aplicación para que use las API disponibles públicamente que exponen los recursos locales.
Si su aplicación utiliza colas o temas JMS, debe migrarlos a un servidor JMS alojado externamente. Una estrategia para aquellos que utilizan JMS es utilizar Azure Service Bus y el protocolo Advanced Message Queuing Protocol. Para obtener más información, consulte Uso de Java Message Service 1.1 con Azure Service Bus estándar y AMQP 1.0.
Si ha configurado almacenes persistentes JMS, debe capturar su configuración y aplicarla después de la migración.
Si usa IBM MQ, puede migrar este software a máquinas virtuales de Azure y utilizarlo tal cual.
Microsoft dispone de una solución para integrar IBM MQ con Logic Apps. Para obtener más información, consulte Conexión a un servidor de IBM MQ desde un flujo de trabajo en Azure Logic Apps.
Si utiliza la característica de biblioteca de Java EE compartida, tiene dos opciones:
Si ha utilizado bundles OSGi añadidos al WAS, deberá añadir los archivos JAR equivalentes directamente a su aplicación web.
Si la aplicación contiene código con dependencias en el sistema operativo del host, deberá refactorizarla para quitar esas dependencias. Por ejemplo, es posible que tenga que reemplazar cualquier uso de /
o \
en las rutas del sistema de archivos con File.Separator
o Paths.get
si la aplicación se ejecuta en Windows.
Si su aplicación utiliza IBM Integration Bus, debe capturar cómo está configurado IBM Integration Bus. Para obtener más información, consulte la documentación de IBM Integration Bus.
Si la aplicación se compone de varios WAR, debe tratar cada uno como aplicaciones independientes y seguir esta guía para cada una de ellas.
Si su aplicación está empaquetada como un archivo EAR, asegúrese de examinar los archivos application.xml, ibm-application-bnd.xmi e ibm-application-ext.xmi y capturar sus configuraciones. Para obtener más información, consulte Diseño del paquete de archivo empresarial (EAR) en WebSphere.
Si tiene procesos que se ejecutan fuera del servidor de aplicaciones, como los demonios de supervisión, tendrá que eliminarlos o migrarlos a otro lugar.
Los sistemas de archivos de las máquinas virtuales funcionan de la misma manera que los sistemas de archivos locales en cuanto a la persistencia, el inicio y el apagado. Sin embargo, es importante tener en cuenta las necesidades del sistema de archivos y asegurarse de que las máquinas virtuales tengan el tamaño y la capacidad de almacenamiento adecuados.
Si su aplicación actualmente sirve contenido estático, necesitará una ubicación alternativa para él. Quizás quiera considerar la posibilidad de mover el contenido estático a Azure Blob Storage y agregar Azure CDN para tener descargas de alta velocidad globalmente. Para más información, consulte Hospedaje de sitios web estáticos en Azure Storage e Inicio rápido: Integración de una cuenta de una instancia de Azure Storage con Azure CDN.
Si su aplicación permite que haya contenido estático que la aplicación carga o produce, pero que es inmutable una vez creado, puede usar Azure Blob Storage y Azure CDN con una función de Azure para controlar las cargas y la actualización de la red CDN. Hemos proporcionado una implementación de ejemplo para su uso en Cargar y carga previa en CDN de contenido estático con Azure Functions.
El conjunto actual de ofertas de Azure Marketplace es un punto de partida para su migración. Si la oferta no cubre aspectos de su arquitectura que necesita migrar, necesita capturar la topología de red de su implementación existente. A continuación, debe reproducir esa topología de red en Azure, incluso después de configurar la oferta básica con una de las plantillas de soluciones.
La topología de red es un tema amplio, pero las siguientes referencias pueden orientar sus esfuerzos de migración:
Si su aplicación existente usa adaptadores JCA u otros adaptadores de recursos para conectarse a otros sistemas empresariales, asegúrese de aplicar la configuración para estos artefactos al WAS que se ejecuta en las máquinas virtuales Azure. Para obtener más información, consulte Adaptadores de recursos relacionales y JCA en la documentación de IBM.
La mayoría de las aplicaciones tienen algún tipo de autenticación y autorización. Si usa OpenID para la autenticación, puede configurar la autenticación de OpenID connect con Microsoft Entra ID. Para obtener más información, consulte Autenticación de OpenID Connect con Microsoft Entra ID.
Lo más probable es que haya implementado la aplicación en varios servidores de WAS para lograr alta disponibilidad. Puede migrar estos clústeres directamente desde su instalación local a WAS para que se ejecuten en máquinas virtuales de Azure. Para obtener más información, consulte WebSphere Application Server Network Deployment en la documentación de IBM.
El equilibrio de carga es una parte esencial de la migración del clúster de WAS a Azure. La solución más sencilla es utilizar el soporte integrado para Azure Application Gateway o IBM HTTP Server proporcionado en la oferta de Azure Marketplace para IBM WebSphere Application Server Cluster.
Para ver un resumen de las funcionalidades de Azure Application Gateway en comparación con otras soluciones de equilibrio de carga de Azure, consulte Opciones de equilibrio de carga.
Si su aplicación usa la característica de cliente de aplicación de Java EE, debería continuar funcionando sin cambios después de migrar a Azure Virtual Machines. Para más información, consulte cómo usar los módulos de aplicación de cliente de Java EE.
Las siguientes ofertas están disponibles para WAS en máquinas virtuales de Azure.
Durante la implementación de una oferta, se le pedirá que elija el tamaño de máquina virtual para los nodos de WAS. Es importante tener en cuenta todos los aspectos (memoria, procesador y disco) a la hora de elegir el tamaño de la máquina virtual. Para obtener más información, consulte Tamaños de Cloud Services (clásico).
Instancia única de IBM WebSphere Application Server en máquina virtual Azure
Esta oferta automatiza la mayoría de los pasos para aprovisionar una única instancia de WebSphere en una máquina virtual Azure. Crea un perfil de servidor de aplicaciones con la consola de administración de WAS.
Clúster de servidores de aplicaciones IBM de WebSphere en máquinas virtuales de Azure
Esta oferta automatiza la mayoría de los pasos para aprovisionar un clúster WebSphere en máquinas virtuales Azure. Crea un administrador de implementación con la consola de administración de WAS en una máquina virtual Azure y el número necesario de agentes de nodo en máquinas virtuales Azure separadas.
Una vez seleccionada la oferta con la que desea empezar, aprovisione dicha oferta siguiendo las instrucciones de Implementación de clúster de WebSphere Application Server (tradicional) en máquinas virtuales Azure.
Una vez aprovisionada la oferta, puede examinar la configuración de los perfiles. Para obtener más información, consulte Conceptos de perfil en la documentación de IBM.
Después de haber migrado los perfiles, puede conectar las bases de datos siguiendo las instrucciones de Configurar el origen de datos de WebSphere Application Server en la documentación de IBM.
Debe tener en cuenta la migración de los almacenes de claves SSL que use la aplicación. Para obtener más información, consulte Configuraciones de almacén de claves para SSL en la documentación de IBM.
Una vez conectadas las bases de datos, puede configurar JMS siguiendo las instrucciones de Configuración de JMS en IBM WebSphere Application Server en la documentación de IBM.
La mayoría de las aplicaciones tienen algún tipo de autenticación y autorización. Si usa OpenID para la autenticación, puede configurar la autenticación de OpenID connect con Microsoft Entra ID. Para obtener más información, consulte Autenticación de OpenID Connect con Microsoft Entra ID.
Puede configurar Elastic Stack siguiendo las instrucciones de Análisis de registros de WebSphere Application Server con Elastic Stack en la documentación de IBM. Azure ofrece un gran soporte para Elastic. Para obtener más información, consulte ¿Qué es la integración de Elastic con Azure? Puede combinar los conocimientos de estos dos recursos para conseguir una solución de registro optimizada para Azure para WAS en máquinas virtuales.
Las técnicas que se usan para implementar las aplicaciones del equipo de desarrollo en servidores de prueba, de ensayo y de producción varían mucho en cada caso. En algunos casos, hay una plataforma de CI/CD muy evolucionada que permite implementar las aplicaciones en el servidor de WebSphere Application. En otros casos, el proceso puede ser más manual. Una ventaja de usar Azure Virtual Machines para migrar aplicaciones de WAS tradicional a la nube es que los procesos existentes seguirán funcionando.
Tendrá que configurar el grupo de seguridad de red que aprovisiona la oferta para poder acceder desde la canalización de CI/CD o el sistema de implementación manual. Para más información, consulteGrupo de seguridad de red.
Debe configurar cualquier prueba de las aplicaciones en el contenedor para tener acceso a los nuevos servidores que se ejecutan en Azure. Al igual que en el caso de CI/CD, debe asegurarse de que las reglas de seguridad de red necesarias permiten que las pruebas tengan acceso a las aplicaciones implementadas en Azure. Para más información, consulteGrupo de seguridad de red.
Una vez alcanzados los objetivos de migración que se han definido antes de la migración, realice pruebas integrales de aceptación para comprobar que todo funciona según lo previsto. Para obtener orientación sobre algunas posibles mejoras posteriores a la migración, consulte las siguientes recomendaciones:
Uso de Azure Storage para servir el contenido estático montado en las máquinas virtuales. Para obtener más información, consulte Conexión o desconexión de un disco de datos para una máquina virtual de laboratorio en Azure DevTest Labs.
Implemente las aplicaciones en el clúster de WAS migrado con Azure DevOps. Para obtener más información, consulte la documentación de introducción a Azure DevOps.
Si implementó WAS tradicional con Azure Application Gateway, es posible que desee realizar más configuraciones en el Application Gateway. Para más información, consulte Introducción a la configuración de Application Gateway.
Mejorar la topología de red con servicios avanzados de equilibrio de carga. Para más información, consulte Uso de servicios de equilibrio de carga en Azure.
Usar Azure Managed Identities para gestionar secretos y asignar acceso basado en roles a los recursos de Azure. Para obtener más información, consulta ¿Qué son las identidades administradas para recursos de Azure?
Integre la autenticación y autorización de WAS Java EE con el Microsoft Entra ID. Para obtener más información, consulte Guía de introducción a la integración de Microsoft Entra ID con aplicaciones.
Usar Azure Key Vault para almacenar toda la información que funcione como un "secreto". Para más información, consulte Conceptos básicos de Azure Key Vault.
Evento
Construír aplicacións e axentes de IA
Mar 17, 9 PM - Mar 21, 10 AM
Únete á serie de encontros para construír solucións de IA escalables baseadas en casos de uso do mundo real con compañeiros desenvolvedores e expertos.
Rexistrar agoraFormación
Camiño de aprendizaxe
Procedimientos recomendados para aplicaciones de Java en Azure - Training
Empiece aquí y descubra cómo puede supervisar, automatizar, ajustar, escalar automáticamente, proteger e implementar aplicaciones de Java en Azure. Como siempre, use sus herramientas y marcos favoritos: Spring, Tomcat, WildFly, JBoss, WebLogic, WebSphere, Maven, Gradle, IntelliJ, Eclipse, Jenkins, Terraform y otros.
Certificación
Microsoft Certified: Azure for SAP Workloads Specialty - Certifications
Muestre la planeación, la migración y el funcionamiento de una solución de SAP en Microsoft Azure mientras aprovecha los recursos de Azure.