You are viewing an old version of this page. View the current version.
Compare with Current View Page History
« Previous Version 5 Next »
guid提供了更简便更高性能的唯一数生成功能。
guid
guid模块的设计目的在于提供一种使用更简便、性能更高效且能满足绝大多数业务场景的唯一数生成。guid的设计比较简单,详情可参考实现源码。
使用方式:
import "github.com/gogf/gf/v2/util/guid"
接口文档:
https://pkg.go.dev/github.com/gogf/gf/v2/util/guid
guid通过S方法生成32字节的唯一数,该方法定义如下:
S
32
func S(data ...[]byte) string
通过不带任何参数的方式使用,该方法生成的唯一数将会有以下方式构成:
MAC(7) + PID(4) + TimestampNano(12) + Sequence(3) + RandomString(6)
其中:
MAC
7
PID
4
TimestampNano
12
Sequence
3
RandomString
6
通过自定义任何参数的方式使用,该方法生成的唯一数将会有以下方式构成:
Data(7/14) + TimestampNano(12) + Sequence(3) + RandomString(3/10)
主要说明:
Data
[]byte
2
14
10
1
goos: linux goarch: amd64 pkg: github.com/gogf/gf/v2/util/guid cpu: Intel(R) Core(TM) i7-9750H CPU @ 2.60GHz Benchmark_S Benchmark_S-12 2407318 449.5 ns/op Benchmark_S_Data_1 Benchmark_S_Data_1-12 2075854 681.7 ns/op Benchmark_S_Data_2 Benchmark_S_Data_2-12 3676795 299.7 ns/op PASS
package main import ( "fmt" "github.com/gogf/gf/v2/util/guid" ) func main() { fmt.Printf("TraceId: %s", guid.S()) }
执行后,输出结果为:
TraceId: oa9sdw03dk0c35q9bdwcnz42p00trwfr
我们的SessionId生成需要具有比较好的唯一性,且需要防止轻易的碰撞,因此可以使用以下方式:
SessionId
func CreateSessionId(r *ghttp.Request) string { var ( address = request.RemoteAddr header = fmt.Sprintf("%v", request.Header) ) return guid.S([]byte(address), []byte(header)) }
可以看到,SessionId需要依靠自定义的两个输入参数RemoteAddr, Header来生成,这两个参数在业务上具有一定的唯一识别性,且通过guid.S方法的设计构成,生成的唯一数将会非常随机且唯一,既满足了业务需要也保证了安全。
RemoteAddr
Header
guid.S