当前位置: 首页 > news >正文

Go语言——kratos微服务框架使用

文章目录

  • 一、安装依赖
  • 二、创建项目
  • 三、初始化项目
  • 四、使用git_bash命令终端运行命令
  • 五、创建自己的项目
    • 1、修改app.proto
    • 3、internal/service/app.go
    • 4、修改internal/service/service.go文件
    • 5、创建internal/biz/content.go文件
    • 6、修改internal/biz/biz.go文件
    • 7、创建internal/data/content.go文件
    • 8.修改internal/data/data.go文件
  • 9、修改ContentManage/configs/config.yaml文件
    • 12、创建ContentManage/cmd/client/client.go,来rpc调用方法

一、安装依赖

  • 1、设置代理
    在这里插入图片描述
  • 2、安装依赖
# 安装Kratos tool
go install github.com/go-kratos/kratos/cmd/kratos/v2@latest

二、创建项目

# 然后在GOPATH\bin目录下能找到kratos.exe,在需要创建项目的目录下执行,即可创建项目
kratos new helloworld
# 如果默认的github不通的话,可以用gitee拉取
kratos new helloworld -r https://gitee.com/go-kratos/kratos-layout.git

三、初始化项目

# 进入helloworld目录
cd helloworld
# 初始化项目
make init
  • 如果没有make命令,可以在网盘中下载
  • 如果没有protoc命令,也可以在网盘中下载,并配置其环境变量

四、使用git_bash命令终端运行命令

# 初始化
make init
# 生成api
make api
# 构建
make build
# 所有操作
make all
# 启动kracos
kracos run
# 测试
curl 'http://127.0.0.1:8000/kracos'

五、创建自己的项目

# 创建内容管理项目
kratos new ContentManage -r https://gitee.com/go-kratos/kratos-layout.git# 进入目录
cd ./ContentManage# 拉取依赖
go mod download# 1.添加我们的自定义协议,并修改为我们自定义的接口,如下
kratos proto add api/operate/app.proto# 2.修改完成之后,重新生成go文件
make api# 3.在internal/service下创建app.go文件。代码如下
# 4.修改internal/service/service.go文件
# 5.创建internal/biz/content.go文件
# 6.修改internal/biz/biz.go文件
# 7.创建internal/data/content.go文件
# 8.修改internal/data/data.go文件
# 9.修改ContentManage/configs/config.yaml文件
# 10.执行命令,重新生成代码
make all
# 11.启动
kratos run
# 12.创建ContentManage/cmd/client/client.go,来rpc调用方法

1、修改app.proto

syntax = "proto3";import "google/api/annotations.proto";package api.operate;option go_package = "ContentManage/api/operate;operate";
option java_multiple_files = true;
option java_package = "api.operate";service App {// 创建内容rpc CreateContent (CreateContentReq) returns (CreateContentResp) {option (google.api.http) = {post: "/api/cms/content/create",body: "content"};};
}message Content {// 内容idint64 id = 1;// 内容标题string title = 2;// 视频播放urlstring videoUrl = 3;// 作者string author = 4;// 内容描述string description =5;// 封面图urlstring thumbnail = 6;// 内容分类string category = 7;// 内容时长int64 duration = 8;// 分辨率string resolution = 9;// 文件大小int64 fileSize = 10;// 文件格式string format = 11;// 视频质量1-高清 2-标清int32 quality = 12;// 审核状态 1-审核中 2-审核通过 3-审核不通过int32 approvalStatus = 13;
}message CreateContentReq {// 内容Content content = 1;
}
message CreateContentResp {}

3、internal/service/app.go

package serviceimport ("ContentManage/api/operate""ContentManage/internal/biz"
)type AppService struct {operate.UnimplementedAppServeruc *biz.ContentUsecase
}// NewAppService new a app service.
func NewAppService(uc *biz.ContentUsecase) *AppService {return &AppService{uc: uc}
}

4、修改internal/service/service.go文件

package serviceimport "github.com/google/wire"// ProviderSet is service providers.
var ProviderSet = wire.NewSet(NewAppService)

5、创建internal/biz/content.go文件

package bizimport ("context""github.com/go-kratos/kratos/v2/log""time"
)type Content struct {Id             int           `gorm:"column:id;primary_key"`  // 内容idTitle          string        `gorm:"column:title"`           // 内容标题Description    string        `gorm:"column:description"`     // 内容描述Author         string        `gorm:"column:author"`          // 作者VideoUrl       string        `gorm:"column:video_url"`       // 视频播放URLThumbnail      string        `gorm:"column:thumbnail"`       // 封面页URLCategory       string        `gorm:"column:category"`        // 内容分类Duration       time.Duration `gorm:"column:duration"`        // 内容时长Resolution     string        `gorm:"column:resolution"`      // 分辨率FileSize       int64         `gorm:"column:file_size"`       // 文件大小Format         string        `gorm:"column:format"`          // 文件格式 如MP4等Quality        int32         `gorm:"column:quality"`         // 视频质量 1-高清 2-标清ApprovalStatus int32         `gorm:"column:approval_status"` // 审核状态 1-审核中 2-审核通过 3-审核不通过CreatedAt      time.Time     `gorm:"column:created_at"`      // 内容创建时间UpdatedAt      time.Time     `gorm:"column:updated_at"`      // 内容更新时间
}func (c Content) TableName() string {return "cms_content.t_content_detail"
}type ContentRepo interface {Create(context.Context, *Content) error
}type ContentUsecase struct {repo ContentRepolog  *log.Helper
}// NewContentUsecase new a Content usecase.
func NewContentUsecase(repo ContentRepo, logger log.Logger) *ContentUsecase {return &ContentUsecase{repo: repo, log: log.NewHelper(logger)}
}func (uc *ContentUsecase) CreateContext(ctx context.Context, content *Content) error {uc.log.WithContext(ctx).Infof("CreateContext: %v+v", content)return uc.repo.Create(ctx, content)
}

