email telefono contacto

Tweaking avanzado del wp-config.php de WordPress

En el artículo anterior hablamos sobre el consumo de RAM de algunos de los plugins más utilizados en WordPress, también hicimos alusión a las consultas que realiza WordPress a la base de datos MySQL y que algunos plugins pueden hacer demasiadas consultas.
Este articulo va a ser un poco distinto, pero entrando en temas técnicos de WordPress que son útiles para los que trabajamos con este CMS, pero que muy pocos conocen ya que son sus entresijos.

wordpress php memory

En este artículo vamos a explicar las variables que pueden ser definidas en el archivo wp-config.php de WordPress, para modificar su funcionamiento o para “ahorrar” peticiones a la base de datos definiendo algunos parámetros que nunca cambian.
Vamos a intentar que este articulo sea lo más completo posible y con la mayor cantidad de información sobre todo lo que puedes incluir en tu wp-config.php, aunque algunos los vamos a excluir de la lista ya que usarlos seria poco inteligente actualmente o por el contrario son cosas demasiado avanzadas como para realizarlas de forma optima con un simple parámetro en el wp-config.php.

Tweaking avanzado del wp-config.php de Wordpress 1
¡Suscríbete al boletín!

No te enviaremos spam, lo prometemos. Enviamos a nuestros suscriptores contenido sobre WordPress, hosting, marketing digital y programación.

+ Información básica sobre protección de datos

DB_NAME

El parámetro DB_NAME nos permite configurar y definir el nombre de la base de datos MySQL a la que se conectara WordPress para funcionar, se define con el siguiente código:

define( 'DB_NAME', 'database_name_here' );

DB_USER

El parámetro DB_USER nos permite configurar y definir el nombre del usuario que usara WordPress para conectarse a la base de datos MySQL, se define con el siguiente código:

define( 'DB_USER', 'MyUserName' );

DB_PASSWORD

El parámetro DB_PASSWORD nos permite configurar y definir la contraseña que utilizara el usuario definido en DB_USER para acceder a la base de datos MySQL, se define con el siguiente código:

define( 'DB_PASSWORD', 'MyPassWord' );

DB_HOST

Con este parámetro definimos cual será el host de la base de datos, si el servidor MySQL que vamos a usar se encuentra en el mismo servidor debemos usar “localhost” o “127.0.0.1”, en este parámetro también podemos usar un MySQL Socket, se define con el siguiente código:

define( 'DB_HOST', 'MyDatabaseHost' );

DB_CHARSET

Con el parámetro DB_CHARSET podemos configurar la codificación de caracteres de la base de datos MySQL a la que nos vamos a conectar, podemos definirlo con el siguiente código:

define( 'DB_CHARSET', 'utf8' );

$table_prefix

Con el parámetro $table_prefix podemos configurar el prefijo de la base de datos para las tablas de la base de datos MySQL que utilizamos en nuestro WordPress, podemos definir el prefijo con el siguiente código:

$table_prefix = 'y77_';

WP_SITEURL

Con el parámetro WP_SITEURL podemos definir de forma estática la URL del sitio web WordPress, incluso podemos configurar como URL un dominio con una subcarpeta, podemos definir la URL del sitio web con el siguiente código:

define( 'WP_SITEURL', 'http://example.com/wordpress' );

WP_HOME

Con el parámetro WP_HOME podemos definir la URL de la página principal del blog, algo parecido al WP_SITEURL pero para el blog (loop de WordPress), puedes definir esta variable con el siguiente código:

define( 'WP_HOME', 'http://example.com/wordpress' );

WP_CONTENT_DIR

Con el parámetro WP_CONTENT_DIR podemos definir otra ubicación personalizada para el directorio WP-CONTENT de WordPress, podemos definir este parámetro mediante una ruta interna o mediante una URL, el código usado es el siguiente:

define( 'WP_CONTENT_DIR', dirname(__FILE__) . '/blog/wp-content' );

WP_PLUGIN_DIR

Podemos modificar la localización de la carpeta de plugins con el parámetro WP_PLUGIN_DIR, al igual que en el caso de WP_CONTENT_DIR podemos usar una ruta interna o una URL, el código usado para esto es el siguiente:

define( 'WP_PLUGIN_DIR', dirname(__FILE__) . '/blog/wp-content/plugins' );

UPLOADS

Podemos modificar la localización de la carpeta usada para guardar los archivos subidos mediante el parámetro UPLOADS, el código usado para esto es el siguiente:

