Skip to content
Toggle navigation
Toggle navigation
This project
Loading...
Sign in
张磊
/
FileStorageBeego
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Network
Create a new issue
Builds
Commits
Issue Boards
Files
Commits
Network
Compare
Branches
Tags
d7090689
authored
2014-07-24 22:54:56 +0800
by
astaxie
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
cache: change the memcache &redis driver
change the memcache to the newest
1 parent
52d153da
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
30 additions
and
32 deletions
cache/memcache/memcache.go
cache/redis/redis.go
cache/redis/redis_test.go
cache/memcache/memcache.go
View file @
d709068
...
...
@@ -12,16 +12,17 @@ package memcache
import
(
"encoding/json"
"errors"
"strings"
"github.com/b
eego
/memcache"
"github.com/b
radfitz/gomemcache
/memcache"
"github.com/astaxie/beego/cache"
)
// Memcache adapter.
type
MemcacheCache
struct
{
conn
*
memcache
.
C
onnection
conninfo
string
conn
*
memcache
.
C
lient
conninfo
[]
string
}
// create new memcache adapter.
...
...
@@ -36,10 +37,8 @@ func (rc *MemcacheCache) Get(key string) interface{} {
return
err
}
}
if
v
,
err
:=
rc
.
conn
.
Get
(
key
);
err
==
nil
{
if
len
(
v
)
>
0
{
return
string
(
v
[
0
]
.
Value
)
}
if
item
,
err
:=
rc
.
conn
.
Get
(
key
);
err
==
nil
{
return
string
(
item
.
Value
)
}
return
nil
}
...
...
@@ -55,11 +54,8 @@ func (rc *MemcacheCache) Put(key string, val interface{}, timeout int64) error {
if
!
ok
{
return
errors
.
New
(
"val must string"
)
}
stored
,
err
:=
rc
.
conn
.
Set
(
key
,
0
,
uint64
(
timeout
),
[]
byte
(
v
))
if
err
==
nil
&&
stored
==
false
{
return
errors
.
New
(
"stored fail"
)
}
return
err
item
:=
memcache
.
Item
{
Key
:
key
,
Value
:
[]
byte
(
v
),
Expiration
:
int32
(
timeout
)}
return
rc
.
conn
.
Set
(
&
item
)
}
// delete value in memcache.
...
...
@@ -69,20 +65,29 @@ func (rc *MemcacheCache) Delete(key string) error {
return
err
}
}
_
,
err
:=
rc
.
conn
.
Delete
(
key
)
return
err
return
rc
.
conn
.
Delete
(
key
)
}
// [Not Support]
// increase counter.
func
(
rc
*
MemcacheCache
)
Incr
(
_
string
)
error
{
return
errors
.
New
(
"not support in memcache"
)
func
(
rc
*
MemcacheCache
)
Incr
(
key
string
)
error
{
if
rc
.
conn
==
nil
{
if
err
:=
rc
.
connectInit
();
err
!=
nil
{
return
err
}
}
_
,
err
:=
rc
.
conn
.
Increment
(
key
,
1
)
return
err
}
// [Not Support]
// decrease counter.
func
(
rc
*
MemcacheCache
)
Decr
(
_
string
)
error
{
return
errors
.
New
(
"not support in memcache"
)
func
(
rc
*
MemcacheCache
)
Decr
(
key
string
)
error
{
if
rc
.
conn
==
nil
{
if
err
:=
rc
.
connectInit
();
err
!=
nil
{
return
err
}
}
_
,
err
:=
rc
.
conn
.
Decrement
(
key
,
1
)
return
err
}
// check value exists in memcache.
...
...
@@ -92,13 +97,10 @@ func (rc *MemcacheCache) IsExist(key string) bool {
return
false
}
}
v
,
err
:=
rc
.
conn
.
Get
(
key
)
_
,
err
:=
rc
.
conn
.
Get
(
key
)
if
err
!=
nil
{
return
false
}
if
len
(
v
)
==
0
{
return
false
}
return
true
}
...
...
@@ -121,7 +123,7 @@ func (rc *MemcacheCache) StartAndGC(config string) error {
if
_
,
ok
:=
cf
[
"conn"
];
!
ok
{
return
errors
.
New
(
"config has no conn key"
)
}
rc
.
conninfo
=
cf
[
"conn"
]
rc
.
conninfo
=
strings
.
Split
(
cf
[
"conn"
],
";"
)
if
rc
.
conn
==
nil
{
if
err
:=
rc
.
connectInit
();
err
!=
nil
{
return
err
...
...
@@ -132,11 +134,7 @@ func (rc *MemcacheCache) StartAndGC(config string) error {
// connect to memcache and keep the connection.
func
(
rc
*
MemcacheCache
)
connectInit
()
error
{
c
,
err
:=
memcache
.
Connect
(
rc
.
conninfo
)
if
err
!=
nil
{
return
err
}
rc
.
conn
=
c
rc
.
conn
=
memcache
.
New
(
rc
.
conninfo
...
)
return
nil
}
...
...
cache/redis/redis.go
View file @
d709068
...
...
@@ -14,7 +14,7 @@ import (
"errors"
"time"
"github.com/
beego
/redigo/redis"
"github.com/
garyburd
/redigo/redis"
"github.com/astaxie/beego/cache"
)
...
...
cache/redis/redis_test.go
View file @
d709068
...
...
@@ -14,7 +14,7 @@ import (
"testing"
"time"
"github.com/
beego
/redigo/redis"
"github.com/
garyburd
/redigo/redis"
"github.com/astaxie/beego/cache"
)
...
...
Write
Preview
Styling with
Markdown
is supported
Attach a file
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to post a comment