Problema: l’editor visuale e testuale di WordPress non si carica

Capita talvolta che l’editor di WordPress dopo qualche aggiornamento non venga più caricato. Nè quello visuale, nè quello testuale. Per risolvere il problema è sufficiente una piccola operazione da fare sul file wp-config.php del proprio sito, basta aggiungere la seguente riga:

define('CONCATENATE_SCRIPTS', false);

da qualche parte nel file. Ricaricando la pagina nel browser dovreste ora vedere nuovamente l’editor.

problema editor visuale wordpress

Velocizzare il proprio server per WordPress

Questa vuole essere una breve guida per chi ha la necessità di velocizzare il proprio server di hosting linux (in questa guida utilizzerò uno dei miei server con CentOS). Velocizzare i siti web ospitati non è legato solo al server, ma naturalmente anche a tanti altri fattori che riguardano i propri siti, che devono essere sviluppati con cura e professionalità. Nel caso di WordPress ci sono tante cose che si possono fare e tanti plugin, questa guida vuole semplicemente essere un buon punto di partenza: lascio a voi sperimentare quale configurazione vada meglio per voi, la fase di test e di verifica continua dei log e delle prestazioni del proprio server è come sempre fondamentale.

PREMESSA: se non siete pratici di server, Linux, console e terminali, questa guida non fa per voi: non è una guida completa, ma una raccolta di suggerimenti e indicazioni per chi mastica almeno un po’ l’argomento. Per questo motivo non è approfondita ma lascio ai link ai siti ufficiali l’onere di descrivervi nel dettaglio tutto quanto, e a questo video tratto dal Wordcamp di Torino del 2016 (cui ho partecipato) in cui viene ben illustrato il quadro generale sull’argomento.

Analisi dei siti

Innazitutto partiamo da uno dei più famosi siti di test online, che ci può dare ottime indicazioni sui siti ospitati sul nostro server: GT Metrix

check website speed

Inserite l’URL del vostro sito e verificate i valori di performance: scorrendo la pagina troverete molte informazioni e suggerimenti utili da attuare. Riuscire a migliorare i valori è il vostro obbiettivo.

In questa guida seguirò questo schema:

Memcached

Serve a ridurre il carico sul database per i siti dinamici come WordPress. Su CentOS si installa così da terminale del proprio server:

yum install libevent-devel
yum install memcached php-pear php-pecl-memcache

Dopodichè si può personalizzare la configurazione:

vi /etc/sysconfig/memcached
PORT="11211" 
USER="memcached" 
MAXCONN="1024" 
CACHESIZE="2048" 
OPTIONS=

ora bisogna finire la configurazione:

chkconfig --levels 235 memcached on
service memcached start

Nginx

E’ un  reverse proxy server, serve a utilizzare in maniera efficiente le risorse di sistema quando si forniscono contenuti statici.

Per installarlo su CentOS:

sudo yum install epel-release
sudo yum install nginx
sudo systemctl start nginx

oppure seguire la guida ufficiale.

GZip

Innazitutto potete verificare se GZip è attivo utilizzando il sito Check GZ Compression o direttamente da terminale:

/etc/init.d/nginx status

Se non è attivo, occorre configurarlo, aprendo il file di configurazione:

vi /etc/nginx/nginx.conf

cercate questa riga di codice:

#gzip on;

e sostituitela con queste:

gzip on;
gzip_comp_level 4;
gzip_http_version 1.0;
gzip_proxied any;
gzip_min_length 1100;
gzip_buffers 16 8k;
gzip_types text/plain text/html text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript;
gzip_vary on;
gzip_disable "MSIE [1-6]\.(?!.*SV1)"

dove “gzip_comp_level 4” indica il livello di compressione richiesto con indice massimo di 9.

Abilitate Gzip:

/usr/local/psa/admin/sbin/nginxmng -e
service nginx restart

Plugin

Si può ora procedere a installare diversi plugin utili sui siti WordPress ospitati sul vostro server (consultate i siti ufficiali per tutte le informazioni sulla loro configurazione avanzata):

Batcache: serve a far sfruttare Memcached al vostro sito.

BJ Lazy Load: velocizza il caricamento della pagina nel browser.

Autoptimize: serve a minimizzare i file JS, CSS e HTML.

WP Super Cache: un potente motore di caching che crea file HTML per velocizzare l’esecuzione del sito. Nelle configurazioni avanzate scegliete inizialmente le opzioni indicate con “raccomandata“.

500 Internal server error durante l’aggiornamento del database di WordPress

500-internal-server-error

Un errore durante l’aggiornamento all’ultima versione di WordPress (4.2.1) mi ha causato un grosso problema su un sito: nel dettaglio provando ad accedere alla bacheca di amministrazione compare il  messaggio (tipico dopo gli aggiornamenti più importanti di WordPress):

E’ richiesto l’aggiornamento del database:
WordPress è stato aggiornato! Prima di proseguire, dobbiamo aggiornare il database alla nuova versione.

e dopo aver lanciato l’aggiornamento, il server restituisce dopo un po’ di minuti l’errore “500 Internal Server Error”. Il tutto si ripete ad ogni tentativo di aggiornamento, rendendo impossibile accedere alla bacheca di WordPress.

Dopo aver consultato a fondo la guida di WordPress, l’unica soluzione trovata (nella rete si trovano diverse guide, ma sono quasi tutte legate a WordPress installati su hosting commerciali tipo Aruba)  è stata  modificare manualmente nel database la versione del database corrente.  Se avete accesso al pannello di gestione del database del vostro sito (tipicamente phpMyAdmin o simili), dovete cercare nella tabella wp_options il campo db_version:

wordpress-500-server-error

il valore numerico sostituendolo con il valore che trovate a questa pagina, in cui si trovano i codici relativi alla versione del database rapportati alla versione corrente di WordPress (ovvero quella cui avete aggiornato prima dell’errore).

forzare upgrade database wordpress

Dopo aver effettuato la modifica, WordPress ha ripreso a funzionare perfettamente, sono stati provati ulteriori aggiornamenti di WordPress, temi e plugin con successo.

Versione di WordPress pre-aggiornamento: 4.2 Italiano

Versione dell’aggiornamento: 4.2.1 Italiano