the write strategy of the client implement affects the set performance dramatically?

Todd Lipcon todd at amiestreet.com
Tue Mar 4 17:18:44 UTC 2008


Hi Yin,

Are you using SO_NODELAY on your client socket?

That's one thing to try. The other option is to use a buffered socket and 
only flush once you've buffered the entire request.

-Todd

On Wed, 5 Mar 2008, Yin Chen wrote:

> Hi:
>    I am involved in the optimization of the performance of a  memcached
> client library now(written by c).
>    And I found that if I want to set a big value(say: 9000 bytes long),
> prepare all the data and call write once or split the data to two writes
> will cause dramatic performance difference: the latter is about 100 times
> slow than the former.
>    I do the experiment on my own machine, a single core T43 notebook. Run
> one memcached server instance with the command "/usr/bin/memcached -m 64 -p
> 11211 -u root", and write code to connect to the 11211 port to write the set
> operation data. Iterate 100 times to set a 9000 bytes value each time. The
> client.c code prepares all the data and write the data once. The
> client_multi_write.c code splite the data to two writes. Run the two
> programs to get the above result.
>   I think it's partly related to the implement of the memcached? Anybody to
> confirm the above experiment or give me an explanation?
>   Thanks.
>
>
> -- 
> Chen Yin
> School of EE & CS, Peking University
>


More information about the memcached mailing list