define( 'UPLOADS', 'blog/wp-content/uploads' );

AUTOSAVE_INTERVAL

Como muchos sabrán, WordPress realiza un autoguardado automático de los artículos y páginas que se están editando mediante revisiones, con este parámetro podemos configurar cada cuanto tiempo se guardan revisiones automáticas, el código usado para esto es el siguiente:

define( 'AUTOSAVE_INTERVAL', 160 );

EMPTY_TRASH_DAYS

Este parámetro nos permite configurar cada cuanto tiempo se vacía la papelera de WordPress, incluso podemos desactivar la papelera de reciclaje. Podemos modificar el comportamiento de la papelera usando el siguiente código:

define( 'EMPTY_TRASH_DAYS', 0 );

WP_POST_REVISIONS

Con la variable WP_POST_REVISIONS podemos activar o desactivar la creación de revisiones por parte del autoguardado de WordPress, con este parámetro también podemos definir cuantas revisiones se guardan, el código usado para esto es el siguiente:

define( 'WP_POST_REVISIONS', false );

COOKIE_DOMAIN

Usando el parámetro COOKIE_DOMAIN podemos definir cuál será el dominio o subdominio principal del blog que tendrá las cookies y las instalara en el navegador del usuario, podría dedicar solo un post a escribir sobre esta opción y sus ventajas, pero creo que no es el momento, el parámetro para definir este parámetro es el siguiente:

define( 'COOKIE_DOMAIN', 'www.askapache.com' );

WP_ALLOW_MULTISITE

Esta opción sirve para activar WordPress Multisite, después de activar esta opción y entrar a WordPress debemos seguir un asistente de configuración de la red de blogs. Para activar esto podemos usar el siguiente parámetro:

define( 'WP_ALLOW_MULTISITE', true );

WP_DEBUG

El DEBUG es una de las mejores herramientas para determinar y detectar problemas en una instalación de WordPress, solo tiene dos modos de funcionamiento, puede estar encendido o apagado. Para activar esto podemos usar el siguiente parámetro:

define( 'WP_DEBUG', true );

SCRIPT_DEBUG

Esta opción la he usado bastante poco ya que apenas le veo utilidad, pero saca algunos errores de Javascript y CSS junto con los errores de PHP cuando el WP_DEBUG está activado, puedes activar el SCRIPT_DEBUG usando el siguiente código:

define( 'SCRIPT_DEBUG', true );

WP_DEBUG_LOG

Si tenemos el WP_DEBUG activado y posteriormente activamos WP_DEBUG_LOG podemos guardar un registro con todos los errores que ha dado la instalación de WordPress, los archivos de log se guardaran en wp-content para activar el log podemos usar el siguiente parámetro:

define( 'WP_DEBUG_LOG', true );

WP_MEMORY_LIMIT

De forma predeterminada WordPress impone un límite de memoria usable, podemos forzar la cantidad de memoria RAM utilizada usando el siguiente parámetro:

define( 'WP_MEMORY_LIMIT', '64M' );

Si quieres más información puedes ver nuestro post sobre cómo ajustar el memory_limit en WordPress.

WP_MAX_MEMORY_LIMIT

Este parámetro se parece al WP_MEMORY_LIMIT, pero solo afecta a la memoria utilizada al ejecutar el panel de administración de WordPress, podemos forzar esta opción con el siguiente parámetro:

define( 'WP_MAX_MEMORY_LIMIT', '256M' );

WP_CACHE

Este parámetro actualmente no se usa para lo que está pensado, pero es necesario tenerlo activado en el wp-config.php para que funcionen algunos plugins de cache para WordPress, ya que lo que hace es activar el archivo advanced-cache.php, podemos activar WP_CACHE con el siguiente código:

define( 'WP_CACHE', true );

CUSTOM_USER_TABLE

Podemos modificar la tabla donde se guardan los usuarios en la base de datos de WordPress, aunque en la práctica esto no tiene mucha utilidad, es una opción más que se puede definir con el siguiente código:

define( 'CUSTOM_USER_TABLE', $table_prefix.'my_users' );

CUSTOM_USER_META_TABLE

La tabla META de usuarios guarda datos adicionales sobre los usuarios registrados en una instalación de WordPress, esta opción nos permite cambiar el nombre de la tabla donde se guardan estos datos, podemos definir esta opción con el siguiente código:

