Edge para la nube privada v4.19.01
En este procedimiento, se describe cómo actualizar una instalación existente del portal de servicios para desarrolladores de Apigee (o simplemente, el portal) en las instalaciones.
Determina el procedimiento de actualización correcto
El procedimiento que usas para actualizar el portal se basa en tu instalación actual:
- Si tu instalación usa Nginx/Postgres, usa Cómo actualizar un portal con RPMs a continuación.
- Si tu instalación usa Apache/MySQL o Apache/MariaDB, consulta Convierte un portal basado en tar en uno basado en RPM.
Determina tu tipo de instalación actual
Si no estás seguro de tu tipo de instalación actual, usa el siguiente comando para determinarlo:
ls /opt
Si usas Nginx/Postgres, verás los siguientes directorios:
/opt/apigee
y/opt/nginx
.Si usas Apache/MySQL o Apache/MariaDB, estos directorios no deberían estar presentes.
/opt/apigee/apigee-service/bin/apigee-all status
Si usas Nginx/Postgres, verás el siguiente resultado:
+ apigee-service apigee-drupal-devportal status OK: apigee-drupal-devportal is up and running + apigee-service apigee-lb status apigee-service: apigee-lb: OK + apigee-service apigee-postgresql status apigee-service: apigee-postgresql: OK
apachectl -S
Si usas Apache/MySQL o Apache/MariaDB, este comando debería mostrar el directorio raíz web del portal, en el siguiente formato:
*:80 192.168.56.102 (/etc/httpd/conf/vhosts/devportal.conf:1)
Directorio de instalación predeterminado
El proceso de actualización supone que el portal se instaló en la siguiente ubicación:
- 4.17.05 y versiones posteriores:
/opt/apigee/apigee-drupal/wwwroot
- Antes de la versión 4.17.05:
/opt/apigee/apigee-drupal
(Nginx) o/var/www/html
(Apache)
Si no instalaste el portal en el directorio predeterminado, modifica las rutas de acceso en el siguiente procedimiento para usar el directorio de instalación.
Versiones de actualización compatibles
Este procedimiento de actualización es compatible con las siguientes versiones del portal:
- OPDK-17-01.x
- OPDK-17-05.x
- OPDK-17-09.x
- OPDK-18-01.x
- OPDK-18-05.x
Para determinar la versión de tu portal, abre la siguiente URL en un navegador:
http://yourportal.com/buildInfo
Antes de actualizar
En las instalaciones existentes, si modificaste algún código en Drupal Core o en módulos no personalizados, se reemplazarán las modificaciones. Esto incluye, entre otros, cualquier cambio que puedas haber hecho en .htaccess
.
Debes suponer que todo lo que esté fuera del directorio /sites
es propiedad de Drupal. Una excepción a esta regla es robots.txt
. Si este archivo existe en la raíz web, se conservará.
Antes de continuar con la instalación, crea una copia de seguridad de todo el directorio raíz web de Drupal. Después de realizar los pasos de instalación que se describen a continuación, puedes restablecer tus personalizaciones desde la copia de seguridad.
Actualiza un portal con RPM
Para actualizar el RPM del portal en un nodo, sigue estos pasos:
- Cambia al directorio de Drupal,
/opt/apigee/apigee-drupal
de forma predeterminada:cd /opt/apigee/apigee-drupal
. - Crea una copia de seguridad de tu instancia de base de datos de Drupal. El comando
pg_dump
crea una copia de la base de datos:pg_dump --dbname=devportal --host=host_IP_address --username=drupaladmin --password --format=c > /tmp/portal.dmp
Aquí:
- devportal es el nombre de la base de datos, como lo especifica la propiedad
PG_NAME
en el archivo de configuración de instalación del portal. - host_IP_address es la dirección IP del nodo del portal.
- drupaladmin es el nombre de usuario de Postgres que usa el portal para acceder a la base de datos, como lo especifica la propiedad
DRUPAL_PG_USER
en el archivo de configuración de la instalación del portal.
Se te solicitará la contraseña del usuario de Postgres, como se define en la propiedad
DRUPAL_PG_PASS
del archivo de configuración de instalación del portal.Si más adelante deseas restablecer desde la copia de seguridad, usa el siguiente comando:
pg_restore --clean --dbname=devportal --host=localhost --username=apigee < /tmp/portal.dmp
- devportal es el nombre de la base de datos, como lo especifica la propiedad
- Crea una copia de seguridad de todo el directorio raíz web de Drupal. La ubicación de instalación predeterminada es
/opt/apigee/apigee-drupal
, pero es posible que la hayas cambiado.Si no estás seguro de la ubicación de este directorio, usa el comando
drush status
o la entrada Configuration > Media > File en el menú de Drupal para determinar la ubicación del sistema de archivos público y la ruta de acceso del sistema de archivos privado (para el siguiente paso). - Crea una copia de seguridad de los archivos en
/opt/apigee/data/apigee-drupal-devportal/private
. - Configura Drupal en modo de mantenimiento:
- Selecciona Configuración en el menú de Drupal.
- En la página Configuración, selecciona Modo de mantenimiento en Desarrollo.
- Selecciona la casilla Pon el sitio en modo de mantenimiento.
- Ingresa un mensaje que los usuarios verán durante el mantenimiento.
- Selecciona Guardar configuración.
- Inhabilita SELinux como se describe en Instala la utilidad apigee-setup de Edge.
- Cambia al directorio
/opt
:cd /opt
- Para realizar una actualización en un servidor con conexión a Internet, sigue estos pasos:
- Descarga el archivo
bootstrap_4.19.01.sh
de Edge 4.19.01 a/tmp/bootstrap_4.19.01.sh
:curl https://software.apigee.com/bootstrap_4.19.01.sh -o /tmp/bootstrap_4.19.01.sh
- Instala la utilidad
apigee-service
y las dependencias de Edge 4.19.01:sudo bash /tmp/bootstrap_4.19.01.sh apigeeuser=uName apigeepassword=pWord
En el que uName y pWord son el nombre de usuario y la contraseña que recibiste de Apigee. Si omites pWord, se te pedirá que lo ingreses.
De forma predeterminada, el instalador comprueba que tengas Java 1.8 instalado. Puedes usar la opción "C" para continuar sin instalar Java.
- Descarga el archivo
- Para realizar una actualización en un servidor sin conexión a Internet, sigue estos pasos:
- Crea un repositorio local 4.19.01 como se describe en Crea un repositorio de Apigee local.
- Para instalar apigee-service desde un archivo .tar, haz lo siguiente:
- En el nodo con el repositorio local, usa el siguiente comando para empaquetar el repositorio local en un solo archivo .tar llamado
/opt/apigee/data/apigee-mirror/apigee-4.19.01.tar.gz
:/opt/apigee/apigee-service/bin/apigee-service apigee-mirror package
- Copia el archivo .tar en el nodo en el que quieres actualizar Edge. Por ejemplo, cópialo
al directorio
/tmp
en el nodo nuevo. - En el nodo nuevo, descomprime el archivo en el directorio /tmp:
tar -xzf apigee-4.19.01.tar.gz
Este comando crea un directorio nuevo, llamado repos, en el directorio que contiene el archivo .tar. Por ejemplo, /tmp/repos.
- Instala la utilidad y las dependencias
apigee-service
de Edge desde/tmp/repos
:sudo bash /tmp/repos/bootstrap_4.19.01.sh apigeeprotocol="file://" apigeerepobasepath=/tmp/repos
Ten en cuenta que debes incluir la ruta de acceso al directorio de repositorios en este comando.
- En el nodo con el repositorio local, usa el siguiente comando para empaquetar el repositorio local en un solo archivo .tar llamado
- Para instalar apigee-service con el servidor web Nginx, sigue estos pasos:
- Configura el servidor web Nginx como se describe en “Instala desde el repositorio con el servidor web de Nginx” en Cómo instalar la utilidad apigee-setup de Edge.
- En el nodo remoto, descarga el archivo
bootstrap_4.19.01.sh
de Edge a/tmp/bootstrap_4.19.01.sh
:/usr/bin/curl http://uName:pWord@remoteRepo:3939/bootstrap_4.19.01.sh -o /tmp/bootstrap_4.19.01.sh
En el ejemplo anterior, uName y pWord son el nombre de usuario y la contraseña que configuraste antes para el repositorio, y remoteRepo es la dirección IP o el nombre de DNS del nodo del repositorio.
- En el nodo remoto, instala la utilidad
apigee-service
de Edge y las dependencias:sudo bash /tmp/bootstrap_4.19.01.sh apigeerepohost=remoteRepo:3939 apigeeuser=uName apigeepassword=pWord apigeeprotocol=http://
En el ejemplo anterior, uName y pWord son el nombre de usuario y la contraseña del repositorio.
- Usa
apigee-service
para actualizar la utilidadapigee-setup
:/opt/apigee/apigee-service/bin/apigee-service apigee-setup update
- Ejecuta la utilidad de actualización en tu nodo de Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile
En el ejemplo anterior, configFile es el archivo de configuración que usaste para instalar la base de datos de Postgres. El único requisito del archivo de configuración es que el usuario “apigee” pueda acceder a él o leerlo.
- Ejecuta la utilidad de actualización en tu nodo para actualizar el portal:
/opt/apigee/apigee-setup/bin/update.sh -c dp -f configFile
En el que configFile es el archivo de configuración que usaste para instalar el portal. El único requisito del archivo de configuración es que el usuario “de Apigee” debe poder acceder a este o leerlo.
- Para ejecutar la secuencia de comandos
update.php
de Drupal, abre la siguiente URL en una ventana del navegador:http://portal_IP_DNS:8079/update.php
- Inhabilita el modo de mantenimiento:
- Selecciona Configuración en el menú de Drupal.
- En la página Configuración, selecciona Modo de mantenimiento en Desarrollo.
- Anula la selección de la casilla Colocar el sitio en modo de mantenimiento.
- Selecciona Guardar configuración.
Ten en cuenta que el directorio raíz después de la actualización es el siguiente:
/opt/apigee/apigee-drupal/wwwroot
Se completó la actualización. Si la utilidad de actualización de Apigee redujo la versión de Drupal, es posible que debas volver a ejecutar la utilidad de actualización de Drupal. Para obtener más información, consulta Cómo volver a ejecutar la actualización de Drupal.
Vuelve a ejecutar la actualización de Drupal
Si la ejecución de la utilidad de actualización de Apigee para actualizar Edge en la nube privada en realidad genera un cambio a una versión inferior de la versión de Drupal, reinstala la actualización de Drupal. Este podría ser el caso si solo actualizaste Drupal entre las actualizaciones de la nube privada.
Por ejemplo:
- Estabas ejecutando la versión 4.18.05 de Edge para la nube privada, que incluía Drupal 7.59.
- Actualizaste Drupal a la versión 7.64 debido a una actualización de seguridad obligatoria.
- Estás actualizando la nube privada a 4.19.01, que incluye Drupal 7.61.
Como se ilustra en este caso, es posible que la versión de Drupal que usa la utilidad de actualización de Apigee no haga referencia a la actualización más reciente de Drupal. Como resultado, ahora debes volver a ejecutar la actualización de Drupal para volver a la versión posterior.