分布式对象存储学习笔记(三)——HTTP请求封装

对go语言的http包作一些封装,把http函数调用转换成读写流的形式。用于接口服务调用数据服务实现数据传输。

type PutStream struct {
   
	writer *io.PipeWriter
	c      chan error //用于把一个协程传输数据过程中的错误传回主线程
}

func NewPutStream(server, object string) *PutStream {
   
	reader, writer := io.Pipe() //一对管道 写入write的内容可以从reader读出来
	c := make(chan error)
	//管道的读写是阻塞 因此需要开启一个协程来调用client.Do(request)方法
	go func() {
   
		request, _ := http.NewRequest("PUT", "http://"+server+"/objects/"+object, reader)
		client := http.Client
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值