获取Golang的redis第三方api
git clone https://github.com/garyburd/redigo.git
package main
import (
"fmt"
"github.com/garyburd/redigo/redis" // 引入redis包
)
func main() {
// 通过go向redis写入数据和读取数据
// 1.连接到redis
conn, err := redis.Dial("tcp", "127.0.0.1:6379")
if err != nil {
fmt.Println("redis connect failed. err = ", err)
return
}
defer conn.Close() //关闭连接
// 2.通过go向redis写入数据
_, err = conn.Do("Set", "name", "tomjerry")
if err != nil {
fmt.Println("Set err = ", err)
return
}
// 3.从redis中读取数据
// 由于返回的r是一个interface{},故要转成字符串
r, err := redis.String(conn.Do("Get", "name"))
if err != nil {
fmt.Println("Get err = ", err)
return
}
fmt.Println("操作ok. name =", r) // 操作ok. name = tomjerry
}
package main
import (
"fmt"
"github.com/garyburd/redigo/redis" // 引入redis包
)
func main() {
// 通过go向redis写入数据和读取数据
// 1.连接到redis
conn, err := redis.Dial("tcp", "127.0.0.1:6379")
if err != nil {
fmt.Println("redis connect failed. err = ", err)
return
}
defer conn.Close() //关闭连接
// 2.通过go向redis写入数据
_, err = conn.Do("HMSet", "user01", "name", "jack", "age", 20)
if err != nil {
fmt.Println("HMSet err = ", err)
return
}
// 3.从redis中读取数据
// 由于返回的r是一个多类型的变量,故需要用redis.Strings()
r, err := redis.Strings(conn.Do("HMGet", "user01", "name", "age"))
if err != nil {
fmt.Println("HMGet err = ", err)
return
}
// 遍历结果
for i, v := range r {
fmt.Printf("r[%d]=%v\n", i, v)
}
/*
r[0]=jack
r[1]=20
*/
}
_, err = conn.Do("MSet", "name01", "RSQ", "name02", "Tom")
if err != nil {
fmt.Println("HMSet err = ", err)
return
}
// 设置超时时间
_, err = conn.Do("expire", "name01", 10)
if err != nil {
fmt.Println("Set Expire err = ", err)
return
}
// 1.通过go向redis写入数据
_, err = conn.Do("Lpush", "herolist", "no1:宋江", 30, "no2:吴淞", 40)
if err != nil {
fmt.Println("Lpush err = ", err)
return
}
// 2.从redis中读取数据
r, err = redis.String(conn.Do("rpop", "herolist"))
if err != nil {
fmt.Println("rpop err = ", err)
return
}
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
// 定义一个全局的pool
var pool *redis.Pool
// 创建连接池
func init() {
pool = &redis.Pool{
MaxIdle: 8, // 表示最大空闲连接数
MaxActive: 0, // 表示和数据库的最大连接数,0表示没有限制
IdleTimeout: 100, // 最大空闲时间
Dial: func() (redis.Conn, error) { // 初始化连接的代码,连接哪个ip的redis
return redis.Dial("tcp", "localhost:6379")
},
}
}
func main() {
conn := pool.Get() // 从连接池中取出一个连接
defer conn.Close() // 关闭连接池,一旦关闭连接池,就不能从连接池再取出连接
_, err := conn.Do("set", "car", "BBB")
if err != nil {
fmt.Println("conn.Do err=", err)
return
}
r, err := redis.String(conn.Do("Get", "car"))
if err != nil {
fmt.Println("read Data err=", err)
return
}
fmt.Println("r=", r)
// 如果要从pool池中取出连接,一定要保证连接池是没有关闭的
}
要求:
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
type Monster struct {
Name string
Age int
Skill string
}
func Process(name string, age int, skill string) {
// 1.连接redis
conn, err := redis.Dial("tcp", "127.0.0.1:6379")
if err != nil {
fmt.Println("conn err = ", err)
return
}
defer conn.Close()
// 2.往redis数据库写入数据
_, err = conn.Do("HMset", "monster", "name", name, "age", age, "skill", skill)
if err != nil {
fmt.Println("write data err = ", err)
return
}
// 3.从redis中读取数据
r, err := redis.Strings(conn.Do("HMget", "monster", "name", "age", "skill"))
if err != nil {
fmt.Println("read data err = ", err)
return
}
for i, v := range r {
fmt.Printf("r[%d]=%v\n", i, v)
}
}
func main() {
// 定义结构体实例
var monster Monster
fmt.Println("请输入monster的Name:")
fmt.Scanln(&monster.Name)
fmt.Println("请输入monster的Age:")
fmt.Scanln(&monster.Age)
fmt.Println("请输入monster的Skill:")
fmt.Scanln(&monster.Skill)
Process(monster.Name, monster.Age, monster.Skill)
}
要求: