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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
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的基础教程,我也写过其他的文章,大家可以参考下。










本文转自 ponpon_ 51CTO博客,原文链接:http://blog.51cto.com/liuxp0827/1387369,如需转载请自行联系原作者
相关实践学习
基于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
目录
相关文章
|
3月前
|
存储 缓存 NoSQL
大数据-38 Redis 高并发下的分布式缓存 Redis简介 缓存场景 读写模式 旁路模式 穿透模式 缓存模式 基本概念等
大数据-38 Redis 高并发下的分布式缓存 Redis简介 缓存场景 读写模式 旁路模式 穿透模式 缓存模式 基本概念等
79 4
|
4月前
|
Prometheus Cloud Native Go
Golang语言之Prometheus的日志模块使用案例
这篇文章是关于如何在Golang语言项目中使用Prometheus的日志模块的案例,包括源代码编写、编译和测试步骤。
83 3
Golang语言之Prometheus的日志模块使用案例
|
4月前
|
数据采集 存储 JSON
从零到一构建网络爬虫帝国:HTTP协议+Python requests库深度解析
在网络数据的海洋中,网络爬虫遵循HTTP协议,穿梭于互联网各处,收集宝贵信息。本文将从零开始,使用Python的requests库,深入解析HTTP协议,助你构建自己的网络爬虫帝国。首先介绍HTTP协议基础,包括请求与响应结构;然后详细介绍requests库的安装与使用,演示如何发送GET和POST请求并处理响应;最后概述爬虫构建流程及挑战,帮助你逐步掌握核心技术,畅游数据海洋。
81 3
|
3月前
|
JSON API 开发者
深入解析Python网络编程与Web开发:urllib、requests和http模块的功能、用法及在构建现代网络应用中的关键作用
深入解析Python网络编程与Web开发:urllib、requests和http模块的功能、用法及在构建现代网络应用中的关键作用
28 0
|
5月前
|
存储 设计模式 前端开发
|
5月前
|
前端开发 API 网络架构
【Azure 应用服务】能否通过 Authentication 模块配置 Azure AD 保护 API 应用?
【Azure 应用服务】能否通过 Authentication 模块配置 Azure AD 保护 API 应用?
|
5月前
|
Kubernetes Go API
构建 Golang 应用程序的实用方法
构建 Golang 应用程序的实用方法
|
5月前
|
缓存 JavaScript 前端开发
为开源项目 go-gin-api 增加 WebSocket 模块
为开源项目 go-gin-api 增加 WebSocket 模块
52 2
|
5月前
|
存储 测试技术 Go
Golang 包:构建模块化代码的基石
【8月更文挑战第31天】
55 0
|
5月前
|
存储 安全 Go