8. 2.4 Release ???http://antirez.com/post/everything-about-redis-24Redis Main ??? ???Small sorted sets now use significantly less memory.RDB Persistence is much much faster for many common data sets.Many write commands now accept multiple arguments, so you can add multiple items into a Set or List with just a single command. This can improve the performance in a pretty impressive way.Our new allocator is jemalloc.Less memory is used by the saving child, as we reduced the amount of copy on write.INFO is more informative. However it is still the old 2.2-alike INFO, not the new one into unstable composed of sub sections.The new OBJECT command can be used to introspect Redis values.The new CLIENT command allows for connected clients introspection.Slaves are now able to connect to the master instance in a non-blocking fashion.Redis-cli was improved in a few ways.Redis-benchmark was improved as well.Make is now colorized ;)VM has been deprecated.In general Redis is now faster than ever.We have a much improved Redis test framework.
10. ?? / ??http://redis.io/download// ??$ wget http://redis.googlecode.com/files/redis-2.2.12.tar.gz $ tar xzf redis-2.2.12.tar.gz $ cd redis-2.2.12 $ make// ?? ??$ cd src$ cd redis-server(daemon).. Log..// ????? ??$ cd????/src ; redis-cli redis> set foo bar OK redis> get foo "bar"
11. Example Code>?set foo 0"OK">?incr foo1>?incr foo2>?incr foo3>?get foo"3¡°>?decr foo2>?set hello world"OK">?get hello"world">?exists hellotrue>?type hello"string">?rename hello olleh"OK">?get olleh"world">?del olleh1>?get ollehnull>?set a 1"OK">?set b 2"OK">?set c 3"OK">?mget a b c["1","2","3"]>?set hello world"OK">?get hello"world"> ?set a 1¡®1¡¯>?expire a 100true>?get a"`1">?get a"`1¡°(100? ?)>?get anull>?sadd seta footrue>?sadd seta bartrue>?saddsetb footrue>?sinter seta setb["foo"]
12. Example Code>?hset user:1 name xtrue>?hset user:1 lastname ytrue>?hset user:2 name aatrue>?hget user:1wrong number of arguments (1 for 2)>?hget user:1 name"x">?hgetall user:1{"name":"x","lastname":"y"}>?hget user:2wrong number of arguments (1 for 2)>?hget user:2 name"aa">?lpush list a1>?lpush list b2>?lpush list c3>?lpush list d4>?lrange list 0 2["d","c","b"]>?lrange list 0 3["d","c","b","a"]>?lrange list 2 3["b","a"]>?sadd set 1true>?sadd set 2true>?sadd set 3true>?smembers set["3","1","2"]>?zaddss 1 aatrue>?zaddss 10 zztrue>?zaddss 9 yytrue>?zaddss 2 bbtrue>?zrangess 0 -1["aa","bb","yy","zz"]LISTSETSortedSETHash
13. Example Code>?multi"OK">?lpushclist a"QUEUED">?lpushclist b"QUEUED">?lpushclist c"QUEUED">?lrangeclist 0 -1"QUEUED">?exec[1,2,3,["c","b","a"]]>?multi"OK">?lpushdlist a"QUEUED">?lpushdlist b"QUEUED">?discard"OK"TXTXCheck and Set ? ??(watch)
18. ??? ??Slave ??? ??? ??? ?? ????. Replication ??slave asks for SYNCmaster BGSAVE, slave waitsmaster BGSAVE finished, the initial bulk data (the .rdb file) is transfered to slavemaster accumulates all the new differences for the slavemaster finishes sending the whole initial rdb file to slavemaster start feeding the slave with the accumulated buffer, and with anything new arriving from clients, if they are writes.