define( 'CUSTOM_USER_META_TABLE', $table_prefix.'my_usermeta' );

WPLANG

Este parámetro nos permite configurar el idioma por defecto de la instalación de WordPress, evidentemente antes de configurar este parámetro debemos asegurarnos de que nuestra instalación de WordPress tiene los archivos de idioma en la carpeta correspondiente. Podemos definir el idioma con el siguiente código:

define( 'WPLANG', 'de_DE' );

WP_LANG_DIR

Con este parámetro podemos configurar la carpeta donde WordPress buscara los archivos de idioma, sinceramente creo que es un parámetro un poco absurdo, pero podemos definir el idioma con el siguiente código:

define( 'WP_LANG_DIR', dirname(__FILE__) . 'wordpress/languages' );

FS_CHMOD_DIR

Este parámetro es uno de los más desconocidos y a la vez uno de los más útiles, ya que nos permite configurar los permisos para las carpetas de la instalación de WordPress, una excelente utilidad para que nuestro WordPress tenga los permisos adecuados. Podemos definir los permisos de las carpetas con el siguiente código:

define( 'FS_CHMOD_DIR', ( 0755 & ~ umask() ) );

FS_CHMOD_FILE

Este parámetro es parecido al FS_CHMOD_DIR, pero en este caso lo que hace es definir los permisos de todos los archivos de la instalación de WordPress, podemos definir los permisos de los archivos con el siguiente código:

define( 'FS_CHMOD_FILE', ( 0644 & ~ umask() ) );

WP_ALLOW_REPAIR

Este parámetro es un gran desconocido, pocos saben que WordPress trae entre sus utilidades una herramienta para reparar la base de datos de WordPress, podemos activarla usando el siguiente parámetro:

define( 'WP_ALLOW_REPAIR', true );

WP_HTTP_BLOCK_EXTERNAL

Lo que hace este parámetro es no permitir que WordPress realice peticiones externas a otros servidores HTTP, es un parámetro útil si estamos realizando un desarrollo sobre WordPress en local. Podemos aplicar el bloqueo con el siguiente código:

define( 'WP_HTTP_BLOCK_EXTERNAL', true );

WP_ACCESSIBLE_HOSTS

Este parámetro va directamente ligado al anterior, ya que nos permite crear una lista blanca con algunos dominios y hostnames a los que WordPress sí que podrá realizar peticiones HTTP externas. Podemos aplicar el bloqueo con el siguiente código:

define( 'WP_ACCESSIBLE_HOSTS', 'api.wordpress.org,*.github.com' );

DISABLE_WP_CRON

Podemos activar o desactivar el WP-CRON, este parámetro nos ayudara a desactivar el WP-CRON de WordPress y comenzar a usar el CRON de Linux, podemos hacerlo con el siguiente parámetro:

define( 'DISABLE_WP_CRON', true );

DISALLOW_FILE_EDIT

Con este parámetro puedes desactivar el editor integrado de themes y plugins desde el panel de WordPress, puedes desactivar el editor utilizando el siguiente código:

define( 'DISALLOW_FILE_EDIT', true );

DISALLOW_FILE_MODS

Este parámetro nos permite bloquear la instalación y actualización de themes y plugins en una instalación de WordPress, podemos activar esta opción utilizando el siguiente codigo:

define( 'DISALLOW_FILE_MODS', true );

FORCE_SSL_LOGIN

El parámetro FORCE_SSL_LOGIN te permitirá obligar a que todos los usuarios que quieran entrar al panel de administración de WordPress lo hagan a través de conexión cifrada HTTPS, podemos activar esta opción con el siguiente codigo:

define( 'FORCE_SSL_LOGIN', true );

FORCE_SSL_ADMIN

Este parámetro se parece al parámetro FORCE_SSL_LOGIN pero tiene una diferencia, en este caso se aplica solo a los administradores de la instalación de WordPress, podemos activar esta opción con el siguiente código:

define( 'FORCE_SSL_ADMIN', true );

AUTOMATIC_UPDATER_DISABLED

Esta opción nos permite desactivar el actualizador automático de plugins, themes y de WordPress, una opción útil si tenemos cambios específicos en el código de la instalación de WordPress y no queremos perderlos, podemos activar esta opción con el siguiente código:

define( 'AUTOMATIC_UPDATER_DISABLED', true );

WP_AUTO_UPDATE_CORE

