{"id":19176104,"url":"https://github.com/davaddi/grpclb","last_synced_at":"2025-05-07T19:22:10.776Z","repository":{"id":57488308,"uuid":"147447964","full_name":"DavadDi/grpclb","owner":"DavadDi","description":"gRPC Client Side Load Balancer  Resolver based on Etcd v3","archived":false,"fork":false,"pushed_at":"2018-09-07T03:25:46.000Z","size":14639,"stargazers_count":14,"open_issues_count":1,"forks_count":4,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-04-20T01:33:08.070Z","etag":null,"topics":["etcdv3","grpc","loadbalancer","resolver","service-discovery"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/DavadDi.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-09-05T02:25:57.000Z","updated_at":"2024-11-19T05:59:15.000Z","dependencies_parsed_at":"2022-08-29T15:01:26.143Z","dependency_job_id":null,"html_url":"https://github.com/DavadDi/grpclb","commit_stats":null,"previous_names":[],"tags_count":1,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DavadDi%2Fgrpclb","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DavadDi%2Fgrpclb/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DavadDi%2Fgrpclb/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DavadDi%2Fgrpclb/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/DavadDi","download_url":"https://codeload.github.com/DavadDi/grpclb/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":252941415,"owners_count":21828872,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["etcdv3","grpc","loadbalancer","resolver","service-discovery"],"created_at":"2024-11-09T10:27:12.317Z","updated_at":"2025-05-07T19:22:05.726Z","avatar_url":"https://github.com/DavadDi.png","language":"Go","readme":"# grpclb\n\n## 注册结构\n\n```go\n// ServerNodeInfo regiested to etcd\ntype ServerNodeInfo struct {\n\tName           string    // 服务名称\n\tVersion        string    // 服务版本号，用于服务升级过程中，配置兼容问题\n\tHostName       string    // 主机名称\n\tAddr           string    // 服务的地址, 格式为 ip:port，参见 https://github.com/grpc/grpc/blob/master/doc/naming.md\n\tWeight         uint16    // 服务权重\n\tLastUpdateTime time.Time // 更新时间使用租约机制\n\tMetaData       string    // 后续考虑替换成 interface{} 推荐 json 格式，服务端与客户端可以约定相关格式\n}\n```\n\n\n\n## 服务注册\n\ngRPC Server 启动的时候调用 Register 函数进行服务相关信息注册。注册过程需要使用 TLL 机制，保证服务信息因异常情况下失效。\n\n\n## 服务访问\ngRPC 使用 LoadBanlance 中的 resover 使用注册的服务信息。首次连接的时候进行全量拉取，后续采用 Watcher 的方式来进行增删，为保证可靠性，设置定期拉取 Sync 的过程。\n\n通过自定义 gRPC esover 的方式，保证对于 gRPC 服务端访问时的透明性。\n\n\n\n## 测试\n\n```\n# 默认端口 2379\n$ ./etcd\n\n$ make test\n\n$ ETCDCTL_API=3 ./etcdctl get --prefix=true \"\"\n```\n\n## 备注\n由于 glide 管理包依赖过程中存在问题， vendor 目录部分代码经过了手工调整。\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdavaddi%2Fgrpclb","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdavaddi%2Fgrpclb","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdavaddi%2Fgrpclb/lists"}