I was trying to use the one memcahed server with the java client on the same machine. i tried with 100 threads using the MemcachedClient using the same socket pool (with 300 socket connections minimum), after few seconds all the threads getting locked at  
com.danga.MemCached.SockIOPool.checkIn. I wanted to measure the memcached performance numbers with lots of threads concurrently executing the getMulti( ) method. <br><br>Using 1 thread, i get 150 msec response..when i tried with 5 threads i get 350 msec average...as i increase the threads the the response is slower and slower (2000 msecs average). Am i missing some configurations?, here is my config.
<br><br>SockIOPool pool = SockIOPool.getInstance( &quot;test&quot; );<br>pool.setServers(serverlist);<br><br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; pool.setInitConn( 100 );<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; pool.setMinConn( 100 );<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; pool.setMaxConn( 500 );<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; 
pool.setMaintSleep( 30 );<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; pool.setAliveCheck( true );<br><br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; pool.setNagle( false )<br><br>&quot;Thread-100&quot; prio=1 tid=0x083c8168 nid=0x1144 runnable [0xaee92000..0xaee93040]<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool.addSocketToPool
(SockIOPool.java:963)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool.checkIn(SockIOPool.java:1047)<br>&nbsp;&nbsp;&nbsp; - locked &lt;0x891392b8&gt; (a com.danga.MemCached.SockIOPool)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool.checkIn(SockIOPool.java
:1062)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool$SockIO.close(SockIOPool.java:1509)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.MemCachedClient.getMulti(MemCachedClient.java:1217)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.MemCachedClient.getMulti(MemCachedClient.java
:1141)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.test.MyBench$bench.run(FeeddoBench.java:136)<br>....<br>...<br>&quot;Thread-3&quot; prio=1 tid=0x0817b550 nid=0x10e3 waiting for monitor entry [0xb1f73000..0xb1f740c0]<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool.getConnection
(SockIOPool.java:874)<br>&nbsp;&nbsp;&nbsp; - waiting to lock &lt;0x891392b8&gt; (a com.danga.MemCached.SockIOPool)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool.getSock(SockIOPool.java:716)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.MemCachedClient.getMulti
(MemCachedClient.java:1205)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.MemCachedClient.getMulti(MemCachedClient.java:1141)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.test.MyBench$bench.run(FeeddoBench.java:136)<br><br>....<br>&quot;Thread-0&quot; daemon prio=1 tid=0x081794b8 nid=0x10e0 waiting for monitor entry [0xb20f6000..0xb20f6e40]
<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool.selfMaint(SockIOPool.java:1161)<br>&nbsp;&nbsp;&nbsp; - waiting to lock &lt;0x891392b8&gt; (a com.danga.MemCached.SockIOPool)<br>&nbsp;&nbsp;&nbsp; at com.danga.MemCached.SockIOPool$MaintThread.run(SockIOPool.java
:1310)<br>