I have an already developed application on Linux which would benefit from one process with more RAM than it would by off-loading individual processes onto smaller compute nodes with less RAM. So this is the one option I'm researching here.
I'd like to run one process on the master node and yet somehow make all the available RAM on all compute nodes appear as one large block of available RAM to the master node (as if a single system).
As far as I know, this use of a Single System Image (SSI) is now called Distributed Shared Memory (DSM). I've been looking into single system images but can't tell which ones support this.
Does anyone know which of the open source SSI packages would accomplish this? I was also wondering about OpenSSI, though the lists are very inactive.
Edit:
In my use of DSM, I was thinking in the context of having physically separate address spaces on different compute nodes, and being able to access them as if they were one logical shared address space available to a single process on a single node, the head node. I used the term SSI (and incorrectly in this context) because I was wanting the system to appear as one single system from the users perspective. My current use of SSI, is a file system in which all diskless nodes boot from a single image in a specific location on the master node.
I understand the memory of multiple nodes is accomplished by means of a comm lib (which is currently in use), but I need more RAM. So in researching SSI packages that seem to mention the ability to support a "Single IPC Space", I was thinking this might be something useful. I had read several white papers where the memory management of nodes could be handled at the OS level and therefore I wouldn't need the communication libary as this would be abstracted below user-space.
I'd like to not modify the code as it would already take advantage of large amounts of RAM if it were already available on the localhost. And I do have large amounts of RAM, except that RAM is distributed on different nodes and therefore does require the use of some MPI type libraries. Modifying the code is costly, adding more RAM requires a new cluster, costly. However, a solution that would give my application the illusion of a very large single address space ... I can only hope.
@Ender
You can download vSMP Foundation Free - it will allow you to aggregate the memory of up to 8 nodes, up to 1TB RAM total, free of charge. Note that the free version only allows for memory aggregation, meaning you will have the compute power of cores of only a single node, but the RAM of many.
http://www.ScaleMP.com/free