【Tars-go】腾讯微服务框架学习使用02-- http 服务

2 http 服务

官方文档说http这里是在net/http原生包的基础上做了修改。

官方给的案例:

go 复制代码
package main

import (
	"net/http"
	"github.com/TarsCloud/TarsGo/tars"
)

func main() {
	mux := &tars.TarsHttpMux{}
	mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
		w.Write([]byte("Hello tafgo"))
	})

    cfg := tars.GetServerConfig()
	tars.AddHttpServant(mux, cfg.App+"."+cfg.Server+".HttpObj") //Register http server
	tars.Run()
}

可以看到 在初始化了TarsHttpMux, 再将TarsHttpMux 注册到tars框架中作为servant就可以启动http服务。

  1. TarsHttpMux是什么:

    go 复制代码
    // TarsHttpMux is http.ServeMux for tars http server.
    type TarsHttpMux struct {
    	http.ServeMux
    	cfg *TarsHttpConf
    }

    可以看出TarsHttpMux确实就只是对http.ServeMux做了个包装加入了Conf 并加入了上报状态信息、计算耗时等基本服务器功能。

  2. TarsHttpMux 注册到tars框架中作为servant:

    1. tars.AddHttpServant的底层实现函数如下:

    go 复制代码
    // AddHttpServantWithExceptionStatusChecker add http servant handler with exceptionStatusChecker for obj.
    func (a *application) AddHttpServantWithExceptionStatusChecker(mux HttpHandler, obj string, exceptionStatusChecker func(int) bool) {
    	cfg, ok := a.tarsConfig[obj]
    	if !ok {
    		msg := fmt.Sprintf("http servant obj name not found: %s", obj)
    		ReportNotifyInfo(NotifyError, msg)
    		TLOG.Debug(msg)
    		panic(errors.New(msg))
    	}
    	TLOG.Debugf("add http protocol server: %+v", cfg)
    	a.objRunList = append(a.objRunList, obj)
    	addrInfo := strings.SplitN(cfg.Address, ":", 2)
    	var port int64
    	if len(addrInfo) == 2 {
    		var err error
    		port, err = strconv.ParseInt(addrInfo[1], 10, 32)
    		if err != nil {
    			panic(fmt.Errorf("http server listen port: %s parse err: %v", addrInfo[1], err))
    		}
    	}
    	svrCfg := a.ServerConfig()
    	httpConf := &TarsHttpConf{
    		Container:              svrCfg.Container,
    		AppName:                fmt.Sprintf("%s.%s", svrCfg.App, svrCfg.Server),
    		Version:                svrCfg.Version,
    		IP:                     addrInfo[0],
    		Port:                   int32(port),
    		SetId:                  svrCfg.Setdivision,
    		ExceptionStatusChecker: exceptionStatusChecker,
    	}
    	mux.SetConfig(httpConf)
    	s := &http.Server{Addr: cfg.Address, Handler: mux, TLSConfig: cfg.TlsConfig}
    	a.httpSvrs[obj] = s
    }
    1. 简单来说就是将http根据配置实例化-》再注册Sever-》这代码很好理解
  3. 配置文件配置servant

    xml 复制代码
    <tars>
        <application>
            <server>
                <AiGo.backend.HttpObjAdapter>
                    allow
                    endpoint=http -h 127.0.0.1 -p 18080 -t 60000
                    handlegroup=AiGo.backend.HttpObjAdapter
                    maxconns=200000
                    protocol=http
                    queuecap=10000
                    queuetimeout=60000
                    servant=AiGo.backend.HttpObj
                    shmcap=0
                    shmkey=0
                    threads=1
                </AiGo.backend.HttpObjAdapter>
            </server>
        </application>
    </tars>

    可以看出就protocol=http 这里改了,其他的和tars服务没啥区别。

相关推荐
龘龍龙1 小时前
大模型学习(三)-RAG、LangChain
学习·langchain
计算机安禾2 小时前
【数据结构与算法】第22篇:线索二叉树(Threaded Binary Tree)
c语言·开发语言·数据结构·学习·算法·链表·visual studio code
计算机安禾2 小时前
【数据结构与算法】第21篇:二叉树遍历的经典问题:由遍历序列重构二叉树
c语言·数据结构·学习·算法·重构·visual studio code·visual studio
信奥胡老师2 小时前
P1255 数楼梯
开发语言·数据结构·c++·学习·算法
s1mple“”3 小时前
大厂Java面试实录:从Spring Boot到AI技术的电商场景深度解析
spring boot·redis·微服务·kafka·向量数据库·java面试·ai技术
夜幕下的ACM之路3 小时前
一、基础知识学习(Transformer + 上下文窗口 + Token 计算 + Embedding 向量)
人工智能·学习·transformer·embedding
GHL2842710903 小时前
Base64学习
学习
知识分享小能手3 小时前
MongoDB入门学习教程,从入门到精通,MongoDB创建副本集知识点梳理(10)
数据库·学习·mongodb
星幻元宇VR3 小时前
VR动感科普单车:让交通安全教育更真实、更有效
科技·学习·安全·生活·vr
@atweiwei4 小时前
深入解析gRPC服务发现机制
微服务·云原生·rpc·go·服务发现·consul