Wp Cli
Notas rápidas
- Tips rápidos para WP-CLI
- Crear un sitio wordpress con wp cli
- Mover un sitio web de un path a otro cambiando las url con wp cli
- Problemas por la versión shell usada y wp-cli
Tips rápidos para WP-CLI
##Introducción Wp-cli es una herramienta muy potente para los webmaster y administradores de sitios. Es un cansancio y una hartura la falta de compromiso de los clientes y de sus empresas de mantenimiento de la página web (esos mismo que luego van diciendole al cliente que deberían migrar su contenido a sus servidores, que ellos, son diseñadores, desarrolladores, hostess, pintores y mecanicos de vuelo, si hace falta, pero luego no tienen ni backups, ni seguridad, ni nada)
Actualiza todo
Funcionara si no hay problemas derivados por php obsoleto, algun plugin desastre, etc,
Estructura de cPanel
cd ~/public_html && wp core update && wp plugin upgrade --all && wp theme upgrade --all
-
Algunas veces puede darnos problemas de memoria. Un tip rápido Error con WP-CLI en el shell con cPanel - PHP Fatal error: Allowed memory size of bytes exhausted
-
Otras veces tenemos problemas con las versiones obsoletas de php, Problemas por la versión shell usada y wp-cli
php -d memory_limit=512M "$(which wp)" core update && php -d memory_limit=512M "$(which wp)" plugin upgrade --all && php -d memory_limit=512M "$(which wp)" theme upgrade --all
Normal
wp core update && wp plugin upgrade --all && wp theme upgrade --all
Usuarios
Crear un administrador de Wordpress con wp cli
# wp user create
$ wp user create castris fake@castris.com --role=administrator
Success: Created user 12.
Password: 0VV3gUlNMECOPIESQUENOVALGOGFO4ht
Borrar un usuario de Wordpress con wp-cli
wp user delete
wp user delete 12
--reassign parameter not passed. All associated posts will be deleted. Proceed? [y/n] y
Success: Removed user 12 from http://www.dunlopillo.es.
Actualizar WP
Como root si la aplicación esta en el sistema de forma global
sudo wp cli update
You have version 2.5.0-alpha-3f4c34b. Would you like to update to 2.5.0? [y/n] Y
Downloading from https://github.com/wp-cli/wp-cli/releases/download/v2.5.0/wp-cli-2.5.0.phar...
md5 hash verified: 20ab512b12d766a2d2f51cc8f5c43411
New version works. Proceeding to replace.
Success: Updated WP-CLI to 2.5.0.
Aviso
Esta documentación y su contenido, no implica que funcione en tu caso o determinados casos. También implica que tienes conocimientos sobre lo que trata, y que en cualquier caso tienes copias de seguridad. El contenido el contenido se entrega, tal y como está, sin que ello implique ningún obligación ni responsabilidad por parte de Castris
Si necesitas soporte profesional puedes contratar con Castris soporte profesional.
Crear un sitio wordpress con wp cli
Introducción
El uso de wp cli para la administración de sitios con wordpress es el paradigma de la eficiencia, sobre todo para los que amamos el shell. Una de las cosas que mejor podemos hacer es instalar wp desde shell.
Requisitos previos
- Tener una base de datos
- Un usuario y su contraseña para usar deicha base de datos.
- Acceso shell
Instalacion de wordpress en el shell con wp cli
Accedemos con nuestro usuario al servidor.
El ejemplo que vamos a explicar es en un servidor con cpanel en el dominio principal.
Primero debemos confirmar que el certificado SSL se ha instalado, ya que es recomendable hacer la instalación sobre la base de usar https
$ cd public_html
$ wp core download --locale=es_ES
Downloading WordPress 5.7.2 (es_ES)...
md5 hash verified: 775ec9305bbe9729568fbc7b5fb7b71d
Success: WordPress downloaded.
$ wp core config --dbhost=localhost --dbname=DBNAME --dbuser=DBUSER --dbpass=PASSWORD
Success: Generated 'wp-config.php' file.
Verificamos por si hubo algun problema de escapoes o similar.
cat wp-config.php | grep -i db
define( 'DB_NAME', 'cpuser_dbname' );
define( 'DB_USER', 'cpuser_dbuser' );
define( 'DB_PASSWORD', 'PaSsW0Rd€#?' );
define( 'DB_HOST', 'localhost' );
define( 'DB_CHARSET', 'utf8' );
define( 'DB_COLLATE', '' );
define( 'LOGGED_IN_KEY', '/whuB6w+(RdHHHHHHHHHHHHHHH=wZ9Up3F0i!9Z@<Ey#P`@PDY^B;^[06Mgy' );
cPanel permisos (PHP FPM)
Los permisos de cpanel para un servidor con PHP-FPM son especificos, y muchas veces la literatura en google de lso expertos, nos lleva a las tipicas cosas que no funcionan.
Por defecto instala ficheros con permisos 664 y 775 para directorios, lo cual no es permisible en cPanel en ese escenario.
Solución
# Atención que el comando debe ejecutarse en el directrpoio public_html donde estabamos
# $ cd ~/public_html
$ find . -type f -exec chmod 644 {} \;
$ find . -type d -exec chmod 755 {} \;
$ chmod 750 ../public_html/
Finalizar la instalación
$ wp core install --url=domainio.tld --title="We Welle" --admin_user=NOMBREADMIN --admin_password=contraseñasincaracteresextendidos --admin_email=email@user
Success: WordPress installed successfully.
Aviso
Esta documentación y su contenido, no implica que funcione en tu caso o determinados casos. También implica que tienes conocimientos sobre lo que trata, y que en cualquier caso tienes copias de seguridad. El contenido el contenido se entrega, tal y como está, sin que ello implique ningún obligación ni responsabilidad por parte de Castris
Si necesitas soporte profesional puedes contratar con Castris soporte profesional.
Mover un sitio web de un path a otro cambiando las url con wp cli
Introducción
A veces a algun diseñador web se lo ocurrió aquello de hacer el sitio en el servidor de producción con una estructura domain.tld/wp o similar, y luego quiere moverlo a domain.tld
El soporte de su hosting y con razón le dirá que eso es una cuestión nuestra, y que no entra dentro del soporte, por lo que no nos ayudará o si lo hace, será bajao presupuesto. Normal, el trabajo no es gratis.
Cambios por ejemplo para domain.tld/wp a domain.tld
En principio basta con acceder via, phpMyAdmin, MysqlWorkbench, TablePlus o similar a la tabla xxx_options para modificar los valores de options_name
de las filas site_url y home por nuetsro nuevo path domain.tld
tal y como nos indica Wordpress en su documentación, Moving Worpdress
También deberemos eliminar o corregir, mejor dicho, la configuración de nuestro .htaccess que contendría el path /wp
Pero bueno, esto a veces no es suficiente y algo falla, ya que incluso podemos acceder a nuestro area de administracion o tablero, con el nuevo dominio, pero wordpress nos idnica un 4040 en el sitio cuando tratamos de acudir a la nueva ubicación.
Es probable que halla restos del path antiguo en nuetsros posts, o en algun sitio de nuestro template, etc.
wp search-replace
wp search-replace comando de wp cli que nos permitirá revisar la base de datos y corregir posibles problemas embutidos en nuestras tablas.
wp search-replace 'https://dominio.tld' 'https://dominio.tld'
Merece repasar las opciones como dry-run
para no hacer cambios, o --export=database.sql
que tampoco hace cambios pero exporta los cambios.
Aviso
Esta documentación y su contenido, no implica que funcione en tu caso o determinados casos. También implica que tienes conocimientos sobre lo que trata, y que en cualquier caso tienes copias de seguridad. El contenido el contenido se entrega, tal y como está, sin que ello implique ningún obligación ni responsabilidad por parte de Castris
Si necesitas soporte profesional puedes contratar con Castris soporte profesional.
Problemas por la versión shell usada y wp-cli
Introducción
A veces podemos encontrarnos con un usuario con un Wordpress muy, muy obsoleto, y aunque tengamos la versión de PHP requerida en el shell, seguiremos teniendo problemas con wp cli porque este depende de la instalación de WP que tiene. La solución pasa por usar la versión php original
En cpanel es fácil hacer esto,
Aunque este tip es para cPanel, vale para cualquier distribución Linux o *nix. adaptando el tip a tu SO
Ejemplo
wp core update && wp plugin upgrade --all && wp theme upgrade --all
Fatal error: __autoload() is no longer supported, use spl_autoload_register() instead in /home/user/public_html/wiki.dominio.com/wp-includes/compat.php on line 502
php -v
PHP 7.2.34 (cli) (built: Mar 28 2023 21:20:00) ( NTS )
Copyright (c) 1997-2018 The PHP Group
Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
with the ionCube PHP Loader + ionCube24 v10.4.5, Copyright (c) 2002-2020, by ionCube Ltd.
with Zend OPcache v7.2.34, Copyright (c) 1999-2018, by Zend Technologies
El usuario tiene una versión correcta en la que todavía no estaba declarada obsoleta la función __autoload()
Así que vemos en el sistema que versiones hay y su path.
Como root podemos hacer
whmapi1 php_get_installed_versions
---
data:
versions:
- ea-php54
- ea-php55
- ea-php56
- ea-php70
- ea-php71
- ea-php72
- ea-php73
- ea-php74
- ea-php80
- ea-php81
- ea-php82
metadata:
command: php_get_installed_versions
reason: OK
result: 1
version: 1
Así que las versiones que tenemos están en /opt/cpanel/ea-phpXX/root/usr/bin/php
Ahora solo nos queda llamar al wp-cli de forma adecuada
72
es la versión que queremos usar
/usr/local/bin/wp
es el path de instalación global de la herramienta wp
/opt/cpanel/ea-php72/root/usr/bin/php /usr/local/bin/wp core update
Aviso
Esta documentación y su contenido, no implica que funcione en tu caso o determinados casos. También implica que tienes conocimientos sobre lo que trata, y que en cualquier caso tienes copias de seguridad. El contenido el contenido se entrega, tal y como está, sin que ello implique ningún obligación ni responsabilidad por parte de Castris
Si necesitas soporte profesional puedes contratar con Castris soporte profesional.