使用golang的http模块构建redis读写查api

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介:

前沿:

        这两天试着用golang做一些高性能的api,不想把压力到聚合在平台的接口上。平台因为要做很多耗时间的操作,uwsgi下会出现少许错误,找了一圈不知道如何解决该问题。 暂时先绕道而行,先拿简单的接口来做测试,慢慢的把复杂的操作也迁移到golang上。

          话说以前高性能的接口,我用的最多的方案还是nginx lua的组合,超强,大家可以看看我以前写的nginx lua的文章,各方面没得说。只是这段时间正在看golang 的,就试着用golang实现redis的api,先来个简单的试试手。


里面引用的是golang自带的http模块,redis是自己down的。

golang redis的配置方法:

1
2
3
4
cd $GOPATH/src
git clone git: //github.com/alphazero/Go-Redis.git redis
cd redis
go install


先简单说下,golang对于redis的操作方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
//xiaorui.cc
package main
import  (
     "os" ;
     "bufio" ;
     "log" ;
     "fmt" ;
     "redis" ;
)
/*
     hello world, redis style.
*/
func main () {
     // create the client.   Here  we are using a synchronous client.
     //  Using  the default  ConnectionSpec , we are specifying the client to connect
     // to db 13 (e.g.  SELECT  13),  and  a password  of  go-redis (e.g.  AUTH  go-redis)
     spec := redis. DefaultSpec (). Db (13). Password ( "go-redis" );
     client, e := redis. NewSynchClientWithSpec  (spec);
     if  e != nil { log. Println  ( "failed to create the client" , e); return }
     key :=  "examples/hello/user.name" ;
     value, e := client. Get (key);
     if  e!= nil { log. Println  ( "error on Get" , e); return }
     if  value == nil {
         fmt. Printf ( "\nHello, don't believe we've met before!\nYour name? " );
         reader:= bufio. NewReader (os. Stdin );
         user, _ := reader. ReadString (byte( '\n' ));
         if  len(user) > 1 {
             user = user[ 0:len (user)-1];
             value = []byte(user);
             client. Set (key, value);
         } else {
             fmt. Printf  ( "vafanculo!\n" );
             return;
         }
     }
     fmt. Printf  ( "Hey, ciao %s!\n" , fmt. Sprintf ( "%s" , value));
}


我写的实例,大家看懂了后,完全可以做更多的扩展。


其实golang自带的http很有mvc的感觉,三者做了一些分离,很像python里面的web.py tornado。。。


测试结果:

服务端的启动

wKioL1Mrmi3Qj3nVAAHGNMEWAPA108.jpg

客户端的测试

wKiom1MrmkSg8_TGAATqDvHKzoA311.jpg


原文:http://rfyiamcool.blog.51cto.com/1030776/1380754


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
//xiaorui.cc
package  main
import (
     "fmt"
     "net/http"
     "io/ioutil"
     "log"
     "time"
     "redis"
)
//xiaorui.cc
const  AddForm = `
<html><body>
<form method= "POST"  action= "/add" >
Name: <input type= "text"  name= "name" >
Age: <input type= "text"  name= "age" >
<input type= "submit"  value= "Add" >
</form>
</body></html>
`
const  setform = `
<html><body>
<form method= "POST"  action= "/set" >
key: <input type= "text"  name= "key" >
value: <input type= "text"  name= "value" >
<input type= "submit"  value= "set" >
</form>
</body></html>
`
func Handler( w http.ResponseWriter,r *http.Request ){
     path := r.URL.Path[ 1 :]
     if  path ==  "favicon.ico"   {
         http.NotFound(w, r)
         return
     }
     if  path ==  "" {
         path =  "index.html"
     }
     contents,err:= ioutil.ReadFile( path )
     if  err !=nil{
         fmt.Fprintf( w, "404"  )
         return
     }
     fmt.Fprintf( w, "%s\n" ,contents )
}
                                                                                                                                                                                                                                                                                                                                                               
