Bienvenido(a) a Alcance Libre 17/08/2022, 23:14
Es un hecho que CentOS 6 y Red Hat™ Enterprise Linux 6 se ha convertido en una plataforma envejecida y casi obsoleta gracias a los requerimientos de las aplicaciones modernas, como Moodle 2.7/2.8/2.9 o ownCloud 8.0. Es por tal motivo que hemos creado un nuevo almacén YUM sólo para CentOS 6 y Red Hat™ Enterprise Linux 6.
Porque es la versión actual para producción utilizada por CentOS 7 y Red Hat™ Enterprise Linux 7. Si la aplicación funciona perfectamente o fue diseñada para funcionar en esos sistemas operativos, lo hará también en CentOS 6 o Red Hat™ Enterprise Linux 6 con AL-Server-Plus.
CentOS 6 y Red Hat™ Enterprise Linux 6 utilizan libselinux 2.0.94. Postgres 9.2 requiere libselinux >= 2.0.99 y PostegreSQL 9.3 en adelante requiere libselinux >= 2.1 para poder compilar con soporte para SELinux. Compilar sin soporte para SELinux sería distribuir invariablemente paquetes con menos seguridad que la que incluyen actualmente los paquetes oficiales de PostgreSQL 8.4.
Lo es para todos los paquetes de las aplicaciones involucradas excepto para MariaDB y PostgreSQL.
MariaDB 5.5 reemplazará a MySQL 5.1. Se requiere habilitar primero una política extra para SELinux, cuyo procedimiento describo con mayor detalle en el este enlace.
Instale el paquete policycoreutils-python:yum -y install policycoreutils-python
Genere un nuevo directorio denominado /usr/share/selinux/packages/mariadb:mkdir -p /usr/share/selinux/packages/mariadb
Cambie al directorio /usr/share/selinux/packages/mariadb:cd /usr/share/selinux/packages/mariadb
Descargue el archivo http://www.alcancelibre.org/linux/secrets/mariadb.te:wget http://www.alcancelibre.org/linux/secrets/mariadb.te
Genere el archivo de módulo para SELinux (mariadb.mod) ejecutando checkmodule del siguiente modo:checkmodule -M -m -o mariadb.mod mariadb.te
Empaquete el archivo mariadb.mod como el archivo mariadb.pp:semodule_package -o mariadb.pp -m mariadb.mod
Vincule el archivo mariadb.pp obtenido con las políticas actuales de SELinux y cargue éstas en el núcleo en ejecución:semodule -i /usr/share/selinux/packages/mariadb/mariadb.pp
Respalde todas las bases de datos:mysqldump --opt -uroot -pcontraseña --all-databases > ~/repaldo-todo-mysql.sql
Respalde el archivo de configuración /etc/my.cnf:cp -a /etc/my.cnf /etc/my.cnf.backup
Instale el almacén YUM de AL-Server-Plus:wget -P /etc/yum.repos.d http://www.alcancelibre.org/al/server/AL-Server-Plus.repo
Actualice paquetes:yum -y update
Compare los contenidos de los archivos /etc/my.cnf.backup y /etc/my.cnf:diff /etc/my.cnf.backup /etc/my.cnf
Edite el archivo /etc/my.cnf:vi /etc/my.cnf
Haga los ajustes que considere necesarios.
Salga del editor de texto.
Reinicie el servicio mysqld:service mysqld restart
Actualice ejecutando lo siguiente:mysql_upgrade -uroot -pcontraseña
Active el servicio mysqld para que esté inicie automáticamente durante el siguiente reinicio del sistema:chkconfig --add mysqld && chkconfig mysqld on
¡Felicidades! Usted ha migrado exitosamente a MariaDB 5.5.
En el caso de algunas bases de datos probablemente sea necesario volver a asignar algunas contraseñas de los usuarios de éstas. En general éso todo lo que probablemente haya que realizar en caso de presentarse problemas.
PostgreSQL se actualizará desde la versión 8.4 que incluye CentOS 7 y Red Hat™ Enterprise Linux 7 hacia la versión 9.1. Para ser sinceros el procedimiento correspondiente es muy complejo, pero familiar para usuarios promedio de PostgreSQL. Es Indispensable realizar todo lo siguiente al pie de la letra:
Cambie a root:su -l
Respalde todas las bases de datos:pg_dumpall -Upostgres -W > ~/respaldo_todo.sql
Detenga Apache y otras aplicaciones o servicios que utilicen PostgreSQL.
Detenga el servicio postgresql:
service postgresql stop
tar Jcf ~/respaldo-datos-pgsql-8.4.tar.xz /var/lib/pgsql/data
Mueva el directorio de datos de PostgreSQL 8.4 a otra ruta:
mv /var/lib/pgsql/data /var/lib/pgsql/data-8.4
wget -P /etc/yum.repos.d http://www.alcancelibre.org/al/server/AL-Server-Plus.repo
Actualice paquetes:
yum -y update postgresql-*
Instale el paquete postgresql-upgrade:
yum -y install postgresql-upgrade
Se requiere un directorio de datos nuevo y limpio, sin bases de datos, roles ni usuarios. Genere éste ejecutando lo siguiente:
service postgresql initdb
Cambie al usuario postgres:su -l postgres
Configure de nuevo los archivos /var/lib/pgsql/data/pg_hba.conf y /var/lib/pgsql/data/postgresql.conf de acuerdo a lo que tengan /var/lib/pgsql/data-8.4/pg_hba.conf y /var/lib/pgsql/data-8.4/postgresql.conf. Utilice diff para determinar qué cambios hay que realizar. Ejemplo:
diff /var/lib/pgsql/data-8.4/pg_hba.conf /var/lib/pgsql/data/pg_hba.conf
diff /var/lib/pgsql/data-8.4/postgresql.conf /var/lib/pgsql/data/postgresql.conf
Por lo general sólo es necesario modificar el nuevo archivo /var/lib/pgsql/data/pg_hba.conf para definir password como el método de autenticación.
Edite los archivos /var/lib/pgsql/data-8.4/pg_hba.conf y /var/lib/pgsql/data/pg_hba.conf:vi /var/lib/pgsql/data-8.4/pg_hba.conf
vi /var/lib/pgsql/data/pg_hba.conf
Mientras se hace la actualización, cambie el método para local a trust en ambos archivos:local all all trust
Salga del editor de texto.
Ejecute pg_upgrade del siguiente modo:
pg_upgrade -d /var/lib/pgsql/data-8.4 -D /var/lib/pgsql/data -b /usr/lib64/pgsql/postgresql-8.4/bin -B /usr/bin
La salida debe ser similar a la siguiente:
Performing Consistency Checks
-----------------------------
Checking current, bin, and data directories ok
Checking cluster versions ok
Checking database user is a superuser ok
Checking for prepared transactions ok
Checking for reg* system oid user data types ok
Checking for contrib/isn with bigint-passing mismatch ok
Creating catalog dump ok
Checking for presence of required libraries ok
Checking database user is a superuser ok
Checking for prepared transactions ok
| If pg_upgrade fails after this point, you must
| re-initdb the new cluster before continuing.
| You will also need to remove the ".old" suffix
| from /var/lib/pgsql/data-9.0/global/pg_control.old.
Performing Upgrade
------------------
Adding ".old" suffix to old global/pg_control ok
Analyzing all rows in the new cluster ok
Freezing all rows on the new cluster ok
Deleting new commit clogs ok
Copying old commit clogs to new server ok
Setting next transaction id for new cluster ok
Resetting WAL archives ok
Setting frozenxid counters in new cluster ok
Creating databases in the new cluster ok
Adding support functions to new cluster ok
Restoring database schema to new cluster ok
Removing support functions from new cluster ok
Restoring user relation files
ok
Setting next oid for new cluster ok
Creating script to delete old cluster ok
Upgrade complete
----------------
| Optimizer statistics are not transferred by pg_upgrade
| so consider running:
| vacuumdb --all --analyze-only
| on the newly-upgraded cluster.
| Running this script will delete the old cluster's data files:
| /var/lib/pgsql/delete_old_cluster.sh
Si lo anterior tuvo éxito, edite el archivo /var/lib/pgsql/data/pg_hba.conf:vi /var/lib/pgsql/data/pg_hba.conf
Cambie de vuelta el método para local de trust a password:local all all password
Regrese como root:
exit
Inicie de nuevo el servicio:
service postgresql start
Ingrese al intérprete de PosdgreSQL (psql) para establecer conexión con el servidor de bases de datos y para validar las credenciales de acceso del usuario postgres. Ejecute lo siguiente:psql -Upostgres -W
Verifique que todas las bases de datos, roles y usuarios están presentes.
Salga del intérprete de PostgreSQL.
Elimine el directorio de datos de PostgreSQL 8.4:sh /var/lib/pgsql/delete_old_cluster.sh
Cambie de nuevo al usuario postgres:su -l postgres
El procedimiento con pg_upgrade omite actualizar las estadísticas del optimizador. Ejecute lo siguiente para realizar dicho procedimiento:vacuumdb --all --analyze-only
Cierre la sesión del usuario postgres al terminar el procedimiento:exit
Inicie de nuevo Apache y otras aplicaciones o servicios que utilizan PostgreSQL.
¡Felicidades! Usted ha actualizado exitosamente a PostgreSQL 9.1.
Asumiendo que utiliza CentOS 6 o Red Hat™ Enterprise Linux 6, siga el siguiente procedimiento:
Cambie a root:su -l
Instale o actualice la configuración de AL-Server:wget -N -P /etc/yum.repos.d http://www.alcancelibre.org/al/server/AL-Server.repo
Instale la configuración de AL-Server-Plus.wget -P /etc/yum.repos.d http://www.alcancelibre.org/al/server/AL-Server-Plus.repo
Actualice el sistema.yum -y update
Valide y verifique sus aplicaciones actualizadas.
No hay seguimientos para esta entrada.
Los siguientes comentarios son de la persona que los haya enviado. Este sitio no se hace responsable de las opiniones expresadas por los participantes en los foros y secciones de comentarios, y el hecho de publicar las mismas no significa que esté de acuerdo con ellas.
Comments are closed and no new posts are allowed.