Foros del Web » Programando para Internet » PHP »

Datos mysql en variable SESSION

Estas en el tema de Datos mysql en variable SESSION en el foro de PHP en Foros del Web. Tengo la duda de si seria aconsejable pasar todos los datos de una tabla donde estan los datos de usuario a una variable SESSION, habia ...
  #1 (permalink)  
Antiguo 25/03/2010, 03:16
 
Fecha de Ingreso: septiembre-2003
Mensajes: 65
Antigüedad: 20 años, 7 meses
Puntos: 1
Datos mysql en variable SESSION

Tengo la duda de si seria aconsejable pasar todos los datos de una tabla donde estan los datos de usuario a una variable SESSION, habia leido que esto satura el servidor, aunque no se bien como o si es asi. ¿Habria algun problema en pasar a SESSION varios valores text de mysql por ejemplo? Supongo que solo habra problema con los text o de mayor capacidad.
  #2 (permalink)  
Antiguo 25/03/2010, 04:07
Avatar de Tokkara  
Fecha de Ingreso: junio-2008
Mensajes: 131
Antigüedad: 15 años, 10 meses
Puntos: 5
Respuesta: Datos mysql en variable SESSION

Las sesiones son archivos temporales que se crean dentro del servidor. Por cada usuario que visite la página se podrá crear un archivo de sesión. Si métes datos muy grandes, como por ejemplo textos, en sesiones, harás que los archivos sean muy grandes. Y por tanto si tienes muchas visitas tendrás muchos archivos grandes guardados en el servidor. Además las sesiones no funcionan en usuarios que tengan desactivadas las cookies.


Un ejemplo: Un archivo de sesión de 10kb. Si tu página tiene 100 visitas online entonces tendrás 100 archivos de 10 Kb cada uno, un total de 1000kb. ¿No es mucho verdad? Pero piensa que cada archivo debe ser trasladado a memoria principal dentro del servidor, con lo que eso supone en tiempo y espacio. Si cada vez que refrescan la página PHP tiene que pasar 10kb de memoria secundaria a memoria principal, entonces la cosa se complica.


Las sesiones están pensadas para guardar datos más pequeños, más personales a cada usuario y más temporales. Si muchos de los textos que extraes de la BD son compartidos por varios usuarios, es decir, no son exclusivo de cada usuario. Quizás te convendría mejor usar una caché PHP que no las sesiones. Te dejo un enlace a google donde te muestran códigos de caché para PHP. Clase caché para PHP.
__________________
Revolucionario controlador de plantillas para php
www.simphple.com
  #3 (permalink)  
Antiguo 25/03/2010, 04:07
 
Fecha de Ingreso: agosto-2005
Ubicación: Argentina, Capital Federal
Mensajes: 435
Antigüedad: 18 años, 8 meses
Puntos: 2
Respuesta: Datos mysql en variable SESSION

La pregunta sería ¿es necesario que traigas desde BD tantos valores para propagarlos a través de la sesión? ¿no podrías guardar en tu sesión tal vez el ID de estos valores y recuperarlos cuando y solo en el caso que los necesites? Quizá podrías contarnos un poco más sobre tu aplicación para sugerirte algún diseño apropiado que se adecue a tus necesidades.

La información de una sesión de PHP nativa se guarda en un archivo de texto plano en tu servidor en el cual los datos a guardar se formatean en un formato parecido al arrojado por la función serialize() al serializar un array... haciendo algunas pruebillas podrás ver que tanto ocupa tu información de sesión en el servidor.

Particularmente, y si es que hay otras alternativas, no manejaría grandes cantidades de datos en una sesión ya que estaría replicando la información y generando una carga innecesaria.

Saludos.
__________________
R4DS en español | R4DS en inglés
  #4 (permalink)  
Antiguo 25/03/2010, 04:31
 
Fecha de Ingreso: septiembre-2003
Mensajes: 65
Antigüedad: 20 años, 7 meses
Puntos: 1
Respuesta: Datos mysql en variable SESSION

¿O sea que el problema seria entonces el tiempo de pasar del disco duro a la RAM, y que la RAM, al ser mucho mas limitada se podria saturar?

En la aplicacion los datos se lee y actualizan frecuentemente, tengo la alternativa de hacer consultas mysql para sacar los datos que necesite, pero me resulta mas comodo tenerlo todo en la misma tabla del usuario con session y no en varias tablas, pero visto que el rendimiento no seria el mismo lo que tengo pensado es meter en session los datos que no sean grandes y los demas en otras tablas. En el session solo estan los datos personales del usuario y no tenia pensado meter en session los datos de otras tablas.

Etiquetas: mysql, session, variables
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 00:53.