使用golang及gorm通过MySQL实现消息队列,保证日志先行,持久化,失败补偿,事务性多客户端并发消费,可水平扩展...

代码目录:

main.go

go.mod

go.sum

makeData/makeData.go

main.go:

package main

import (  "fmt"  "strconv"  "strings"   //"mysqltaskdirdemo/makeData"   "gorm.io/driver/mysql"  "gorm.io/gorm" )  type VsTask struct {  ID uint  Sha256 string  FileType uint8 }  type VsDir struct {  ID uint  VsTaskId string }  func CreateVsDir(db *gorm.DB) error {  // Note the use of tx as the database handle once you are within a transaction  //get min id from vs_tasks  //get five records from vs_tasks  //insert into this five records to vs_dirs  //delete this five records from vs_tasks  //commit  tx := db.Begin()  defer func() {  if r := recover(); r != nil {  tx.Rollback()  }  }()   if err := tx.Error; err != nil {  return err  }   var ID string  if err := tx.Raw("SELECT MIN(ID) FROM vs_tasks").Scan(&ID).Error; err != nil {  tx.Rollback()  return err  }   var IDs []string  IDnum, err := strconv.Atoi(ID)  if err != nil {  panic(err)  }  upID := IDnum + 4  if err := tx.Raw("select ID from vs_tasks WHERE ID >= ? and ID <= ? for update", ID, upID).Scan(&IDs).Error; err != nil {  tx.Rollback()  return err  }   VsTaskIdStr := strings.Join(IDs
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值