Esta opción nos permite activar o desactivar las actualizaciones automáticas del núcleo de WordPress, es decir, de los archivos del propio WordPress, podemos activar esta opción con el siguiente código:

define( 'WP_AUTO_UPDATE_CORE', false );

FTP_HOST

Esta opción nos permite guardar en la configuración de WordPress el servidor FTP donde se encuentra la instalación de WordPress, podemos definir esto con el siguiente código:

define( 'FTP_HOST', 'ftp.example.org' );

FTP_USER

Nos permite guardar el usuario FTP del servidor donde se guarda la instalación de WordPress, podemos definir esto con el siguiente código:

define( 'FTP_USER', 'username' );

FTP_PASS

Podemos definir también la contraseña del usuario FTP del servidor donde se guarda la instalación de WordPress, podemos definir y guardar esto con el siguiente código:

define( 'FTP_PASS', 'password' );

MÁS PARAMETROS DEL WP-CONFIG.PHP

Podría contabilizar más de 300 parámetros o variantes de parámetros que podríamos usar en el wp-config.php de WordPress para modificar funcionalidades en WordPress o desactivar funcionalidades de WordPress, es más, esta es la única manera que conozco de cambiar la forma de funcionar del núcleo de WordPress.
Desgraciadamente si incluyera todos los parámetros y sus variantes esta lista sería imposible de leer y no se podría buscar nada en ella.

Si necesitas ayuda para resolver algún problema en tu WordPress o estás buscando a alguien para desarrollar tu web sobre WordPress, nosotros somos los indicados, contacta con nosotros sin compromiso.

Extra: Checklist de mantenimiento de WordPress

Ya para terminar el post, te animo a descargarte la checklist que hemos creado para ayudarte a realizar las frecuentes tareas de mantenimiento que es importante llevar a cabo en WordPress. Así siempre tendrás un documento guardado que podrás utilizar en tus mantenimientos periódicos. Solo tienes que rellenar el siguiente formulario.

Tweaking avanzado del wp-config.php de Wordpress 1
¡Suscríbete al boletín!

No te enviaremos spam, lo prometemos. Enviamos a nuestros suscriptores contenido sobre WordPress, hosting, marketing digital y programación.

+ Información básica sobre protección de datos
Alvaro Fontela
Alvaro Fontela

Mi nombre es Alvaro Fontela, soy consultor Wordpress y blogger activo desde hace años. CEO y co-Fundador de Raiola Networks, escribiendo sobre WordPress, hosting y WPO en este blog desde 2014.

Artículos relacionados

Si te ha gustado este post, aquí tienes otros que pueden ser de tu interés. ¡No dejes de aprender!

Tenemos 6 comentarios en "Tweaking avanzado del wp-config.php de WordPress"
  • Hola Yam, con tan pocos datos no podemos ayudarte, ya que puede ser por muchas cosas, habría que ver el caso con detenimiento.

    Si necesitas ayuda profesional, puedes contactar con nuestro servicio especializado en WordPress: enlace

    • Hola Yam, con tan pocos datos no podemos ayudarte, ya que puede ser por muchas cosas, habría que ver el caso con detenimiento.

      Si necesitas ayuda profesional, puedes contactar con nuestro servicio especializado en WordPress: enlace

  • Hola Yam, con tan pocos datos no podemos ayudarte, ya que puede ser por muchas cosas, habría que ver el caso con detenimiento.

    Si necesitas ayuda profesional, puedes contactar con nuestro servicio especializado en WordPress: enlace

    • Hola Yam, con tan pocos datos no podemos ayudarte, ya que puede ser por muchas cosas, habría que ver el caso con detenimiento.

      Si necesitas ayuda profesional, puedes contactar con nuestro servicio especializado en WordPress: enlace

  • Hola Yam, con tan pocos datos no podemos ayudarte, ya que puede ser por muchas cosas, habría que ver el caso con detenimiento.

    Si necesitas ayuda profesional, puedes contactar con nuestro servicio especializado en WordPress: enlace

    • Hola Yam, con tan pocos datos no podemos ayudarte, ya que puede ser por muchas cosas, habría que ver el caso con detenimiento.

      Si necesitas ayuda profesional, puedes contactar con nuestro servicio especializado en WordPress: enlace

  • Deja una respuesta

    Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

    ¿Vienes de otro proveedor?

    ¡Ningún problema! Te migramos gratis y sin cortes
    cohete raiola