How to manage session variables in a web cluster?

2019-02-04 22:43发布

Session variables are normally keept in the web server RAM memory.

In a cluster, each request made by a client can be handled by a different cluster node. right?!

So, in this case...

  • What happens with session variables? Aren't they stored in the nodes RAM memory?
  • How the other nodes will handled my request correctly if it doesn't have my session variables, or at least all of it?
  • This issue is treated by the web server (Apache, IIS) or by the language runtime (PHP, ASP.NET, Ruby, JSP)?

EDIT: Is there some solution for Classic ASP?

8条回答
Summer. ? 凉城
2楼-- · 2019-02-04 22:44

There are 3 ways to store session state in ASP.NET. The first is in process, where the variables are stored in memory. The second is to use a session state service by putting the following in your web.config file:

<sessionState
    mode="StateServer"
    stateConnectionString="tcpip=127.0.0.1:42424"
    sqlConnectionString="data source=127.0.0.1;user id=sa;password="
    cookieless="false"
    timeout="20" />

As you can see in the stateConnectionString attribute, the session state service can be located on a different computer.

The third option is to use a centralized SQL database. To do that, you put the following in your web.config:

<sessionState
    mode="SQLServer"
    stateConnectionString="tcpip=127.0.0.1:42424"
    sqlConnectionString=
     "data source=SERVERHAME;user id=sa;password="
    cookieless="false"
    timeout="20"
/>

More details on all of these options are written up here: http://www.ondotnet.com/pub/a/dotnet/2003/03/24/sessionstate.html

查看更多
相关推荐>>
3楼-- · 2019-02-04 22:45

With Hazelcast, you can either use Hazelcast distributed map to store and share sessions across the cluster or let Hazelcast Webapp Manager do everything for you. Please check out the docs for details. Hazelcast is a distributed/partitioned, super lite and easy, free data distribution solution for Java.

Regards,

-talip

http://www.hazelcast.com

查看更多
We Are One
4楼-- · 2019-02-04 22:45

In ASP.NET you can persist session data to an SQL Server database which is common to all web servers in the cluster.

Once configured (in the web.config for your site), the framework handles all of the persistance for you and you can access the session data as normal.

查看更多
男人必须洒脱
5楼-- · 2019-02-04 22:46

As with all sorts of thing, "it depends".

There are different solutions and approaches.

As mentioned, there's the concept of a centralized store for session state (database, memcached, shared file system, etc.).

There are also cluster wide caching systems available that make local data available to all of the machines in the cluster. Conceptually it's similar to the centralized session state store, but this data isn't persistent. Rather it lives within the individual nodes and is replicated using some mechanism provided by your provider.

Another method is server pinning. When a client hits the cluster the first time, some mechanism (typically a load balancer fronting the cluster) pins the client to a specific server. In a typical client lifespan, that client will spend their entire time on a single machine.

For the failover mechanism, each machine of the cluster is paired with another machine, and so any session changes are shared with the paired machine. Should the clients pinned machine encounter an issue, the client will hit another machine. At this point, perhaps due to cookies, the new machine sees that it's not the original machine for the client, so it pings both the original machine, and the paired machine for the clients session data.

At that point the client may well be pinned to the new machine.

Different platforms do it in different ways, including having no session state at all.

查看更多
淡お忘
6楼-- · 2019-02-04 22:52

To extend @yogman's answer.

Memcached is pure awesomeness! It's a high performance and distributed object cache.

And even though I mentioned distributed it's basically as simple as starting one instance on one of your spare/idle servers, you configure it as in ip, port and how much ram to use and you're done.

memcached -d -u www -m 2048 -l 10.0.0.8 -p 11211

(Runs memcached in daemon mode, as user www, 2048 MB (2 GB) of RAM on IP 10.0.0.8 with port 11211.)

From then on, you ask memcached for data and if the data is not yet cached you pull it from the original source and store it in memcached. I'm sure you are familiar with cache basics.

In a cluster environment you can link up your memcached's into a cluster and replicate the cache across your nodes. Memcached runs on Linux, Unix and Windows, start it anywhere you have spare RAM and start using your resources.

APIs for memcached should be generally available. I'm saying should because I only know of Perl, Java and PHP. But I am sure that e.g. in Python people have means to leverage it as well. There is a memcached wiki, in case you need pointers, or let me know in the comments if I was raving too much. ;)

查看更多
爱情/是我丢掉的垃圾
7楼-- · 2019-02-04 22:57

To achieve load balancing for classic ASP, you may store the user specific values in the database and pass a reference unique id in the URL as follows.

Maintain a session table in the database which generates a unique id for each record. The first time you want to store session specific data, generate a record in your session table and store the session values in it. Obtain the unique id of the new session record and re-write all links in your web application to send the unique id as part of querystring.

In every subsequent page where you need the session data, query the session table with the unique id passed in the querystring.

Example:

Consider your website to have 4 pages: Login.asp, welcome.asp, taskList.asp, newtask.asp

When the user logs in using login.asp page, after validating the user, create a record in session table and store the required session specific values (lets say user's login date/time for this example). Obtain the new session record's unique id (lets say the unique id is abcd).

Append all links in your website with the unique id as below:

  • welcome.asp?sessionId=abcd
  • tasklist.asp?sessionId=abcd
  • newtask.asp?sessionId=abcd

Now, if in any of the above web pages you want to show the user's login date/time, you just have to query your session table with the sessionID parameter (abcd in this case) and display to the user.

Since the unique value identifying the session is a part of the URL, any of your web servers serving the user will be able to display the correct login date/time value.

Hope this helps.

查看更多
登录 后发表回答