G
Guest
I’m researching the idea of using caching in my application. And I wanted to
get other people thoughts that have used it with .NET 2.0. Below is an
explanation of the current process:
I have an application with several web pages. When any of these pages is
first loaded, it retrieves the information from SQL and stores the
information in a DataSet. This DataSet is then converted to a Session
variable so that it can be used over and over without the need to reconnect
to the database to refresh the data. The only time connections to SQL are
made is when the user requests to DELETE or UPDATE the physical records. Once
the delete/update is complete, I convert the Session variable back to a
dataset and perform the same action on the dataset. Next I rebind the dataset
back to the control and redisplay the page.
All works great and it is fast. But it takes a lot of memory to store those
datasets for each user session. Not to mention that if user(A) makes a change
to a record, and user (B) is view the same record, b/c they are session
variables, user (B) will never see user (A) changes.
So I wanted to try using disk caching where user (A) requests a record, it
gets cached on the server hard drive. SQL update and deletes happen as they
do now, but I update the cache instead of a dataset in memory.
If user (B) accesses the same record, and this record is already in cache
from another user, it reads the cache instead of connecting to SQL to issue
the SELECT statements. This cache would need to reside on the drive for say
24 hrs.
All this to say, have any of you done anything similar? What are thing
things I should watch out for? What’s a good resource to get started using
this method in C#. I know disk I/O is slower then memory, but its faster then
connecting to SQL every time to refresh the data.
get other people thoughts that have used it with .NET 2.0. Below is an
explanation of the current process:
I have an application with several web pages. When any of these pages is
first loaded, it retrieves the information from SQL and stores the
information in a DataSet. This DataSet is then converted to a Session
variable so that it can be used over and over without the need to reconnect
to the database to refresh the data. The only time connections to SQL are
made is when the user requests to DELETE or UPDATE the physical records. Once
the delete/update is complete, I convert the Session variable back to a
dataset and perform the same action on the dataset. Next I rebind the dataset
back to the control and redisplay the page.
All works great and it is fast. But it takes a lot of memory to store those
datasets for each user session. Not to mention that if user(A) makes a change
to a record, and user (B) is view the same record, b/c they are session
variables, user (B) will never see user (A) changes.
So I wanted to try using disk caching where user (A) requests a record, it
gets cached on the server hard drive. SQL update and deletes happen as they
do now, but I update the cache instead of a dataset in memory.
If user (B) accesses the same record, and this record is already in cache
from another user, it reads the cache instead of connecting to SQL to issue
the SELECT statements. This cache would need to reside on the drive for say
24 hrs.
All this to say, have any of you done anything similar? What are thing
things I should watch out for? What’s a good resource to get started using
this method in C#. I know disk I/O is slower then memory, but its faster then
connecting to SQL every time to refresh the data.