El paquete Memcache proporciona un cliente para el almacén de clave-valor distribuido en memoria de App Engine para pequeños fragmentos de datos arbitrarios.
Las operaciones fundamentales obtienen y establecen elementos, con claves según una string.
item0, err := memcache.Get(c, "key") if err != nil && err != memcache.ErrCacheMiss { return err } if err == nil { fmt.Fprintf(w, "memcache hit: Key=%q Val=[% x]\n", item0.Key, item0.Value) } else { fmt.Fprintf(w, "memcache miss\n") }
y
item1 := &memcache.Item{ Key: "foo", Value: []byte("bar"), } if err := memcache.Set(c, item1); err != nil { return err }
Variables
ErrCacheMiss, ErrCASConflict, ErrNoStats, ErrNotStored, ErrServerError
var (
// ErrCacheMiss means that an operation failed
// because the item wasn't present.
ErrCacheMiss = errors.New("memcache: cache miss")
// ErrCASConflict means that a CompareAndSwap call failed due to the
// cached value being modified between the Get and the CompareAndSwap.
// If the cached value was simply evicted rather than replaced,
// ErrNotStored will be returned instead.
ErrCASConflict = errors.New("memcache: compare-and-swap conflict")
// ErrNoStats means that no statistics were available.
ErrNoStats = errors.New("memcache: no statistics available")
// ErrNotStored means that a conditional write operation (i.e. Add or
// CompareAndSwap) failed because the condition was not satisfied.
ErrNotStored = errors.New("memcache: item not stored")
// ErrServerError means that a server error occurred.
ErrServerError = errors.New("memcache: server error")
)
Gob, JSON
var (
// Gob is a Codec that uses the gob package.
Gob = Codec{gobMarshal, gobUnmarshal}
// JSON is a Codec that uses the json package.
JSON = Codec{json.Marshal, json.Unmarshal}
)
Funciones
func Add
Add escribe el elemento dado, si ya no existe ningún valor para su clave. Se muestra ErrNotStored si no se cumple esa condición.
func AddMulti
AddMulti es una versión por lotes de Add. Es posible que se muestre appengine.MultiError.
func CompareAndSwap
CompareAndSwap escribe el elemento dado que mostró previamente Get, si el valor no se modificó o expulsó entre las llamadas Get y CompareAndSwap. La clave del elemento no debe cambiar entre llamadas, pero todos los demás campos del elemento pueden variar. Se muestra ErrCASConflict si el valor se modificó entre las llamadas. Se muestra ErrNotStored si el valor se expulsó entre las llamadas.
func CompareAndSwapMulti
CompareAndSwapMulti es una versión por lotes de CompareAndSwap. Es posible que se muestre appengine.MultiError.
func Delete
Delete borra el elemento para la clave dada. Se muestra ErrCacheMiss si no se puede encontrar el elemento especificado. La clave debe tener como máximo 250 bytes de longitud.
func DeleteMulti
DeleteMulti es una versión por lotes de Delete. Si no se puede encontrar ninguna clave, se muestra appengine.MultiError. Cada clave debe tener como máximo 250 bytes de longitud.
func Flush
Flush limpia todos los elementos de Memcache.
func GetMulti
GetMulti es una versión por lotes de Get. El mapa que se muestra de las claves a los elementos puede tener menos elementos que la porción de entrada, debido a errores de caché de Memcache. Cada clave debe tener como máximo 250 bytes de longitud.
func Increment
func Increment(c context.Context, key string, delta int64, initialValue uint64) (newValue uint64, err error)
Increment aumenta atómicamente el valor decimal en la clave dada por delta y muestra el nuevo valor. El valor debe caber en un uint64. El desbordamiento se une y el subdesbordamiento tiene un máximo de cero. El delta proporcionado puede ser negativo. Si la clave no existe en Memcache, el valor inicial proporcionado se usa para propagarla atómicamente antes de aplicar el delta. La clave debe tener como máximo 250 bytes de longitud.
func IncrementExisting
IncrementExisting funciona como Increment, pero supone que la clave ya existe en Memcache y no toma un valor inicial. IncrementExisting puede ahorrar trabajo si calcular el valor inicial es costoso. Se muestra un error si no se puede encontrar el elemento especificado.
func PeekMulti
PeekMulti es una versión por lotes de Peek. Es similar a GetMulti, pero también propaga Item.Timestamps.
func Set
Set escribe el elemento dado, incondicionalmente.
func SetMulti
SetMulti es una versión por lotes de Set. Es posible que se muestre appengine.MultiError.
Códec
type Codec struct {
Marshal func(interface{}) ([]byte, error)
Unmarshal func([]byte, interface{}) error
}
Codec representa un par simétrico de funciones que implementan un códec. Los elementos almacenados en Memcache o recuperados de allí mediante un códec tienen sus valores ordenados o no ordenados.
Todos los métodos proporcionados para Codec se comportan de manera análoga a la función de nivel de paquete con el mismo nombre.
func (Codec) Add
Add escribe el elemento dado, si ya no existe ningún valor para su clave. Se muestra ErrNotStored si no se cumple esa condición.
func (Codec) AddMulti
AddMulti es una versión por lotes de Add. Es posible que se muestre appengine.MultiError.
func (Codec) CompareAndSwap
CompareAndSwap escribe el elemento dado que mostró previamente Get, si el valor no se modificó o expulsó entre las llamadas Get y CompareAndSwap. La clave del elemento no debe cambiar entre llamadas, pero todos los demás campos del elemento pueden variar. Se muestra ErrCASConflict si el valor se modificó entre las llamadas. Se muestra ErrNotStored si el valor se expulsó entre las llamadas.
func (Codec) CompareAndSwapMulti
CompareAndSwapMulti es una versión por lotes de CompareAndSwap. Es posible que se muestre appengine.MultiError.
func (Codec) Get
Get obtiene el elemento para la clave dada y decodifica el valor obtenido en v. Se muestra ErrCacheMiss por un error de caché de Memcache. La clave debe tener como máximo 250 bytes de longitud.
func (Codec) Set
Set escribe el elemento dado, incondicionalmente.
func (Codec) SetMulti
SetMulti es una versión por lotes de Set. Es posible que se muestre appengine.MultiError.
Elemento
type Item struct {
// Key is the Item's key (250 bytes maximum).
Key string
// Value is the Item's value.
Value []byte
// Object is the Item's value for use with a Codec.
Object interface{}
// Flags are server-opaque flags whose semantics are entirely up to the
// App Engine app.
Flags uint32
// Expiration is the maximum duration that the item will stay
// in the cache.
// The zero value means the Item has no expiration time.
// Subsecond precision is ignored.
// This is not set when getting items.
Expiration time.Duration
// ItemTimestamps are server values only returned when calling Peek and PeekMulti.
// The timestamps are nil when calling Get and GetMulti.
Timestamps ItemTimestamps
// contains filtered or unexported fields
}
Item es la unidad que Memcache obtiene y establece.
func Get
Get obtiene el elemento para la clave dada. ErrCacheMiss se muestra por un error de caché de Memcache. La clave debe tener como máximo 250 bytes de longitud.
func Peek
Peek obtiene el elemento para la clave determinada y, además, propaga Item.Timestamps. ErrCacheMiss se muestra por un error de caché de Memcache. La clave debe tener como máximo 250 bytes de longitud.
ItemTimestamps
type ItemTimestamps struct {
// Expiration is related to Item.Expiration but it is a Time (not a Duration),
// provided by the server. It is not meant to be set by the user.
Expiration *time.Time
// LastAccess is the last time the Item was accessed.
LastAccess *time.Time
}
Las ItemTimestamps son marcas de tiempo que el servidor proporciona de manera opcional. Consulta Peek y PeekMulti.
Estadísticas
type Statistics struct {
Hits uint64 // Counter of cache hits
Misses uint64 // Counter of cache misses
ByteHits uint64 // Counter of bytes transferred for gets
Items uint64 // Items currently in the cache
Bytes uint64 // Size of all items currently in the cache
Oldest int64 // Age of access of the oldest item, in seconds
}
Statistics representa un conjunto de estadísticas sobre la memoria caché de Memcache. Esto puede incluir elementos que han caducado, pero que aún no se han quitado de la caché.
func Stats
func Stats(c context.Context) (*Statistics, error)
Stats recupera las estadísticas actuales de Memcache.