mirror of
https://gitee.com/johng/gf
synced 2026-06-07 02:12:11 +08:00
* up * rename function names for package gtcp/gudp; add proxy example for gtcp.Server (#2295) * fix router supported for handler of package ghttp; fix json tag name issue when it contains for package goai * add proxy example for http server * rename function names for package gtcp/gudp; add proxy example for gtcp.Server * move TX from struct to interface for package gdb (#2247) * move TX from struct to interface for package gdb * i updates * up * up * fix comment Co-authored-by: houseme <housemecn@gmail.com> * move `go-redis` implements `Adapter` from package `gredis` to `contrib/nosql/redis`; add redis string operation functions for package `gredis` (#2240) * unify configuration pattern of for package gdb * version updates * improve implements `internal/rwmutex` and `internal/mutex`; add `TablesFields` cache implements in `gdb.Core` instead of `contrib/drivers`; add `ClearTableFields` and `ClearCache` functions for `gdb.Core` (#2128) * add ClearTableFiels/ClearCache for Core of package gdb * improve TableFields for contrib/drivers * fix UT case for contrib/drivers/clickhouse * remove unecessary attribute state for internal/rwmutex and internal/mutex * add ClearTableFieldsAll/ClearCacheAll for gdb.Core * improve clickhouse driver * improve clickhouse driver * fix ut * feat: improve import Co-authored-by: daguang <daguang830@gmail.com> Co-authored-by: houseme <housemecn@gmail.com> * refract builtin rules management mechanism, add `eq/not-eq/gt/gte/lt/lte/before/before-equal/after/after-equal/array/not-regex` rules for for package `gvalid` (#2133) * refract builtin rules management for package gvalid * refract builtin rules management for package gvalid * refract builtin rules management for package gvalid * add valiation rules and implements for package gvalid * UT cases update for package gvalid * improve error message of fields validation for package gvalid * up * add more validation rules for package gvalid * add validation rule foreach for package gvalid (#2136) * add ToSQL/CatchSQL funcions for package gdb (#2137) * add ToSQL/CatchSQL funcions for package gdb * Update gdb_core_underlying.go * fix ci Co-authored-by: houseme <housemecn@gmail.com> * add redis interface for package gredis * up * remove `FilteredLink` function for DB and all driver implements and improve details for package gdb (#2142) * fix: pgsql DoExec Transaction checks (#2101) Co-authored-by: John Guo <john@johng.cn> * improve package gdb * up * up * up * up * up * add DriverWrapper and DriverWarapperDB for package gdb * add DriverWrapper and DriverWarapperDB for package gdb * up Co-authored-by: HaiLaz <739476267@qq.com> * add new database driver `dm` * add drivers dm * upd go version * add gf ci yaml Co-authored-by: Xu <zhenghao.xu> * move go-redis implements from package gredis to contrib/nosql/redis; add redis string operation functions for package gredis * improve `contrib/drivers/dm` (#2144) * improve contrib/drivers/dm * format TODO list info * 1) add config.Name is required 2) The upper layer no longer needs to specify the schema 3) Adjust unit tests Co-authored-by: Xu <zhenghao.xu> Co-authored-by: houseme <housemecn@gmail.com> * move redis adapter related ut case from package gcache/gsession to package contrib/nosql/redis * up * up * up * up * up * improve comment * add implements of `gcfg.Adapter` using kubernetes configmap (#2145) * remove Logger from kubecm.Client * README updates for package kubecm * error message update for package gredis * comment update for package gdb * Feature/v2.2.0 gredis (#2155) * improve package gredis (#2162) * improve package gredis * Update gredis_redis_group_list.go * fix * up Co-authored-by: houseme <housemecn@gmail.com> * up * up * up * up * up * up * add func Test_GroupScript_Eval * ut cases for group string * UT cases update for group script * mv redis operation implements to contrib/nosql/redis from package gredis * test: add redis group list unit test (#2248) * test: add redis group list unit test * improve comment * test: fix redis group list unit test Co-authored-by: houseme <housemecn@gmail.com> * up * add func Test_GroupGeneric_Copy, Test_GroupGeneric_Exists,Test_GroupGeneric_Type,Test_GroupGeneric_Unlink,Test_GroupGeneric_Rename,Test_GroupGeneric_Move,Test_GroupGeneric_Del * add Redis GroupGeneric UnitTest (#2253) add func Test_GroupGeneric_RandomKey,Test_GroupGeneric_DBSize,Test_GroupGeneric_Keys,Test_GroupGeneric_FlushDB,Test_GroupGeneric_FlushAll,Test_GroupGeneric_Expire,Test_GroupGeneric_ExpireAt * hash test case completed (#2260) Co-authored-by: junler <sunjun@bookan.com> * add Redis GroupGeneric Unit Test part2 (#2258) * up * ci updates * ci updates * up * Feature/contrib redis fsprouts (#2274) * Feature/contrib redis starck (#2275) * up * up * fix `/*` router supported for handler of package ghttp; fix json tag name issue when it contains `,` for package goai; add proxy example for http server (#2294) * fix router supported for handler of package ghttp; fix json tag name issue when it contains for package goai * add proxy example for http server * fix: update szenius/set-timezone@v1.1 (#2293) * add Tag* functions to retreive most commonly used tag value from struct field for package gstructs; use description tag as default value if brief is empty for gcmd.Argument (#2299) * fix cache issue in Count/Value functions for gdb.Model (#2300) * add Tag* functions to retreive most commonly used tag value from struct field for package gstructs; use description tag as default value if brief is empty for gcmd.Argument * fix cache issue in Count/Value functions for gdb.Model * add more ut case for package gdb * version updates * add minus of `start` parameter support for `gstr.Substr`, like the `substr` function in `PHP` (#2297) * Make the substr like the substr in PHP Make the substr like the substr in PHP * Update gstr_z_unit_test.go * Update gstr_z_unit_test.go * Make the SubStrRune like the mb_substr in PHP Make the SubStrRune like the mb_substr in PHP * Update gstr_z_unit_test.go * Update gstr_z_unit_test.go * Update gins_z_unit_view_test.go * Update gview_z_unit_test.go * add ut cases for package gcode (#2307) * add ut cases for package gerror (#2304) * add ut cases for package gerror * add ut cases for package gerror * add ut cases for package gtime (#2303) * add ut cases for package gtime * add ut cases for package gtime * add ut cases for package gtime * add ut cases for package glog (#2302) * add ut cases for package glog * add ut cases for package glog * add ut cases for package glog * add ut cases for package glog * add ut cases for package glog * add ut cases for package glog * change result data type of function Count from int to int64 for package gdb (#2298) * feat: modify model count value int64 * fix * fix:modify int64 * fix * feat: cmd gf prebuild suport oracle (#2312) * add ut cases for package g (#2315) * add ut cases for package gdebug (#2313) * add ut cases for package gdebug * add ut cases for package gdebug * add ut cases for package gdebug Co-authored-by: houseme <housemecn@gmail.com> * add zookeeper registry support (#2284) * add ut cases for package glog part2 (#2317) * fix invalid UpdatedAt usage in soft deleting feature for package gdb (#2323) * fix issue in failed installing when there's shortcut between file paths for command install (#2326) * fix issue in failed installing when has shortcut between file paths for command install * version updates * template for command gf updates * improve lru clearing for package gcache (#2327) * add ut cases for package ghttp_middleware and ghttp_request (#2344) * add ut cases for package ghttp_middleware * add ut cases for package ghttp_request * add ut cases for package ghttp_request * add ut cases for package ghttp_response (#2352) * add ut cases for package ghttp_response * add ut cases for package ghttp_response * add ut cases for package ghttp_response * add ut cases for package ghttp_request (#2351) * add ut cases for package ghttp_middleware * add ut cases for package ghttp_request * add ut cases for package ghttp_request * add ut cases for package ghttp_request * add ut cases for package ghttp_request - form * add ut cases for package ghttp_request - query * add ut cases for package ghttp_request - request * add ut cases for package ghttp_request - router * add ut cases for package gcache (#2341) * gTcp Example Function: 1.NewConn 2.NewConnTLS 3.NewConnKeyCrt * gTcp Example Function: 1.Send * add example function ExampleConn_Recv and ExampleConn_RecvWithTimeout * add example function 1. ExampleConn_SendWithTimeout 2. ExampleConn_RecvLine 3. ExampleConn_RecvTill * add example function 1. ExampleConn_SendRecv 2. ExampleConn_SendRecvWithTimeout 3. ExampleConn_SetDeadline 4. ExampleConn_SetReceiveBufferWait * add gtcp test function 1. Test_Package_Option_HeadSize4 2. Test_Package_Option_Error * add gtcp example function 1. ExampleGetFreePorts 2. ExampleSend 3. ExampleSendRecv 4. ExampleSendWithTimeout 5. ExampleSendRecvWithTimeout 6. ExampleMustGetFreePort * add gtcp example function 1. ExampleSendPkg 2. ExampleSendRecvPkg 3. ExampleSendPkgWithTimeout 4. ExampleSendRecvPkgWithTimeout * add gtcp test function 1. Test_Pool_Send 2. Test_Pool_Recv 3. Test_Pool_RecvLine 4. Test_Pool_RecvTill 5. Test_Pool_RecvWithTimeout 6. Test_Pool_SendWithTimeout 7. Test_Pool_SendRecvWithTimeout * fix * add gtcp example function 1. ExampleGetServer 2. ExampleSetAddress 3. ExampleSetHandler 4. ExampleRun_NilHandle * exec CI * exec CI * exec CI * modify test server address * modify and exec CI * modify and exec CI * modify and exec CI * modify and exec CI * modify and exec CI * modify and exec CI * add example funcion ExampleConn_Recv_Once and fix * fix * add some error case in example function * add some error case in example function * 1.add example function ExampleNewServerKeyCrt 2.add function SendRecvPkgWithTimeout unit test * add function Test_Server_NewServerKeyCrt unit test * revert * add function Test_Package_Timeout, Test_Package_Option_HeadSize3, Test_Conn_RecvPkgError unit test * fix * add example function 1.ExampleClient_Clone 2.ExampleLoadKeyCrt * add example function 1.ExampleNewNetConnKeyCrt * fix * add example function 1.ExampleClient_DeleteBytes 2.ExampleClient_HeadBytes 3.ExampleClient_PatchBytes 4.ExampleClient_ConnectBytes 5.ExampleClient_OptionsBytes 6.ExampleClient_TraceBytes 7.ExampleClient_PutBytes * add example function 1.ExampleClient_Prefix 2.ExampleClient_Retry 3.ExampleClient_RedirectLimit * add example function 1.ExampleClient_SetBrowserMode 2.ExampleClient_SetHeader 3.ExampleClient_SetRedirectLimit * add example function 1.ExampleClient_SetTLSKeyCrt 2.ExampleClient_SetTLSConfig modify example funcion 1.ExampleClient_SetProxy 2.ExampleClient_Proxy * add example function 1.ExampleClient_PutContent 2.ExampleClient_DeleteContent 3.ExampleClient_HeadContent 4.ExampleClient_PatchContent 5.ExampleClient_ConnectContent 6.ExampleClient_OptionsContent 7.ExampleClient_TraceContent 8.ExampleClient_RequestContent * add example function 1.ExampleClient_RawRequest * add unit function 1.TestGetFreePorts 2.TestNewConn 3.TestNewConnTLS 4.TestNewConnKeyCrt 5.TestConn_SendWithTimeout * add unit function 1.TestConn_Send 2.TestConn_SendRecv 3.TestConn_SendRecvWithTimeout * modify * modify * add example function 1.TestConn_SetReceiveBufferWait 2.TestNewNetConnKeyCrt 3.TestSend * add example function 1.TestSendRecv 2.TestSendWithTimeout * add unit function 1.TestMustGetFreePort 2.TestSendRecvWithTimeout 3.TestSendPkg * add client recevied server's response content assert * modify * modify * add example function 1.TestSendRecvPkg 2.TestSendPkgWithTimeout 3.TestSendRecvPkgWithTimeout * add GetAddress() function add unit funciton 1.TestNewServer 2.TestGetServer 3.TestServer_SetAddress 4.TestServer_SetHandler 5.TestServer_Run * modify * modify * add unit funciton 1.TestLoadKeyCrt * modify * delete function fromHex * add gclient dump unit test * add example function 1.ExampleClient_Put 2.ExampleClient_Delete 3.ExampleClient_Head 4.ExampleClient_Patch 5.ExampleClient_Connect 6.ExampleClient_Options 7.ExampleClient_Trace * add example function 1.TestClient_DoRequest * add example function 1.ExampleClient_PutVar 2.ExampleClient_DeleteVar 3.ExampleClient_HeadVar 4.ExampleClient_PatchVar 5.ExampleClient_ConnectVar 6.ExampleClient_OptionsVar 7.ExampleClient_TraceVar * modify * modify * add CustomProvider function * modify * add unit funciton 1.Test_NewConn 2.Test_GetFreePorts * add unit funciton 1.Test_Server * garray_normal_any code converage * garray_normal_int code converage * garray_normal_str code converage * garray_sorted_any code converage * garray_sorted_int code converage * garray_sorted_str code converage * glist code converage * gmap, gmap_hash_any_any_map code converage * gmap_hash_int_any_map code converage * gmap_hash_int_any_map code converage * gmap_hash_int_int_map code converage * gmap_hash_int_str_map code converage * gmap_hash_str_any_map code converage * gmap_hash_str_int_map code converage * gmap_hash_str_str_map code converage * gmap_list_map code converage * gmap_list_map code converage * revert gf.yml * add gtest unit test function * add ut cases for package gcache * add ut cases for package gcache * add ut cases for package gcache * add ut cases for package gcache * add ut cases for package gcache * modify Co-authored-by: John Guo <john@johng.cn> * improve ut case for package internal/rwmutex (#2364) * fix issue when only one file was uploaded in batch receiver attribute (#2365) * fix fixed An error occurred when only one file was uploaded in batches and add unit testing(#2092) * fix issue uploading files for ghttp.Server Co-authored-by: yxh <yxh1103@qq.com> * fix issue #2334 when accessing static files with cache time (#2366) * Solve the problem of error when accessing static files with cache time. Error message: 2022-11-29 19:40:11.090 [ERRO] http: superfluous response.WriteHeader call from github.com/gogf/gf/v2/net/ghttp.(*ResponseWriter).Flush (ghttp_response_writer.go:58) Stack: Verification method: curl 'http://127.0.0.1:8000/' -H 'If-Modified-Since: Thu, 08 Dec 2022 03:13:55 GMT' --compressed * Solve the problem of error when accessing static files with cache time. Error message: 2022-11-29 19:40:11.090 [ERRO] http: superfluous response.WriteHeader call from github.com/gogf/gf/v2/net/ghttp.(*ResponseWriter).Flush (ghttp_response_writer.go:58) Stack: Verification method: curl 'http://127.0.0.1:8000/' -H 'If-Modified-Since: Thu, 08 Dec 2022 03:13:55 GMT' --compressed * Solve the problem of error when accessing static files with cache time. Error message: 2022-11-29 19:40:11.090 [ERRO] http: superfluous response.WriteHeader call from github.com/gogf/gf/v2/net/ghttp.(*ResponseWriter).Flush (ghttp_response_writer.go:58) Stack: Verification method: curl 'http://127.0.0.1:8000/' -H 'If-Modified-Since: Thu, 08 Dec 2022 03:13:55 GMT' --compressed * fix issue #2334 when accessing static files with cache time * up Co-authored-by: 曾洪亮 <hongliang.zeng@i-soft.com.cn> Co-authored-by: houseme <housemecn@gmail.com> * fix issue in cycle dumping for g.Dump (#2367) * fix issue in cycle dumping for g.Dump * up * up * up Co-authored-by: houseme <housemecn@gmail.com> * 由于 clickhouse 的 position的初始值为 1,导致gdb_core_utility.HasField 中对 fieldsArray 初始化出错 (#2346) * 由于 clickhouse 的 position的初始值为 1,导致gdb_core_utility.HasField 中对 fieldsArray 初始化出错 * 修复单元测试 * 修复单元测试 * 补充单元测试 * 增加CK防御性代码 Co-authored-by: longl <longlei@dealmap.cloud> Co-authored-by: houseme <housemecn@gmail.com> * fix: ghttp server static path config (#2335) Co-authored-by: daguang <daguang830@gmail.com> Co-authored-by: houseme <housemecn@gmail.com> Co-authored-by: ftl <1139556759@qq.com> Co-authored-by: HaiLaz <739476267@qq.com> Co-authored-by: zhonghuaxunGM <50815786+zhonghuaxunGM@users.noreply.github.com> Co-authored-by: huangqian <huangqian1985@qq.com> Co-authored-by: junler <827640651@qq.com> Co-authored-by: junler <sunjun@bookan.com> Co-authored-by: Starccck <28645972+starccck@users.noreply.github.com> Co-authored-by: Jinhongyu <30454170+cnjinhy@users.noreply.github.com> Co-authored-by: YuanXin Hu <huyuanxin1999@outlook.com> Co-authored-by: yxh <yxh1103@qq.com> Co-authored-by: 曾洪亮 <hongliang.zeng@i-soft.com.cn> Co-authored-by: long <48313408+qq375251855@users.noreply.github.com> Co-authored-by: longl <longlei@dealmap.cloud> Co-authored-by: houseme <housemecn@gmail.com> Co-authored-by: daguang <daguang830@gmail.com> Co-authored-by: ftl <1139556759@qq.com> Co-authored-by: HaiLaz <739476267@qq.com> Co-authored-by: zhonghuaxunGM <50815786+zhonghuaxunGM@users.noreply.github.com> Co-authored-by: huangqian <huangqian1985@qq.com> Co-authored-by: junler <827640651@qq.com> Co-authored-by: junler <sunjun@bookan.com> Co-authored-by: Starccck <28645972+starccck@users.noreply.github.com> Co-authored-by: Jinhongyu <30454170+cnjinhy@users.noreply.github.com> Co-authored-by: YuanXin Hu <huyuanxin1999@outlook.com> Co-authored-by: yxh <yxh1103@qq.com> Co-authored-by: 曾洪亮 <hongliang.zeng@i-soft.com.cn> Co-authored-by: long <48313408+qq375251855@users.noreply.github.com> Co-authored-by: longl <longlei@dealmap.cloud>
742 lines
17 KiB
Go
742 lines
17 KiB
Go
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
|
//
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
// If a copy of the MIT was not distributed with this file,
|
|
// You can obtain one at https://github.com/gogf/gf.
|
|
|
|
package gcache_test
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/gogf/gf/v2/database/gredis"
|
|
"github.com/gogf/gf/v2/frame/g"
|
|
"github.com/gogf/gf/v2/os/gcache"
|
|
"github.com/gogf/gf/v2/os/gctx"
|
|
)
|
|
|
|
func ExampleNew() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly.
|
|
c := gcache.New()
|
|
|
|
// Set cache without expiration
|
|
c.Set(ctx, "k1", "v1", 0)
|
|
|
|
// Get cache
|
|
v, _ := c.Get(ctx, "k1")
|
|
fmt.Println(v)
|
|
|
|
// Get cache size
|
|
n, _ := c.Size(ctx)
|
|
fmt.Println(n)
|
|
|
|
// Does the specified key name exist in the cache
|
|
b, _ := c.Contains(ctx, "k1")
|
|
fmt.Println(b)
|
|
|
|
// Delete and return the deleted key value
|
|
fmt.Println(c.Remove(ctx, "k1"))
|
|
|
|
// Close the cache object and let the GC reclaim resources
|
|
|
|
c.Close(ctx)
|
|
|
|
// Output:
|
|
// v1
|
|
// 1
|
|
// true
|
|
// v1 <nil>
|
|
}
|
|
|
|
func ExampleCache_Set() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set cache without expiration
|
|
c.Set(ctx, "k1", g.Slice{1, 2, 3, 4, 5, 6, 7, 8, 9}, 0)
|
|
|
|
// Get cache
|
|
fmt.Println(c.Get(ctx, "k1"))
|
|
|
|
// Output:
|
|
// [1,2,3,4,5,6,7,8,9] <nil>
|
|
}
|
|
|
|
func ExampleCache_SetIfNotExist() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Write when the key name does not exist, and set the expiration time to 1000 milliseconds
|
|
k1, err := c.SetIfNotExist(ctx, "k1", "v1", 1000*time.Millisecond)
|
|
fmt.Println(k1, err)
|
|
|
|
// Returns false when the key name already exists
|
|
k2, err := c.SetIfNotExist(ctx, "k1", "v2", 1000*time.Millisecond)
|
|
fmt.Println(k2, err)
|
|
|
|
// Print the current list of key values
|
|
keys1, _ := c.Keys(ctx)
|
|
fmt.Println(keys1)
|
|
|
|
// It does not expire if `duration` == 0. It deletes the `key` if `duration` < 0 or given `value` is nil.
|
|
c.SetIfNotExist(ctx, "k1", 0, -10000)
|
|
|
|
// Wait 1 second for K1: V1 to expire automatically
|
|
time.Sleep(1200 * time.Millisecond)
|
|
|
|
// Print the current key value pair again and find that K1: V1 has expired
|
|
keys2, _ := c.Keys(ctx)
|
|
fmt.Println(keys2)
|
|
|
|
// Output:
|
|
// true <nil>
|
|
// false <nil>
|
|
// [k1]
|
|
// [<nil>]
|
|
}
|
|
|
|
func ExampleCache_SetMap() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// map[interface{}]interface{}
|
|
data := g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
}
|
|
|
|
// Sets batch sets cache with key-value pairs by `data`, which is expired after `duration`.
|
|
// It does not expire if `duration` == 0. It deletes the keys of `data` if `duration` < 0 or given `value` is nil.
|
|
c.SetMap(ctx, data, 1000*time.Millisecond)
|
|
|
|
// Gets the specified key value
|
|
v1, _ := c.Get(ctx, "k1")
|
|
v2, _ := c.Get(ctx, "k2")
|
|
v3, _ := c.Get(ctx, "k3")
|
|
|
|
fmt.Println(v1, v2, v3)
|
|
|
|
// Output:
|
|
// v1 v2 v3
|
|
}
|
|
|
|
func ExampleCache_Size() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Add 10 elements without expiration
|
|
for i := 0; i < 10; i++ {
|
|
c.Set(ctx, i, i, 0)
|
|
}
|
|
|
|
// Size returns the number of items in the cache.
|
|
n, _ := c.Size(ctx)
|
|
fmt.Println(n)
|
|
|
|
// Output:
|
|
// 10
|
|
}
|
|
|
|
func ExampleCache_Update() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Sets batch sets cache with key-value pairs by `data`, which is expired after `duration`.
|
|
// It does not expire if `duration` == 0. It deletes the keys of `data` if `duration` < 0 or given `value` is nil.
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1", "k2": "v2", "k3": "v3"}, 0)
|
|
|
|
// Print the current key value pair
|
|
k1, _ := c.Get(ctx, "k1")
|
|
fmt.Println(k1)
|
|
k2, _ := c.Get(ctx, "k2")
|
|
fmt.Println(k2)
|
|
k3, _ := c.Get(ctx, "k3")
|
|
fmt.Println(k3)
|
|
|
|
// Update updates the value of `key` without changing its expiration and returns the old value.
|
|
re, exist, _ := c.Update(ctx, "k1", "v11")
|
|
fmt.Println(re, exist)
|
|
|
|
// The returned value `exist` is false if the `key` does not exist in the cache.
|
|
// It does nothing if `key` does not exist in the cache.
|
|
re1, exist1, _ := c.Update(ctx, "k4", "v44")
|
|
fmt.Println(re1, exist1)
|
|
|
|
kup1, _ := c.Get(ctx, "k1")
|
|
fmt.Println(kup1)
|
|
kup2, _ := c.Get(ctx, "k2")
|
|
fmt.Println(kup2)
|
|
kup3, _ := c.Get(ctx, "k3")
|
|
fmt.Println(kup3)
|
|
|
|
// Output:
|
|
// v1
|
|
// v2
|
|
// v3
|
|
// v1 true
|
|
// false
|
|
// v11
|
|
// v2
|
|
// v3
|
|
}
|
|
|
|
func ExampleCache_UpdateExpire() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
c.Set(ctx, "k1", "v1", 1000*time.Millisecond)
|
|
expire, _ := c.GetExpire(ctx, "k1")
|
|
fmt.Println(expire)
|
|
|
|
// UpdateExpire updates the expiration of `key` and returns the old expiration duration value.
|
|
// It returns -1 and does nothing if the `key` does not exist in the cache.
|
|
c.UpdateExpire(ctx, "k1", 500*time.Millisecond)
|
|
|
|
expire1, _ := c.GetExpire(ctx, "k1")
|
|
fmt.Println(expire1)
|
|
|
|
// May Output:
|
|
// 1s
|
|
// 500ms
|
|
}
|
|
|
|
func ExampleCache_Values() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Write value
|
|
c.Set(ctx, "k1", g.Map{"k1": "v1", "k2": "v2"}, 0)
|
|
// c.Set(ctx, "k2", "Here is Value2", 0)
|
|
// c.Set(ctx, "k3", 111, 0)
|
|
|
|
// Values returns all values in the cache as slice.
|
|
data, _ := c.Values(ctx)
|
|
fmt.Println(data)
|
|
|
|
// May Output:
|
|
// [map[k1:v1 k2:v2]]
|
|
}
|
|
|
|
func ExampleCache_Close() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set Cache
|
|
c.Set(ctx, "k1", "v", 0)
|
|
data, _ := c.Get(ctx, "k1")
|
|
fmt.Println(data)
|
|
|
|
// Close closes the cache if necessary.
|
|
c.Close(ctx)
|
|
|
|
data1, _ := c.Get(ctx, "k1")
|
|
|
|
fmt.Println(data1)
|
|
|
|
// Output:
|
|
// v
|
|
// v
|
|
}
|
|
|
|
func ExampleCache_Contains() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set Cache
|
|
c.Set(ctx, "k", "v", 0)
|
|
|
|
// Contains returns true if `key` exists in the cache, or else returns false.
|
|
// return true
|
|
data, _ := c.Contains(ctx, "k")
|
|
fmt.Println(data)
|
|
|
|
// return false
|
|
data1, _ := c.Contains(ctx, "k1")
|
|
fmt.Println(data1)
|
|
|
|
// Output:
|
|
// true
|
|
// false
|
|
}
|
|
|
|
func ExampleCache_Data() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1"}, 0)
|
|
|
|
data, _ := c.Data(ctx)
|
|
fmt.Println(data)
|
|
|
|
// Set Cache
|
|
c.Set(ctx, "k5", "v5", 0)
|
|
data1, _ := c.Get(ctx, "k1")
|
|
fmt.Println(data1)
|
|
|
|
// Output:
|
|
// map[k1:v1]
|
|
// v1
|
|
}
|
|
|
|
func ExampleCache_Get() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set Cache Object
|
|
c.Set(ctx, "k1", "v1", 0)
|
|
|
|
// Get retrieves and returns the associated value of given `key`.
|
|
// It returns nil if it does not exist, its value is nil or it's expired.
|
|
data, _ := c.Get(ctx, "k1")
|
|
fmt.Println(data)
|
|
|
|
// Output:
|
|
// v1
|
|
}
|
|
|
|
func ExampleCache_GetExpire() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set cache without expiration
|
|
c.Set(ctx, "k", "v", 10000*time.Millisecond)
|
|
|
|
// GetExpire retrieves and returns the expiration of `key` in the cache.
|
|
// It returns 0 if the `key` does not expire. It returns -1 if the `key` does not exist in the cache.
|
|
expire, _ := c.GetExpire(ctx, "k")
|
|
fmt.Println(expire)
|
|
|
|
// May Output:
|
|
// 10s
|
|
}
|
|
|
|
func ExampleCache_GetOrSet() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// GetOrSet retrieves and returns the value of `key`, or sets `key`-`value` pair and returns `value`
|
|
// if `key` does not exist in the cache.
|
|
data, _ := c.GetOrSet(ctx, "k", "v", 10000*time.Millisecond)
|
|
fmt.Println(data)
|
|
|
|
data1, _ := c.Get(ctx, "k")
|
|
fmt.Println(data1)
|
|
|
|
// Output:
|
|
// v
|
|
// v
|
|
|
|
}
|
|
|
|
func ExampleCache_GetOrSetFunc() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// GetOrSetFunc retrieves and returns the value of `key`, or sets `key` with result of function `f`
|
|
// and returns its result if `key` does not exist in the cache.
|
|
c.GetOrSetFunc(ctx, "k1", func(ctx context.Context) (value interface{}, err error) {
|
|
return "v1", nil
|
|
}, 10000*time.Millisecond)
|
|
v, _ := c.Get(ctx, "k1")
|
|
fmt.Println(v)
|
|
|
|
// If func returns nil, no action is taken
|
|
c.GetOrSetFunc(ctx, "k2", func(ctx context.Context) (value interface{}, err error) {
|
|
return nil, nil
|
|
}, 10000*time.Millisecond)
|
|
v1, _ := c.Get(ctx, "k2")
|
|
fmt.Println(v1)
|
|
|
|
// Output:
|
|
// v1
|
|
}
|
|
|
|
func ExampleCache_GetOrSetFuncLock() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Modify locking Note that the function `f` should be executed within writing mutex lock for concurrent safety purpose.
|
|
c.GetOrSetFuncLock(ctx, "k1", func(ctx context.Context) (value interface{}, err error) {
|
|
return "v1", nil
|
|
}, 0)
|
|
v, _ := c.Get(ctx, "k1")
|
|
fmt.Println(v)
|
|
|
|
// Modification failed
|
|
c.GetOrSetFuncLock(ctx, "k1", func(ctx context.Context) (value interface{}, err error) {
|
|
return "update v1", nil
|
|
}, 0)
|
|
v, _ = c.Get(ctx, "k1")
|
|
fmt.Println(v)
|
|
|
|
c.Remove(ctx, g.Slice{"k1"}...)
|
|
|
|
// Output:
|
|
// v1
|
|
// v1
|
|
}
|
|
|
|
func ExampleCache_Keys() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1"}, 0)
|
|
|
|
// Print the current list of key values
|
|
keys1, _ := c.Keys(ctx)
|
|
fmt.Println(keys1)
|
|
|
|
// Output:
|
|
// [k1]
|
|
}
|
|
|
|
func ExampleCache_KeyStrings() {
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1", "k2": "v2"}, 0)
|
|
|
|
// KeyStrings returns all keys in the cache as string slice.
|
|
keys, _ := c.KeyStrings(ctx)
|
|
fmt.Println(keys)
|
|
|
|
// May Output:
|
|
// [k1 k2]
|
|
}
|
|
|
|
func ExampleCache_Remove() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1", "k2": "v2"}, 0)
|
|
|
|
// Remove deletes one or more keys from cache, and returns its value.
|
|
// If multiple keys are given, it returns the value of the last deleted item.
|
|
remove, _ := c.Remove(ctx, "k1")
|
|
fmt.Println(remove)
|
|
|
|
data, _ := c.Data(ctx)
|
|
fmt.Println(data)
|
|
|
|
// Output:
|
|
// v1
|
|
// map[k2:v2]
|
|
}
|
|
|
|
func ExampleCache_Removes() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1", "k2": "v2", "k3": "v3", "k4": "v4"}, 0)
|
|
|
|
// Remove deletes one or more keys from cache, and returns its value.
|
|
// If multiple keys are given, it returns the value of the last deleted item.
|
|
c.Removes(ctx, g.Slice{"k1", "k2", "k3"})
|
|
|
|
data, _ := c.Data(ctx)
|
|
fmt.Println(data)
|
|
|
|
// Output:
|
|
// map[k4:v4]
|
|
}
|
|
|
|
func ExampleCache_MustGet() {
|
|
// Intercepting panic exception information
|
|
// err is empty, so panic is not performed
|
|
defer func() {
|
|
if r := recover(); r != nil {
|
|
fmt.Println("recover...:", r)
|
|
}
|
|
}()
|
|
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set Cache Object
|
|
c.Set(ctx, "k1", "v1", 0)
|
|
|
|
// MustGet acts like Get, but it panics if any error occurs.
|
|
k2 := c.MustGet(ctx, "k2")
|
|
fmt.Println(k2)
|
|
|
|
k1 := c.MustGet(ctx, "k1")
|
|
fmt.Println(k1)
|
|
|
|
// Output:
|
|
// v1
|
|
}
|
|
|
|
func ExampleCache_MustGetOrSet() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// MustGetOrSet acts like GetOrSet, but it panics if any error occurs.
|
|
k1 := c.MustGetOrSet(ctx, "k1", "v1", 0)
|
|
fmt.Println(k1)
|
|
|
|
k2 := c.MustGetOrSet(ctx, "k1", "v2", 0)
|
|
fmt.Println(k2)
|
|
|
|
// Output:
|
|
// v1
|
|
// v1
|
|
}
|
|
|
|
func ExampleCache_MustGetOrSetFunc() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// MustGetOrSetFunc acts like GetOrSetFunc, but it panics if any error occurs.
|
|
c.MustGetOrSetFunc(ctx, "k1", func(ctx context.Context) (value interface{}, err error) {
|
|
return "v1", nil
|
|
}, 10000*time.Millisecond)
|
|
v := c.MustGet(ctx, "k1")
|
|
fmt.Println(v)
|
|
|
|
c.MustGetOrSetFunc(ctx, "k2", func(ctx context.Context) (value interface{}, err error) {
|
|
return nil, nil
|
|
}, 10000*time.Millisecond)
|
|
v1 := c.MustGet(ctx, "k2")
|
|
fmt.Println(v1)
|
|
|
|
// Output:
|
|
// v1
|
|
//
|
|
}
|
|
|
|
func ExampleCache_MustGetOrSetFuncLock() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// MustGetOrSetFuncLock acts like GetOrSetFuncLock, but it panics if any error occurs.
|
|
c.MustGetOrSetFuncLock(ctx, "k1", func(ctx context.Context) (value interface{}, err error) {
|
|
return "v1", nil
|
|
}, 0)
|
|
v := c.MustGet(ctx, "k1")
|
|
fmt.Println(v)
|
|
|
|
// Modification failed
|
|
c.MustGetOrSetFuncLock(ctx, "k1", func(ctx context.Context) (value interface{}, err error) {
|
|
return "update v1", nil
|
|
}, 0)
|
|
v = c.MustGet(ctx, "k1")
|
|
fmt.Println(v)
|
|
|
|
// Output:
|
|
// v1
|
|
// v1
|
|
}
|
|
|
|
func ExampleCache_MustContains() {
|
|
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set Cache
|
|
c.Set(ctx, "k", "v", 0)
|
|
|
|
// MustContains returns true if `key` exists in the cache, or else returns false.
|
|
// return true
|
|
data := c.MustContains(ctx, "k")
|
|
fmt.Println(data)
|
|
|
|
// return false
|
|
data1 := c.MustContains(ctx, "k1")
|
|
fmt.Println(data1)
|
|
|
|
// Output:
|
|
// true
|
|
// false
|
|
}
|
|
|
|
func ExampleCache_MustGetExpire() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Set cache without expiration
|
|
c.Set(ctx, "k", "v", 10000*time.Millisecond)
|
|
|
|
// MustGetExpire acts like GetExpire, but it panics if any error occurs.
|
|
expire := c.MustGetExpire(ctx, "k")
|
|
fmt.Println(expire)
|
|
|
|
// May Output:
|
|
// 10s
|
|
}
|
|
|
|
func ExampleCache_MustSize() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Add 10 elements without expiration
|
|
for i := 0; i < 10; i++ {
|
|
c.Set(ctx, i, i, 0)
|
|
}
|
|
|
|
// Size returns the number of items in the cache.
|
|
n := c.MustSize(ctx)
|
|
fmt.Println(n)
|
|
|
|
// Output:
|
|
// 10
|
|
}
|
|
|
|
func ExampleCache_MustData() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1", "k2": "v2"}, 0)
|
|
|
|
data := c.MustData(ctx)
|
|
fmt.Println(data)
|
|
|
|
// May Output:
|
|
// map[k1:v1 k2:v2]
|
|
}
|
|
|
|
func ExampleCache_MustKeys() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1", "k2": "v2"}, 0)
|
|
|
|
// MustKeys acts like Keys, but it panics if any error occurs.
|
|
keys1 := c.MustKeys(ctx)
|
|
fmt.Println(keys1)
|
|
|
|
// May Output:
|
|
// [k1 k2]
|
|
|
|
}
|
|
|
|
func ExampleCache_MustKeyStrings() {
|
|
c := gcache.New()
|
|
|
|
c.SetMap(ctx, g.MapAnyAny{"k1": "v1", "k2": "v2"}, 0)
|
|
|
|
// MustKeyStrings returns all keys in the cache as string slice.
|
|
// MustKeyStrings acts like KeyStrings, but it panics if any error occurs.
|
|
keys := c.MustKeyStrings(ctx)
|
|
fmt.Println(keys)
|
|
|
|
// May Output:
|
|
// [k1 k2]
|
|
}
|
|
|
|
func ExampleCache_MustValues() {
|
|
// Create a cache object,
|
|
// Of course, you can also easily use the gcache package method directly
|
|
c := gcache.New()
|
|
|
|
// Write value
|
|
c.Set(ctx, "k1", "v1", 0)
|
|
|
|
// MustValues returns all values in the cache as slice.
|
|
data := c.MustValues(ctx)
|
|
fmt.Println(data)
|
|
|
|
// Output:
|
|
// [v1]
|
|
}
|
|
|
|
func ExampleCache_SetAdapter() {
|
|
var (
|
|
err error
|
|
ctx = gctx.New()
|
|
cache = gcache.New()
|
|
redisConfig = &gredis.Config{
|
|
Address: "127.0.0.1:6379",
|
|
Db: 9,
|
|
}
|
|
cacheKey = `key`
|
|
cacheValue = `value`
|
|
)
|
|
// Create redis client object.
|
|
redis, err := gredis.New(redisConfig)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
// Create redis cache adapter and set it to cache object.
|
|
cache.SetAdapter(gcache.NewAdapterRedis(redis))
|
|
|
|
// Set and Get using cache object.
|
|
err = cache.Set(ctx, cacheKey, cacheValue, time.Second)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
fmt.Println(cache.MustGet(ctx, cacheKey).String())
|
|
|
|
// Get using redis client.
|
|
fmt.Println(redis.MustDo(ctx, "GET", cacheKey).String())
|
|
|
|
// May Output:
|
|
// value
|
|
// value
|
|
}
|
|
|
|
func ExampleCache_GetAdapter() {
|
|
var (
|
|
err error
|
|
ctx = gctx.New()
|
|
cache = gcache.New()
|
|
redisConfig = &gredis.Config{
|
|
Address: "127.0.0.1:6379",
|
|
Db: 10,
|
|
}
|
|
cacheKey = `key`
|
|
cacheValue = `value`
|
|
)
|
|
redis, err := gredis.New(redisConfig)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
cache.SetAdapter(gcache.NewAdapterRedis(redis))
|
|
|
|
// Set and Get using cache object.
|
|
err = cache.Set(ctx, cacheKey, cacheValue, time.Second)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
fmt.Println(cache.MustGet(ctx, cacheKey).String())
|
|
|
|
// Get using redis client.
|
|
v, err := cache.GetAdapter().(*gcache.AdapterRedis).Get(ctx, cacheKey)
|
|
fmt.Println(err)
|
|
fmt.Println(v.String())
|
|
|
|
// May Output:
|
|
// value
|
|
// <nil>
|
|
// value
|
|
}
|