6、修改internal/biz/biz.go文件

package bizimport "github.com/google/wire"// ProviderSet is biz providers.
var ProviderSet = wire.NewSet(NewContentUsecase)

7、创建internal/data/content.go文件

package dataimport ("ContentManage/internal/biz""context""github.com/go-kratos/kratos/v2/log"
)type contentRepo struct {data *Datalog  *log.Helper
}func NewContentRepo(data *Data, logger log.Logger) biz.ContentRepo {return &contentRepo{data: data,log:  log.NewHelper(logger),}
}func (r *contentRepo) Create(ctx context.Context, content *biz.Content) error {r.log.Infof("contentRepo Create content = %+v", content)return r.data.db.Save(content).Error
}

8.修改internal/data/data.go文件

package dataimport ("ContentManage/internal/conf""gorm.io/driver/mysql""gorm.io/gorm""github.com/go-kratos/kratos/v2/log""github.com/google/wire"
)// ProviderSet is data providers.
var ProviderSet = wire.NewSet(NewData, NewContentRepo)// Data .
type Data struct {db *gorm.DB
}// NewData .
func NewData(c *conf.Data, logger log.Logger) (*Data, func(), error) {cleanup := func() {log.NewHelper(logger).Info("closing the data resources")}mysqlDB, err := gorm.Open(mysql.Open(c.GetDatabase().Source))if err != nil {log.Error("[data] failed to connect database", "error", err)panic(err)}db, err := mysqlDB.DB()if err != nil {log.Error("[data] failed to connect database", "error", err)panic(err)}db.SetMaxOpenConns(4)db.SetMaxIdleConns(2)return &Data{db: mysqlDB,}, cleanup, nil
}

9、修改ContentManage/configs/config.yaml文件

server:http:addr: 0.0.0.0:8000timeout: 1sgrpc:addr: 0.0.0.0:9000timeout: 1s
data:database:driver: mysqlsource: root:p@ssw0rd@tcp(127.0.0.1:3306)/?charset=utf8mb4&parseTime=True&loc=Localredis:addr: 127.0.0.1:6379read_timeout: 0.2swrite_timeout: 0.2s

12、创建ContentManage/cmd/client/client.go,来rpc调用方法

package mainimport ("ContentManage/api/operate""context""github.com/go-kratos/kratos/v2/log""github.com/go-kratos/kratos/v2/middleware/recovery""github.com/go-kratos/kratos/v2/transport/grpc"
)func main() {conn, err := grpc.DialInsecure(context.Background(),grpc.WithEndpoint("127.0.0.1:9000"),grpc.WithMiddleware(recovery.Recovery()),)if err != nil {panic(err)}defer conn.Close()client := operate.NewAppClient(conn)reply, err := client.CreateContent(context.Background(), &operate.CreateContentReq{Content: &operate.Content{Title:       "test content_manage create",VideoUrl:    "https://example.com/video.mp4",Author:      "lucky",Description: "test",},})if err != nil {log.Fatal(err)}log.Infof("[grpc] CreateContent %v\n", reply)
}

相关文章:

  • Linux 进程控制 基础IO
  • 关系数据库-关系运算
  • Docker Compose 的历史和发展
  • C++ RAII机制
  • LeetCode 高频题实战:如何优雅地序列化和反序列化字符串数组?
  • 深入解析PyTorch中MultiheadAttention的隐藏参数add_bias_kv与add_zero_attn
  • Redis 缓存
  • Python爬虫实战:研究网站动态滑块验证
  • 数据结构【二叉树的遍历实现】
  • Python打卡训练营Day22
  • LiteLLM:统一API接口,让多种LLM模型调用如臂使指
  • Cribl 利用CSV 对IP->hostname 的转换
  • 卫宁健康WiNGPT3.0与WiNEX Copilot 2.2:医疗AI创新的双轮驱动分析
  • 如何选择 RabbitMQ、Redis 队列等消息中间件?—— 深度解析与实战评估
  • Mac下Robotframework + Python3环境搭建
  • 视频编解码学习三之显示器续
  • MIT XV6 - 1.5 Lab: Xv6 and Unix utilities - xargs
  • Python赋能自动驾驶:如何打造高效的环境感知系统
  • 超市销售管理系统 - 需求分析阶段报告
  • “多端多接口多向传导”空战数据链体系——从异构融合架构到抗毁弹性网络的系统性设计
  • 甘肃:今年6月前,由县级党委、政府制定农村彩礼倡导性标准
  • 白玉兰奖征片综述丨综艺市场破局焕新,多元赛道重塑价值坐标
  • 山东枣庄同一站点两名饿了么骑手先后猝死,当地热线:职能部门正调查
  • 署名文章:从宏观调控看中国经济基本面
  • 中美经贸高层会谈11日在日内瓦将继续进行
  • 观察|天空之外的战场:官方叙事、新闻与社交平台中的印巴冲突