Passa al contingut principal

Per fi!, tema dominat: mysql asincron en node.js

Escoltant marea (no té res a veure, però així indique preferències musicals ;)), he trobat la solució al problema dels posts anteriors. Resulta que la funció query del paquet és asíncrona, és a dir que no se pot saber quan s'executarà, però serà quan s'acabe la funció que la crida. Aleshores el que hem de fer és no retornar la resposta fins que no s'execute el callback. I així ens evitem el problema, si has estat seguint el post entendràs la consulta i tot:


function fservidor(request, response){
var resXML="<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?><resposta>";
function frequeston(){
  // El codi 200 vol dir què la petició ha segut correcta, i enviem la resposta en text pla.
   response.writeHead(200, {
         'Content-Type': 'text/plain'
      }); //end writehead
 }//end frequeston

request.on("end", frequeston);
 var client = mysql.createConnection('mysql://'+user + ':'+pass+'@'+server+'/'+database);
 client.query("select * from personatges",function (err,result){
   resXML+="<personatges><personatge><id>" + result[0].id + "</id></personatge></personatges>";
   resXML+="</resposta>";
 response.end(resXML);
  }//callback query
 );//query


}

var servidor = http.createServer(fservidor);
servidor.listen(10000);



Si ens fixem la línia en roig, (la resposta), està fins el callback, per tant ens assegurem que no es retornarà la resposta al client fins que no s'execute el callback. Això és així per què el servidor node.js té un únic fil, (al contrari, com per exemple php, que cada petició és un nou fil), i per cada petició s'execute una vegada fservidor() fins que acaba. Si mysql fora síncrona, i fora una consulta llarga (per exemple), el servidor quedaria colapsat fins que la petició a la base de dades es realitzara i no estaria realitzant cap procés. Així, retorna el control i pot atendre les següent peticions. Recordem node.js és un servidor orientat a events.
La resposta en l'exemple, òbviament no té molt de sentit lògic però si ilustratiu:

<?xml version="1.0" encoding="ISO-8859-1"?>
<resposta><personatges><personatge><id>1</id></personatge>
</personatges></resposta>



Comentaris

Entrades populars d'aquest blog

Comparativa dels Sistemes Polítics Espanyol, Valencià i d'un partit polític. (II)

El Poder Executiu En l’Estat Espanyol, el poder executiu real bé donat pel President del Govern. Aquest triarà els Vicepresidents, Ministres, etc (directa o indirectament, alguns alts càrrecs els triaran els corresponent Ministres). No hi ha cap limitació al respecte la persona elegida (no ha de ser diputada, ni cap límit de formació, etc.). Al País Valencià, l’òrgan executiu és el Consell, i, existeix, de manera anàloga, el president del Consell (què és, també, el president del Generalitat, el és conjunt d’institucions d’autogovern). S’elegix de manera anàloga al President del Govern espanyol, però amb la diferència que ha d’ésser elegit entre els diputats de les Corts Valencianes. Aquest procedirà, igual que al govern espanyol, a nomenar el seu gabinet. Al Bloc Nacionalista Valencià, el poder executiu rau en l’Executiva Nacional. Aquesta, de manera tradicional, és triada al Congrés Nacional des d’un sistema de llista tancada majoritari. Encara que tradicionalment sol haver-hi només...

Clean Code... WTF? És realment viable?

Després d'haver llegit un bon grapat (realment no tants però així quede d'entés ;)) de llibres sobre fer codi clar, bona programació... no sé com dir-ho, en anglés Clean Code, he trobat a l'anar a modificar (adaptar) programes d'altres (programari lliure) que no hi havia per on agarrar-ho. Vaig a posar un cas (no, no vaig a refactoritzar-lo ni vaig a menyspreuar-lo) en el que volia "treballar" actualment. Volia fer una modificació del fòrum Simple Machines Forum (el fòrum és una passada, va molt bé i inclou de serie una versió per a mòbil que ve molt bé). El resultat és què  la funció (on supose) que volia fer la modificació, té un tamany de més de 600 línies!!! Recordem que uns dels principis (segons l'Uncle Bob) és què les funcions han de fer una i només una cosa, i han de ser curtes. El que caldria supose què és refacoritzar-lo, però a veure qui és el guapo que es posa ara a fer-ho  (hi ha molt de codi al fòrum). He de dir també que el codi està fet en...

Hui he vist la por als ulls

Estic trist ,molt trist.Vinc de la manifestació del 9 d'octubre i, puc dir que he vist moltes coses, però el que no he vist és democràcia. He vist moltes banderes d'Espanya i blaveres dels increpadors, però no he vist democràcia. Les seues paraules eren "ven aquí fuera", "te voy a meter esa bandera por el coño", etc. He vist com manifestants fàcilment identificables entraven a provocar i la Policia Nacional no feia res per evitar-ho, però no he vist democràcia. He vist com un pare utilitzava al seu fill per provocar, i amb actitud agresiva (inclús anava a pegar-li manotada a un), però no he vist democràcia. He vist com es permetia una manifestació no autoritzada que podia alterar l'ordre públic. Segons la sacrosanta Constitució Espanyola, això és il·legal, però no he vist democràcia. He vist com la Policia Nacional tractava respectuosament, i inclús es coordinava amb els feixites. A nosaltres ens miraven amb cara de fàstic, però no he vist democràc...