Passa ai contenuti principali

PostgreSQL's request for a shared memory segment exceeded your kernel's SHMMAX parameter

Dopo aver aggiornato il kernel della mia ubuntu 8.10 alla versione 2.6.27-9, il server PostgreSQL 8.3 ha iniziato a fare i capricci e a non voler partire. Riporto qui l'errore riscontrato.
* Starting PostgreSQL 8.3 database server
* The PostgreSQL server failed to start. Please check the log output:
2008-12-02 08:51:50 CET LOG: could not load root certificate file "root.crt": no SSL error reported
2008-12-02 08:51:50 CET DETAIL: I certificati del client non saranno verificati.
2008-12-02 08:51:50 CET FATAL: could not create shared memory segment: Argomento non valido
2008-12-02 08:51:50 CET DETAIL: Failed system call was shmget(key=5432001, size=38207488, 03600).
2008-12-02 08:51:50 CET HINT: This error usually means that PostgreSQL's request for a shared memory segment exceeded your kernel's SHMMAX parameter. You can either reduce the request size or reconfigure the kernel with larger SHMMAX. To reduce the request size (currently 38207488 bytes), reduce PostgreSQL's shared_buffers parameter (currently 4096) and/or its max_connections parameter (currently 103). If the request size is already small, it's possible that it is less than your kernel's SHMMIN parameter, in which case raising the request size or reconfiguring SHMMIN is called for.
The PostgreSQL documentation contains more information about shared memory configuration. [fail]
Il problema è già stato segnalato al team di ubuntu come bug 264336, ma come si dice in questi casi, "mai paura, testa alta... e non sbaja mai". Andiamo a modificare il file di configurazione del server con l'editor di testo. Da terminale lanciamo gedit:
sudo gedit /etc/postgresql/8.3/main/postgresql.conf
NOTA IMPORTANTE: non uso il server per produzione ma solo per test in locale, le impostazioni possono quindi non essere le più consone all'utilizzo in un ambiente di rilascio.
Fatte le dovute premesse, passiamo alle due righe incriminate:
riga 61 circa, sotto la sezione Connections and authentication
max_connections = 50 (prima era impostata a 100)
riga 107 circa, sotto la sezione Resource Usage
shared_buffers = 25MB

Ho riavviato il servizio e sono riuscito a far ripartire il server.

Post popolari in questo blog

Se excel non aggiorna le formule

Oggi in ufficio è capitata una richiesta particolare. In un documento excel dopo aver eseguito un copia-incolla di una formula non si aggiornavano i risultati nelle celle interessate. Dopo attimi di perplessità dal fondo dell'ufficio il capo ci illumina con una funzione ai più sconosciuta e che ha risolto il problema: il tasto F9. Scusate la mia ignoranza in excel ma questo blog è pensato proprio per appuntare esperienze di vita informatica. Tutto sta nel fatto che i "calcolatori d'un tempo" non disponevano di una adeguata potenza di calcolo e nelle operazioni di copia-incolla si verificavano lunghe attese per l'aggiornamento. La soluzione adottata da MS è stata quella di inserire un'opzione per impedire l'aggiornamento automatico e forzarlo con una combinazione di tasti... il tasto F9!
Combinazioni utili per il calcolo delle formule F9 = calcola le formule modificate dall'ultimo calcolo in tutte le cartelle e fogli di lavoro aperte. MAIUSC + F9 = c…

Dove si trova il mio ISP?

Il link di oggi è My IP Address Lookup. Questo servizio spagnolo mostra dove si trova fisicamente il vostro ISP. Quando vi collegate ad internet in realtà prima fate una richiesta (il vostro modem o router) ad una macchina del vostro ISP e poi vi viene assegnato un indirizzo IP. Se volete sapere dove si trova la macchina che vi permette di accedere alla rete visitate pure
http://www.ip-adress.com/

Potrete inoltre conoscere il vostro IP e il provider che ve lo offre

RaspberryPi: Abilitare l'audio analogico

Introduzione
Il mio raspi è collegato ad una vecchia TV CRT che ho convertito in una smartTV. RaspberryPi infatti è un ottimo prodotto per configurare un media center con connessione ad internet ed altre amenità. Se usate una vecchia TV come nel mio cavo potrebbe interessarvi come abilitare l'uscita analogica per l'audio, il jack da 3,5 mm per intenderci. Per fare ciò dobbiamo assicurarci di avere i moduli giusti del kernel caricati e configurare il raspi ad utilizzare la giusta uscita audio, infatti di default utilizza la porta HDMI.

Controllo della presenza del modulo snd_bcm2835
1 Per controllare che il modulo giusto sia presente da linea di comando eseguire

sudo lsmod | grep snd_bcm2835

2 Se non vedete alcun output vuol dire che il modulo non è ancora caricato altrimenti potete passare al prossimo paragrafo.
3 Proviamo a caricare  il modulo con il seguente comando da terminale

sudo modprobe snd_bcm2835

Se l'output del comando è una cosa del genere

FATAL: Module snd_bcm2835…