func Add( w http.ResponseWriter,r *http.Request ){
     name := r.FormValue( "name" )
     age := r.FormValue( "age" )
     if  name ==  ""  || age ==  ""  {
         fmt.Fprint(w, AddForm)
         return
     }
     fmt.Fprintf(w,  "Save : Your name is  %s , You age is %s" ,name,age)
}
func redisset( w http.ResponseWriter,r *http.Request ){
     key := r.FormValue( "key" )
     value := r.FormValue( "value" )
     if  key ==  ""  || value ==  ""  {
         fmt.Fprint(w, setform)
         return
     }
     spec := redis.DefaultSpec().Db( 0 ).Password( "" );
     client, e := redis.NewSynchClientWithSpec (spec);
     if  e != nil { log.Println ( "服务器连接有异常" , e);  return  }
     inva := []byte(value)
     client.Set(key, inva);
     fmt.Fprintf(w,  "哥们,你输入的key  %s 和value  %s 已经插入到redis里面了" ,key,key)
}
func redisget( w http.ResponseWriter,r *http.Request ){
     key := r.FormValue( "key" )
     if  key ==  ""  {
         fmt.Fprint(w, setform)
         return
     }
     spec := redis.DefaultSpec().Db( 0 ).Password( "" );
     client, e := redis.NewSynchClientWithSpec (spec);
     if  e != nil { log.Println ( "服务器连接有异常" , e);  return  }
                                                                                                                                                                                                                                                                                                                                                                  
     value, e := client.Get(key);
     fmt.Fprintf(w,  "哥们,你要查询的key  %s 和value  %s " ,key,value)
}
func valueget(w http.ResponseWriter, r *http.Request) {
     params := r.URL.Query()
     user := params.Get( "user" )
     fmt.Fprintf(w,  "you are get user %s" , user)
}
                                                                                                                                                                                                                                                                                                                                                               
func main(){
     http.HandleFunc(  "/" ,Handler)
     http.HandleFunc(  "/add" ,Add)
     http.HandleFunc(  "/redisset" ,redisset)
     http.HandleFunc(  "/redisget" ,redisget)
     http.HandleFunc(  "/valueget" ,valueget)
     s := &http.Server{
         Addr:            ":80" ,
         ReadTimeout:     30  * time.Second,
         WriteTimeout:    30  * time.Second,
         MaxHeaderBytes:  1  <<  20 ,
     }
     log.Fatal(s.ListenAndServe())
}


对于go的基础教程,我也写过其他的文章,大家可以参考下。


关于Golang语言的web编程的实例及常见问题

http://rfyiamcool.blog.51cto.com/1030776/1285325


关于Go语言在服务端做Restful接口和socket通信

http://rfyiamcool.blog.51cto.com/1030776/1286372




 本文转自 rfyiamcool 51CTO博客,原文链接:http://blog.51cto.com/rfyiamcool/1380754,如需转载请自行联系原作者


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
5月前
|
JavaScript 前端开发 Serverless
在阿里云函数计算FC部署好HTTP API后
在阿里云函数计算FC部署好HTTP API后
121 5
|
2月前
|
XML 自然语言处理 前端开发
NLP自学习平台提供了API接口调用服务,这些接口可以通过HTTP GET请求进行调用
【2月更文挑战第7天】NLP自学习平台提供了API接口调用服务,这些接口可以通过HTTP GET请求进行调用
17 2
|
2月前
|
Shell API
srs的http api鉴权
srs的http api鉴权
37 0
|
3月前
|
JSON Java API
Java 编程问题:十三、HTTP 客户端和 WebSocket API
Java 编程问题:十三、HTTP 客户端和 WebSocket API
|
4月前
|
分布式计算 Hadoop Java
[hadoop3.x系列]HDFS REST HTTP API的使用(二)HttpFS
[hadoop3.x系列]HDFS REST HTTP API的使用(二)HttpFS
53 1
|
4月前
|
分布式计算 Hadoop API
✨[hadoop3.x系列]HDFS REST HTTP API的使用(一)WebHDFS
✨[hadoop3.x系列]HDFS REST HTTP API的使用(一)WebHDFS
60 1
|
4月前
|
设计模式 JSON 缓存
[Web 基础] HTTP API 设计指南
[Web 基础] HTTP API 设计指南
|
4月前
|
Shell API
srs的http api鉴权
srs的http api鉴权
39 0
|
5月前
|
Java API
Java 11中引入的HTTP客户端API是什么?如何使用它进行HTTP请求?
Java 11中引入的HTTP客户端API是什么?如何使用它进行HTTP请求?
|
6月前
|
XML Java API
该丢弃 HttpClient 了,这款轻量级 HTTP 客户端 API 框架很强
一般情况下是后端提供接口,前端调用,解决需求,但是有的时候为了方便,复用别人的接口(网上的,公共的第三方接口(短信、天气等)),就出现了后端调用后端接口的情况。 此外,因为业务关系,要和许多不同第三方公司进行对接。这些服务商都提供基于http的api,但是每家公司提供api具体细节差别很大。

热门文章

最新文章