combine_service.go 36 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070
  1. package model
  2. import (
  3. "encoding/base64"
  4. "errors"
  5. "fmt"
  6. "github.com/go-redis/redis"
  7. "os"
  8. "rocommon"
  9. "rocommon/service"
  10. "rocommon/util"
  11. "roserver/baseserver/model"
  12. "roserver/baseserver/set"
  13. model3 "roserver/battleboss/model"
  14. model5 "roserver/cross_rank/model"
  15. model6 "roserver/cross_server/model"
  16. model2 "roserver/db/model"
  17. model4 "roserver/game/model"
  18. model7 "roserver/guild/model"
  19. "roserver/serverproto"
  20. "strconv"
  21. "strings"
  22. "time"
  23. )
  24. var typeServerActsList = set.New(set.NonThreadSafe)
  25. func ConvertOldRedis() {
  26. err := util.InitLog(1, 0, "./log", "test", "")
  27. if err != nil {
  28. return
  29. }
  30. err = service.ServerCmd.Parse(os.Args[1:])
  31. if err != nil {
  32. util.InfoF("param parse err=%v", err)
  33. return
  34. }
  35. //加载活动配置表,查看哪些活动类型是开服时间活动
  36. path := "./config/csv/"
  37. //
  38. serverproto.ItemCfgLoad(path)
  39. serverproto.ActivitiesCfgLoad(path)
  40. serverproto.GlobalCfgLoad(path)
  41. serverproto.RuneShopGiftsCfgLoad(path)
  42. serverproto.GuildBossCfgLoad(path)
  43. model.ConvertOldRedisGlobalCfg()
  44. model.ConvertOldRedisRuneCfg()
  45. //for _, cfgData := range serverproto.ActivitiesCfgLoader {
  46. // startDataList := strings.Split(cfgData.StartTime, ";")
  47. // endDataList := strings.Split(cfgData.EndTime, ";")
  48. // if len(startDataList) > 0 && len(endDataList) > 0 {
  49. // tmpTimeType, _ := model.Str2Num(startDataList[0])
  50. // if tmpTimeType == model.ActivitiesTime_Type_Server {
  51. // typeServerActsList.Add(cfgData.Id)
  52. // }
  53. // }
  54. //}
  55. //typeServerActsList.Add(int32(4)) //每日累充必须重置
  56. //util.InfoF("typeServerActsList=%v", typeServerActsList.List())
  57. //
  58. //合并redis进程监听地址
  59. tmpIpStr := ""
  60. if *service.IPParam != "" {
  61. tmpIpStr = *service.IPParam
  62. }
  63. //tmpPortStr := ""
  64. //if *service.TempParam != "" {
  65. // tmpPortStr = *service.TempParam
  66. //}
  67. // 新增: 支持同一个redis实例按db列表执行,参数格式: -dbs 0,1,2
  68. tmpDbStr := ""
  69. if service.DBListParam != nil {
  70. tmpDbStr = strings.TrimSpace(*service.DBListParam)
  71. }
  72. if tmpDbStr != "" {
  73. if tmpIpStr == "" {
  74. util.InfoF("convert abort: ip is empty when using -dbs")
  75. return
  76. }
  77. dbStrList := strings.Split(tmpDbStr, ",")
  78. dbList := make([]int, 0, len(dbStrList))
  79. for _, dbRaw := range dbStrList {
  80. dbStr := strings.TrimSpace(dbRaw)
  81. dbIdx, err := strconv.Atoi(dbStr)
  82. if err != nil || dbIdx < 0 {
  83. util.InfoF("skip invalid db index=%v err=%v", dbStr, err)
  84. continue
  85. }
  86. dbList = append(dbList, dbIdx)
  87. }
  88. if len(dbList) == 0 {
  89. util.InfoF("convert abort: no valid db in -dbs=%v", tmpDbStr)
  90. return
  91. }
  92. // 1) 逐个DB执行原有清洗逻辑
  93. for idx := 0; idx < len(dbList); idx++ {
  94. dbIdx := dbList[idx]
  95. convertOldRedis(tmpIpStr, dbIdx, idx == len(dbList)-1, false)
  96. util.InfoF("convert finish ip=%v db=%v", tmpIpStr, dbIdx)
  97. }
  98. // 2) 按dbs顺序,把后续DB合并到第一个DB
  99. targetDB := dbList[0]
  100. for idx := 1; idx < len(dbList); idx++ {
  101. sourceDB := dbList[idx]
  102. err = mergeDbIntoFirst(tmpIpStr, sourceDB, targetDB)
  103. if err != nil {
  104. util.ErrorF("merge db err source=%v target=%v err=%v", sourceDB, targetDB, err)
  105. return
  106. }
  107. util.InfoF("merge finish source=%v target=%v", sourceDB, targetDB)
  108. }
  109. // 3) 仅目标库执行一次持久化
  110. //convertOldRedis(tmpIpStr, targetDB, true, true)
  111. util.InfoF("persist finish target db=%v", targetDB)
  112. return
  113. }
  114. //tmpPortStrList := strings.Split(tmpPortStr, ",")
  115. //for idx := 0; idx < len(tmpPortStrList); idx++ {
  116. // ipStr := tmpIpStr + ":" + tmpPortStrList[idx]
  117. // if idx == len(tmpPortStrList)-1 {
  118. // convertOldRedis(ipStr, 0, true)
  119. // } else {
  120. // convertOldRedis(ipStr, 0, false)
  121. // }
  122. // util.InfoF("convert finish ipStr=%v", ipStr)
  123. //}
  124. //var ipStrList = []string{
  125. // "127.0.0.1:6379",
  126. //}
  127. //for idx := 0; idx < len(ipStrList); idx++ {
  128. // convertOldRedis(ipStrList[idx])
  129. //}
  130. }
  131. func convertOldRedis(redisIpStr string, dbIndex int, lastOne bool, persistOnly bool) {
  132. //直接获取远端redis数据,调用db接口
  133. cli := service.NewNetRedisConnector([]string{redisIpStr}, "", dbIndex, 0)
  134. service.SetRedis(cli)
  135. util.InfoF("convert start redis=%v db=%v lastOne=%v", redisIpStr, dbIndex, lastOne)
  136. if persistOnly {
  137. service.GetRedis().ConfigSet("appendonly", "yes")
  138. service.GetRedis().BgSave()
  139. service.GetRedis().BgRewriteAOF()
  140. return
  141. }
  142. //0.获取角色uid列表
  143. uidList := getUidListFromRedis()
  144. util.InfoF("uidListSize=%v", len(uidList))
  145. ////1.清除当前数据库中不需要的数据(数据清除分个人数据/共用数据)
  146. for idx := 0; idx < len(uidList); idx++ {
  147. uid := uidList[idx]
  148. //1.1活动数据处理 role_activity.go
  149. convertActivityOldRedis(typeServerActsList, uid)
  150. //1.2英灵殿 role_arena.go
  151. convertArenaOldRedis(uid)
  152. //1.3地图 role_battle.go
  153. convertRoleBattleOldRedis(uid)
  154. //1.4赛季 role_competition.go
  155. convertRoleCompetitionOldRedis(uid)
  156. //1.5百人道场 role_daochang100.go
  157. convertRoleDaochang100OldRedis(uid)
  158. //1.6公会 role_guild.go
  159. convertRoleGuildOldRedis(uid)
  160. //1.7邮件 role_mail.go
  161. convertRoleMailOldRedis(uid)
  162. //1.8世界boss role_map.go
  163. convertRoleMapOldRedis(uid)
  164. //1.9卢恩商店 role_rune.go
  165. convertRoleRuneOldRedis(uid)
  166. //1.10冲榜 role_rush.go
  167. convertRoleRushOldRedis(uid)
  168. //1.11爬塔 role_tower.go
  169. convertRoleTowerOldRedis(uid)
  170. //1.12背包数据删除(背包内的活动数据)
  171. convertRoleBagOldRedis(uid)
  172. }
  173. //系统共用数据部分
  174. //1.1.1 role_activity.go
  175. service.GetRedis().Del(model.ActivitiesCollectionDataPrefix) //活动全局数据
  176. //1.2.1 role_arena.go
  177. convertArenaOldCommonRedis()
  178. //1.3.1 role_battle.go 远征之门积分排行榜
  179. service.GetRedis().Del(model.ExpeditionScoreRankPrefix) //合并数据后数据自动重排
  180. //1.3.2 推图冲榜(冒险盛典)排行榜
  181. service.GetRedis().Del(model.RushMapScorePrefix)
  182. service.GetRedis().Del(model.RushMapPrefix)
  183. service.GetRedis().Del(model.RushMapRankPrefix)
  184. tmpList, _ := service.GetRedis().Keys(model.RushMapRankPrefix + "*").Result()
  185. for idx := 0; idx < len(tmpList); idx++ {
  186. service.GetRedis().Del(tmpList[idx])
  187. }
  188. //1.4.1 role_competition.go
  189. convertRoleCompetitionOldCommonRedis()
  190. //1.5.1 role_daochang100.go
  191. convertRoleDaochang100OldCommonRedis()
  192. //1.6.1 role_guild.go
  193. convertRoleGuildOldCommonRedis()
  194. //1.7.1 role_mail.go
  195. convertRoleMailOldCommonRedis()
  196. //1.8.1 role_map.go
  197. convertRoleMapOldCommonRedis()
  198. //1.10.1 role_rush.go
  199. //宠物盛典 ,技能盛典
  200. convertRoleRushOldCommonRedis()
  201. //1.11.1 role_tower.go
  202. convertRoleTowerOldCommonRedis()
  203. //1.12.1跨服玩法 巅峰爬塔/远航试炼
  204. convertRoleCrossOldRedisCommon()
  205. //战斗记录数据清除
  206. service.GetRedis().Del(model.BattleRecordMapPrefix)
  207. service.GetRedis().Del(model.BattleRecordDetailPrefix)
  208. service.GetRedis().Del(model.BattleRecordDetailCheckPrefix)
  209. //卡片收集rank清除
  210. service.GetRedis().Del(model.CardCollectRankPrefix)
  211. //信物收集
  212. service.GetRedis().Del(model.KeepSakeCollectRankPrefix)
  213. //推图排行榜和历史最大战力排行榜(aof启动后会自动合并zset中的排行榜数据)
  214. ////2.导入数据到新redis数据库中
  215. //开启aof
  216. //service.GetRedis().ConfigSet("appendonly", "yes")
  217. ////service.GetRedis().ConfigSet("aof-use-rdb-preamble", "no")
  218. //service.GetRedis().BgSave()
  219. //service.GetRedis().BgRewriteAOF()
  220. }
  221. func getUidListFromRedis() []uint64 {
  222. var uidList []uint64
  223. tmpUidList, err := service.GetRedis().Keys("account_*").Result()
  224. if err != nil {
  225. return uidList
  226. }
  227. for idx := 0; idx < len(tmpUidList); idx++ {
  228. tmpMsg := &serverproto.SSAccountGetRoleListAck{}
  229. err := model.GetMessageFromRedis(tmpUidList[idx], "", tmpMsg)
  230. if err != nil || len(tmpMsg.Roles) <= 0 {
  231. util.ErrorF("account=%v getUidListFromRedis err=%v", tmpUidList[idx], err)
  232. continue
  233. }
  234. uidList = append(uidList, tmpMsg.Roles[0].Uid)
  235. }
  236. return uidList
  237. }
  238. func GetUidListFromRedis2() {
  239. cli := service.NewNetRedisConnector([]string{"127.0.0.1:6379"}, "", 7, 0)
  240. service.SetRedis(cli)
  241. var uidList []uint64
  242. tmpUidList, err := service.GetRedis().Keys("account_*").Result()
  243. if err != nil {
  244. fmt.Println("getUidListFromRedis2 err=", err)
  245. return
  246. }
  247. for idx := 0; idx < len(tmpUidList); idx++ {
  248. tmpMsg := &serverproto.SSAccountGetRoleListAck{}
  249. err := model.GetMessageFromRedis(tmpUidList[idx], "", tmpMsg)
  250. if err != nil || len(tmpMsg.Roles) <= 0 {
  251. util.ErrorF("account=%v getUidListFromRedis err=%v", tmpUidList[idx], err)
  252. continue
  253. }
  254. uidList = append(uidList, tmpMsg.Roles[0].Uid)
  255. }
  256. for _, v := range uidList {
  257. convertActivityOld2Redis(v)
  258. }
  259. fmt.Println("getUidListFromRedis2 done")
  260. }
  261. // role_activity.go
  262. func convertActivityOldRedis(typeServerActsList set.Interface, uid uint64) {
  263. uidStr := strconv.FormatUint(uid, 10)
  264. tmpRoleActivity := &serverproto.RoleActivity{}
  265. err := model2.GetSystemDataFromRedis(model2.RoleActivityDataSignPrefix, uid, tmpRoleActivity)
  266. if err != nil && err != service.NIL {
  267. util.ErrorF("uid=%v [convertActivityOldRedis] Get RoleActivitySign err=%v", uid, err)
  268. return
  269. }
  270. //1.过期列表中保留着以往开过的所有过期活动 ->清除根据开服时间的活动id
  271. var tmpExpiredActivityList []int32
  272. for idx := 0; idx < len(tmpRoleActivity.ExpiredActivityList); idx++ {
  273. expiredActivityId := tmpRoleActivity.ExpiredActivityList[idx]
  274. if !typeServerActsList.Has(expiredActivityId) {
  275. tmpExpiredActivityList = append(tmpExpiredActivityList, expiredActivityId)
  276. continue
  277. }
  278. activityIdStr := strconv.Itoa(int(expiredActivityId))
  279. tmpKeyStr := model2.RoleActivityDataPrefix + uidStr + ":" + activityIdStr
  280. service.GetRedis().Del(tmpKeyStr)
  281. }
  282. //2.已经开启的列表中清除根据开服时间的id
  283. retList := service.GetRedis().SMembers(model2.RoleActivityDataOpenListPrefix + uidStr).Val()
  284. for idx := 0; idx < len(retList); idx++ {
  285. openActivityId, _ := strconv.Atoi(retList[idx])
  286. if openActivityId <= 0 {
  287. service.GetRedis().SRem(model2.RoleActivityDataOpenListPrefix+uidStr, retList[idx])
  288. continue
  289. }
  290. if typeServerActsList.Has(int32(openActivityId)) {
  291. service.GetRedis().SRem(model2.RoleActivityDataOpenListPrefix+uidStr, retList[idx])
  292. tmpKeyStr := model2.RoleActivityDataPrefix + uidStr + ":" + retList[idx]
  293. service.GetRedis().Del(tmpKeyStr)
  294. }
  295. }
  296. //3.签到数据重置
  297. tmpRoleActivity.SignInfo = &serverproto.SignUp{
  298. SignRound: 1,
  299. CurDay: 0,
  300. CurSignInfo: &serverproto.CurRoundSign{
  301. LastSign: 0,
  302. },
  303. }
  304. //重新保存
  305. tmpRoleActivity.ExpiredActivityList = tmpExpiredActivityList
  306. err = model2.SetSystemDataToRedis(model2.RoleActivityDataSignPrefix, uid, tmpRoleActivity)
  307. if err != nil {
  308. util.ErrorF("uid=%v [convertActivityOldRedis] save err=%v", uid, err)
  309. }
  310. }
  311. func convertActivityOld2Redis(uid uint64) {
  312. uidStr := strconv.FormatUint(uid, 10)
  313. tmpRoleActivity := &serverproto.RoleActivity{}
  314. err := model2.GetSystemDataFromRedis(model2.RoleActivityDataSignPrefix, uid, tmpRoleActivity)
  315. if err != nil && err != service.NIL {
  316. util.ErrorF("uid=%v [convertActivityOldRedis] Get RoleActivitySign err=%v", uid, err)
  317. return
  318. }
  319. data := make([]*serverproto.ActivitiesDetailData, 0)
  320. for _, v := range tmpRoleActivity.ActivityDataList {
  321. if v.ActivitiesId == 36 || v.ActivitiesId == 43 || v.ActivitiesId == 49 {
  322. continue
  323. }
  324. data = append(data, v)
  325. }
  326. //2.已经开启的列表中清除根据开服时间的id
  327. retList := service.GetRedis().SMembers(model2.RoleActivityDataOpenListPrefix + uidStr).Val()
  328. for idx := 0; idx < len(retList); idx++ {
  329. openActivityId, _ := strconv.Atoi(retList[idx])
  330. if openActivityId == 36 || openActivityId == 43 || openActivityId == 49 {
  331. service.GetRedis().SRem(model2.RoleActivityDataOpenListPrefix+uidStr, retList[idx])
  332. tmpKeyStr := model2.RoleActivityDataPrefix + uidStr + ":" + retList[idx]
  333. service.GetRedis().Del(tmpKeyStr)
  334. continue
  335. }
  336. }
  337. var tmpExpiredActivityList []int32
  338. for idx := 0; idx < len(tmpRoleActivity.ExpiredActivityList); idx++ {
  339. expiredActivityId := tmpRoleActivity.ExpiredActivityList[idx]
  340. if expiredActivityId == 36 || expiredActivityId == 43 || expiredActivityId == 49 {
  341. activityIdStr := strconv.Itoa(int(expiredActivityId))
  342. tmpKeyStr := model2.RoleActivityDataPrefix + uidStr + ":" + activityIdStr
  343. service.GetRedis().Del(tmpKeyStr)
  344. continue
  345. }
  346. tmpExpiredActivityList = append(tmpExpiredActivityList, expiredActivityId)
  347. }
  348. //重新保存
  349. tmpRoleActivity.ActivityDataList = data
  350. tmpRoleActivity.ExpiredActivityList = tmpExpiredActivityList
  351. err = model2.SetSystemDataToRedis(model2.RoleActivityDataSignPrefix, uid, tmpRoleActivity)
  352. if err != nil {
  353. util.ErrorF("uid=%v [convertActivityOldRedis] save err=%v", uid, err)
  354. }
  355. }
  356. // roleanera
  357. func convertArenaOldRedis(uid uint64) {
  358. //uidStr := strconv.FormatUint(uid, 10)
  359. //1.竞技场赛季个人数据重置
  360. tmpRoleArena := &serverproto.RoleArena{}
  361. err := model2.GetSystemDataFromRedis(model2.RoleArenaDataPrefix, uid, tmpRoleArena)
  362. if err != nil && err != service.NIL {
  363. util.ErrorF("uid=%v [convertArenaOldRedis] Get RoleArena err=%v", uid, err)
  364. return
  365. }
  366. if tmpRoleArena.Arena == nil {
  367. return
  368. }
  369. //重置剩余挑战次数/剩余购买次数
  370. tmpRoleArena.Arena.ChallengeCount = model.GlobalDaoChangChallengeCount
  371. tmpRoleArena.Arena.BuyCount = model.GlobalDaoChangByCount
  372. //重置段位/积分
  373. tmpRoleArena.Arena.ArenaSeasonId = 0
  374. tmpRoleArena.Arena.LastArenaSeasonTime = 0
  375. tmpRoleArena.Arena.RecordWinCount = 0
  376. tmpRoleArena.Arena.RecordTotalCount = 0
  377. tmpRoleArena.Arena.ArenaSeasonIdReduce = 0
  378. tmpRoleArena.Arena.Score = 0
  379. tmpRoleArena.Arena.OldScore = 0
  380. tmpRoleArena.Arena.RushArena = nil
  381. err = model2.SetSystemDataToRedis(model2.RoleArenaDataPrefix, uid, tmpRoleArena)
  382. if err != nil {
  383. util.ErrorF("uid=%v [convertArenaOldRedis] Set RoleArena err=%v", uid, err)
  384. }
  385. }
  386. func convertArenaOldCommonRedis() {
  387. //2.匹配数据处理
  388. //英灵殿积分排行榜,只用来match使用
  389. service.GetRedis().Del(model.ArenaRankMatchPrefix)
  390. //3.积分排行榜清除
  391. service.GetRedis().Del(model.ArenaRankPrefix)
  392. service.GetRedis().Del(model.ArenaPreRankPrefix)
  393. service.GetRedis().Del(model.ArenaTopRankPrefix)
  394. tmpTopList, _ := service.GetRedis().Keys(model.ArenaTopRankPrefix + "*").Result()
  395. for idx := 0; idx < len(tmpTopList); idx++ {
  396. if tmpTopList[idx] != model.ArenaTopRankPrefix {
  397. service.GetRedis().Del(tmpTopList[idx])
  398. }
  399. }
  400. //4.冲榜相关处理
  401. service.GetRedis().Del(model.RushArenaRankPrefix) //冲榜相关
  402. tmpTopList, _ = service.GetRedis().Keys(model.RushArenaRankPrefix + "*").Result()
  403. for idx := 0; idx < len(tmpTopList); idx++ {
  404. service.GetRedis().Del(tmpTopList[idx])
  405. }
  406. service.GetRedis().Del(model.RushArenaPrefix) //最终排行
  407. }
  408. // rolebattle
  409. func convertRoleBattleOldRedis(uid uint64) {
  410. //uidStr := strconv.FormatUint(uid, 10)
  411. tmpRoleBattle := &serverproto.RoleBattle{}
  412. err := model2.GetSystemDataFromRedis(model2.RoleBattleDataPrefix, uid, tmpRoleBattle)
  413. if err != nil && err != service.NIL {
  414. util.ErrorF("uid=%v [convertRoleBattleOldRedis] Get RoleBattle err=%v", uid, err)
  415. return
  416. }
  417. //1.时光之力
  418. if tmpRoleBattle.QuickBattle != nil {
  419. tmpRoleBattle.QuickBattle.DayTimes = 0
  420. }
  421. //2.远征之门积分排行榜 共用数据部分
  422. //service.GetRedis().Del(model.ExpeditionScoreRankPrefix)
  423. //3.推图冲榜(冒险盛典)
  424. tmpRoleBattle.RushMap = &serverproto.RushMap{}
  425. err = model2.SetSystemDataToRedis(model2.RoleBattleDataPrefix, uid, tmpRoleBattle)
  426. if err != nil {
  427. util.ErrorF("uid=%v [convertRoleBattleOldRedis] save err=%v", uid, err)
  428. }
  429. }
  430. // rolecompetition
  431. func convertRoleCompetitionOldRedis(uid uint64) {
  432. uidStr := strconv.FormatUint(uid, 10)
  433. service.GetRedis().Del(model2.RoleCompetitionDataPrefix + uidStr)
  434. //1.招募季,地图排行榜(需要清空地图排行榜)
  435. //夺宝数据清空(在道场数据中)
  436. }
  437. func convertRoleCompetitionOldCommonRedis() {
  438. //历史进行到的赛季数据伤处
  439. service.GetRedis().Del(model.ServerCompetitionPrefix)
  440. //1.招募季赛季信息删除
  441. service.GetRedis().Del(model.CompetitionMapRankPrefix)
  442. tmpList, _ := service.GetRedis().Keys(model.CompetitionMapRankPrefix + "*").Result()
  443. for idx := 0; idx < len(tmpList); idx++ {
  444. service.GetRedis().Del(tmpList[idx])
  445. }
  446. //2.选拔季
  447. service.GetRedis().Del(model.CompetitionScoreRankPrefix)
  448. tmpList, _ = service.GetRedis().Keys(model.CompetitionScoreRankPrefix + "*").Result()
  449. for idx := 0; idx < len(tmpList); idx++ {
  450. service.GetRedis().Del(tmpList[idx])
  451. }
  452. //3.夺宝赛季:道场轮盘/活动转盘
  453. service.GetRedis().Del(model.CompetitionDuoBaoScoreRankPrefix)
  454. tmpList, _ = service.GetRedis().Keys(model.CompetitionDuoBaoScoreRankPrefix + "*").Result()
  455. for idx := 0; idx < len(tmpList); idx++ {
  456. service.GetRedis().Del(tmpList[idx])
  457. }
  458. //大奖日志数据
  459. service.GetRedis().Del(model.RoleDaoChang100WheeLogPrefix)
  460. //4.占星数据
  461. service.GetRedis().Del(model.CompetitionZhanBuScoreRankPrefix)
  462. tmpList, _ = service.GetRedis().Keys(model.CompetitionZhanBuScoreRankPrefix + "*").Result()
  463. for idx := 0; idx < len(tmpList); idx++ {
  464. service.GetRedis().Del(tmpList[idx])
  465. }
  466. //4.偶像季数据
  467. service.GetRedis().Del(model.CompetitionIdolScoreRankPrefix)
  468. tmpList, _ = service.GetRedis().Keys(model.CompetitionIdolScoreRankPrefix + "*").Result()
  469. for idx := 0; idx < len(tmpList); idx++ {
  470. service.GetRedis().Del(tmpList[idx])
  471. }
  472. }
  473. // roleguild
  474. func convertRoleGuildOldRedis(uid uint64) {
  475. //serverproto.SSGuildBossRefreshNtf
  476. //公会个人数据清楚
  477. tmpRoleGuild := &serverproto.RoleGuild{}
  478. err := model2.GetSystemDataFromRedis(model2.RoleGuildDataPrefix, uid, tmpRoleGuild)
  479. if err != nil && err != service.NIL {
  480. util.InfoF("uid=%v [convertRolegGuildOldRedis] err%v", uid, err)
  481. return
  482. }
  483. tmpRoleGuild.BossFight = tmpRoleGuild.BossFight[:0]
  484. tmpRoleGuild.GuildBattle = nil
  485. tmpRoleGuild.DemonInfo = nil
  486. tmpRoleGuild.EliteBossCd = 0
  487. err = model2.SetSystemDataToRedis(model2.RoleGuildDataPrefix, uid, tmpRoleGuild)
  488. if err != nil {
  489. util.ErrorF("uid=%v [convertRolegGuildOldRedis] err=%v", uid, err)
  490. }
  491. }
  492. func convertRoleGuildOldCommonRedis() {
  493. //1.公会狩猎-公会boss数据
  494. service.GetRedis().Del(model.GuildBossPrefix)
  495. tmpList, _ := service.GetRedis().Keys(model.GuildBossPrefix + "*").Result()
  496. //重新初始化公会狩猎boss
  497. for idx := 0; idx < len(tmpList); idx++ {
  498. for _, data := range serverproto.GuildBossCfgLoader {
  499. bossInfo := &serverproto.GuildBossInfo{}
  500. if data.BossType == model7.Guild_Boss_Type_Normal {
  501. nowTime := util.GetCurrentTimeNow()
  502. if nowTime.Hour() == 4 {
  503. bossInfo.BossState = model7.Guild_Boss_State_Wait_Summon
  504. } else {
  505. bossInfo.BossState = model7.Guild_Boss_State_Fight
  506. }
  507. bossInfo.RefreshTime = uint64(util.GetCurrentTime())
  508. bossInfo.MaxDam = &serverproto.GuildFight{}
  509. } else if data.BossType == model7.Guild_Boss_Type_Elite {
  510. bossInfo.BossState = model7.Guild_Boss_State_Wait_Summon
  511. }
  512. fieldStr := strconv.FormatUint(uint64(data.Id), 10)
  513. err, msgStr := model.GetEncodeMessage(bossInfo)
  514. if err == nil {
  515. ret, err := service.GetRedis().HSet(tmpList[idx], fieldStr, msgStr).Result()
  516. if err != nil {
  517. util.InfoF("[SaveGuildBoss] err:%v %v", err, ret)
  518. return
  519. }
  520. }
  521. }
  522. //service.GetRedis().Del(tmpList[idx])
  523. }
  524. //2.公会魔王
  525. service.GetRedis().Del(model.GuildDemonPrefix)
  526. service.GetRedis().Del(model.GuildDemonRewardPrefix)
  527. tmpList, _ = service.GetRedis().Keys(model.GuildDemonRewardPrefix + "*").Result()
  528. for idx := 0; idx < len(tmpList); idx++ {
  529. service.GetRedis().Del(tmpList[idx])
  530. }
  531. service.GetRedis().Del(model.GuildDemonGuildPrefix)
  532. service.GetRedis().Del(model.GuildDemonMVPPrefix)
  533. //3.公会战排行榜(百人道场积分排行榜)
  534. //已经在百人道场中清除RoleDaoChang100GuildRankPrefix
  535. //4.公会战
  536. service.GetRedis().Del(model7.GuildBattlePrefix)
  537. tmpList, _ = service.GetRedis().Keys(model7.GuildBattlePrefix + "*").Result()
  538. for idx := 0; idx < len(tmpList); idx++ {
  539. service.GetRedis().Del(tmpList[idx])
  540. }
  541. //公会战合服
  542. service.GetRedis().Del(model7.GuildBattleRankPrefix)
  543. tmpList, _ = service.GetRedis().Keys(model7.GuildBattleRankPrefix + "*").Result()
  544. for idx := 0; idx < len(tmpList); idx++ {
  545. service.GetRedis().Del(tmpList[idx])
  546. }
  547. service.GetRedis().Del(model7.GuildBattleLogPrefix)
  548. tmpList, _ = service.GetRedis().Keys(model7.GuildBattleLogPrefix + "*").Result()
  549. for idx := 0; idx < len(tmpList); idx++ {
  550. service.GetRedis().Del(tmpList[idx])
  551. }
  552. service.GetRedis().Del(model7.GuildBattleBasePrefix)
  553. service.GetRedis().Del(model7.GuildBattleTablePrefix)
  554. }
  555. // roledaochang100
  556. func convertRoleDaochang100OldRedis(uid uint64) {
  557. uidStr := strconv.FormatUint(uid, 10)
  558. //1.log状态重置
  559. service.GetRedis().HSet(model.RoleDaoChang100Prefix+uidStr, "log", 0)
  560. tmpRoleDaochang100 := &serverproto.RoleDaoChang100{}
  561. if !model2.GetRoleDaoChang100FromRedis(uid, tmpRoleDaochang100) {
  562. //util.ErrorF("uid=%v [convertRoleDaochang100OldRedis] load", uid)
  563. return
  564. }
  565. //2.重置挑战次数
  566. tmpRoleDaochang100.LogState = false
  567. tmpRoleDaochang100.ChallengeCount = model.GlobalDaoChang100ChallengeCount
  568. //4.道场转盘数据清空(赛季相关)
  569. tmpRoleDaochang100.WheelRewardItemList = nil
  570. tmpRoleDaochang100.WheelOpen = false
  571. tmpRoleDaochang100.WheelRefreshNum = 0
  572. tmpRoleDaochang100.TemplateIdx = 0
  573. tmpRoleDaochang100.WheelNum = 0
  574. tmpRoleDaochang100.WheelIdx = 0
  575. model2.SetRoleDaoChang100ToRedis(uid, tmpRoleDaochang100)
  576. //3.占位奖励列表清空
  577. service.GetRedis().Del(model.DaoChang100RewardPrefix + uidStr)
  578. }
  579. func convertRoleDaochang100OldCommonRedis() {
  580. //4.占位数据初始化为机器人数据
  581. service.GetRedis().Del(model.DaoChang100Prefix)
  582. //5.百人道场公会贡献点排行榜
  583. //占位获取奖励中包含积分
  584. service.GetRedis().Del(model.RoleDaoChang100GuildRankPrefix)
  585. tmpList, _ := service.GetRedis().Keys(model.RoleDaoChang100GuildRankPrefix + "*").Result()
  586. for idx := 0; idx < len(tmpList); idx++ {
  587. service.GetRedis().Del(tmpList[idx])
  588. }
  589. }
  590. // rolemail
  591. func convertRoleMailOldRedis(uid uint64) {
  592. uidStr := strconv.FormatUint(uid, 10)
  593. keyStr := model2.RoleMailDataPrefix + uidStr
  594. //1.个人身上的全局邮件ID重置
  595. service.GetRedis().HDel(keyStr, "gMaxId")
  596. }
  597. func convertRoleMailOldCommonRedis() {
  598. //1.删除全局邮件
  599. service.GetRedis().Del(model2.RoleGlobalMailListPrefix) //列表
  600. service.GetRedis().Del(model2.RoleGlobalMailPrefix)
  601. tmpList, _ := service.GetRedis().Keys(model2.RoleGlobalMailPrefix + "*").Result()
  602. for idx := 0; idx < len(tmpList); idx++ {
  603. service.GetRedis().Del(tmpList[idx])
  604. }
  605. }
  606. // rolemap
  607. func convertRoleMapOldRedis(uid uint64) {
  608. //uidStr := strconv.FormatUint(uid, 10)
  609. tmpRoleMap := &serverproto.RoleMap{}
  610. err := model2.GetSystemDataFromRedis(model2.RoleMapDataPrefix, uid, tmpRoleMap)
  611. if err != nil && err != service.NIL {
  612. util.InfoF("uid=%v [convertRoleMapOldRedis] RoleMap err=%v", uid, err)
  613. return
  614. }
  615. tmpRoleMap.WorldBossCount = 0
  616. tmpRoleMap.WorldBossChallengeList = []int32{}
  617. err = model2.SetSystemDataToRedis(model2.RoleMapDataPrefix, uid, tmpRoleMap)
  618. if err != nil {
  619. util.ErrorF("uid=%v [convertRoleMapOldRedis] save err=%v", uid, err)
  620. }
  621. }
  622. func convertRoleMapOldCommonRedis() {
  623. //重置世界boss数据
  624. //1.世界boss列表数据
  625. service.GetRedis().Del(model3.WorldBossStatePrefix)
  626. //2.挑战过世界boss的玩家列表
  627. tmpList, _ := service.GetRedis().Keys(model3.WorldBossStateUidListPrefix + "*").Result()
  628. for idx := 0; idx < len(tmpList); idx++ {
  629. service.GetRedis().Del(tmpList[idx])
  630. }
  631. }
  632. // rolerune
  633. func convertRoleRuneOldRedis(uid uint64) {
  634. uidStr := strconv.FormatUint(uid, 10)
  635. keyStr := model2.RoleRuneDataPrefix + uidStr
  636. valList, err := service.GetRedis().HGetAll(keyStr).Result()
  637. if err != nil {
  638. util.InfoF("uid=%v [convertRoleRuneOldRedis] err=%v", uid, err)
  639. return
  640. }
  641. //1.重置日礼包/周礼包/月礼包 购买限制
  642. //2.重置飞艇探索数据
  643. for k, v := range valList {
  644. if k == "runeBase" {
  645. //todo
  646. } else if k == "runeExplore" {
  647. service.GetRedis().HDel(keyStr, k)
  648. } else {
  649. shopData := &serverproto.RuneShop{}
  650. err = model.GetDecodeMessage(shopData, v)
  651. if err != nil {
  652. continue
  653. }
  654. //检查是否是日礼包/周礼包/月礼包 商品数据
  655. if shopData.ShopId == model4.Rune_Shop_Type_Bag {
  656. service.GetRedis().HDel(keyStr, k)
  657. }
  658. }
  659. }
  660. }
  661. // rolerush
  662. func convertRoleRushOldRedis(uid uint64) {
  663. //1.技能盛典个人数据清除
  664. uidStr := strconv.FormatUint(uid, 10)
  665. service.GetRedis().Del(model2.RoleRushDataPrefix + uidStr)
  666. //2.宠物盛典个人数据清除
  667. baseStr, err := service.GetRedis().HGet(model2.RolePetDataPrefix+uidStr, model2.RolePetDataFieldPrefix_base).Result()
  668. if err != nil {
  669. if err != service.NIL {
  670. util.InfoF("uid=%v [convertRoleRushOldRedis] pet err=%v", uid, err)
  671. }
  672. return
  673. }
  674. tmpRolePet := &serverproto.RolePet{}
  675. err = model.GetDecodeMessage(tmpRolePet, baseStr)
  676. if err == nil {
  677. tmpRolePet.RushPet = nil
  678. err1, msgData := model.GetEncodeMessage(tmpRolePet)
  679. if err1 == nil {
  680. service.GetRedis().HSet(model2.RolePetDataPrefix+uidStr,
  681. model2.RolePetDataFieldPrefix_base, msgData)
  682. }
  683. }
  684. //3.其他盛典个人数据在对应不同系统中做清除
  685. }
  686. func convertRoleRushOldCommonRedis() {
  687. //宠物盛典
  688. service.GetRedis().Del(model.RushPetScorePrefix)
  689. service.GetRedis().Del(model.RushPetPrefix)
  690. service.GetRedis().Del(model.RushPetRankPrefix)
  691. tmpList1, _ := service.GetRedis().Keys(model.RushPetRankPrefix + "*").Result()
  692. for idx := 0; idx < len(tmpList1); idx++ {
  693. service.GetRedis().Del(tmpList1[idx])
  694. }
  695. service.GetRedis().Del(model.RushPetDataPrefix)
  696. tmpList2, _ := service.GetRedis().Keys(model.RushPetDataPrefix + "*").Result()
  697. for idx := 0; idx < len(tmpList2); idx++ {
  698. service.GetRedis().Del(tmpList2[idx])
  699. }
  700. //技能盛典
  701. service.GetRedis().Del(model.RushSkillScorePrefix)
  702. service.GetRedis().Del(model.RushSkillPrefix)
  703. service.GetRedis().Del(model.RushSkillRankPrefix)
  704. tmpList3, _ := service.GetRedis().Keys(model.RushSkillRankPrefix + "*").Result()
  705. for idx := 0; idx < len(tmpList3); idx++ {
  706. service.GetRedis().Del(tmpList3[idx])
  707. }
  708. }
  709. // rolecross
  710. func convertRoleCrossOldRedisCommon() {
  711. //1.巅峰之塔
  712. service.GetRedis().Del(model5.CrossMaxFightPowerRankPrefix)
  713. service.GetRedis().Del(model5.CrossMaxFightPowerRankOldPrefix)
  714. service.GetRedis().Del(model5.TopTowerWinRankPrefix)
  715. service.GetRedis().Del(model5.FightInfoPrefix)
  716. service.GetRedis().Del(model5.CommonInfoPrefix)
  717. //2.远航试炼
  718. service.GetRedis().Del(model6.YuanHangTrialFightInfoPrefix)
  719. service.GetRedis().Del(model6.YuanHangTrialItemPrefix)
  720. service.GetRedis().Del(model6.YuanHangTrialRankPrefix)
  721. }
  722. // roletower
  723. func convertRoleTowerOldRedis(uid uint64) {
  724. //个人冲榜数据清除
  725. tmpRoleTower := &serverproto.RoleTower{}
  726. err := model2.GetSystemDataFromRedis(model2.RoleTowerDataPrefix, uid, tmpRoleTower)
  727. if err != nil && err != service.NIL {
  728. util.InfoF("uid=%v [convertRoleTowerOldRedis] err=%v", uid, err)
  729. return
  730. }
  731. tmpRoleTower.RushTower = nil
  732. err = model2.SetSystemDataToRedis(model2.RoleTowerDataPrefix, uid, tmpRoleTower)
  733. if err != nil {
  734. util.ErrorF("uid=%v [convertRoleTowerOldRedis] save err=%v", uid, err)
  735. }
  736. }
  737. // 1.12背包数据删除(背包内的活动数据)
  738. func convertRoleBagOldRedis(uid uint64) {
  739. tmpRoleBag := &serverproto.RoleBag{}
  740. err := model2.GetSystemDataFromRedis(model2.RoleBagDataPrefix, uid, tmpRoleBag)
  741. if err != nil && err != service.NIL {
  742. util.ErrorF("uid=%v del bag activity itemlist err=%v", uid, err)
  743. return
  744. }
  745. bSave := false
  746. var newItemList []*serverproto.ItemData
  747. for idx := 0; idx < len(tmpRoleBag.ItemList); idx++ {
  748. tmpItem := tmpRoleBag.ItemList[idx]
  749. cfgData := model4.GetItemCfg(tmpItem.ConfigId)
  750. if cfgData == nil {
  751. bSave = true
  752. continue
  753. }
  754. //删除活动类型道具
  755. if cfgData.ItemTime == model4.Item_Time_Type_Competition_2 ||
  756. cfgData.ItemTime == model4.Item_Time_Type_Competition_4 ||
  757. cfgData.ItemTime == model4.Item_Time_Type_Activities ||
  758. cfgData.ItemTime == model4.Item_Time_Type_Likability {
  759. bSave = true
  760. continue
  761. }
  762. newItemList = append(newItemList, tmpItem)
  763. }
  764. if bSave {
  765. tmpRoleBag.ItemList = newItemList
  766. err = model2.SetSystemDataToRedis(model2.RoleBagDataPrefix, uid, tmpRoleBag)
  767. if err != nil {
  768. util.ErrorF("uid=%v save bag item list err=%v", uid, err)
  769. }
  770. }
  771. }
  772. func convertRoleTowerOldCommonRedis() {
  773. //试炼盛典-爬塔数据清除
  774. service.GetRedis().Del(model.RushTowerPrefix)
  775. service.GetRedis().Del(model.RushTowerRankPrefix)
  776. tmpList, _ := service.GetRedis().Keys(model.RushTowerRankPrefix + "*").Result()
  777. for idx := 0; idx < len(tmpList); idx++ {
  778. service.GetRedis().Del(tmpList[idx])
  779. }
  780. //爬塔排行榜清除
  781. //service.GetRedis().Del(model.TowerLevelRankPrefix) 合并数据后数据自动重排
  782. service.GetRedis().Del(model.TowerFightpowerRankPrefix)
  783. }
  784. func mergeDbIntoFirst(redisIpStr string, sourceDB int, targetDB int) error {
  785. if sourceDB == targetDB {
  786. return nil
  787. }
  788. src := service.NewNetRedisConnector([]string{redisIpStr}, "", sourceDB, 0).RedisCli()
  789. dst := service.NewNetRedisConnector([]string{redisIpStr}, "", targetDB, 0).RedisCli()
  790. if src == nil || dst == nil {
  791. return fmt.Errorf("init redis connector failed sourceDB=%v targetDB=%v", sourceDB, targetDB)
  792. }
  793. keys, err := src.Keys("*").Result()
  794. if err != nil {
  795. return err
  796. }
  797. keyStr := "guild:recommendindex"
  798. for idx := 0; idx < len(keys); idx++ {
  799. key := keys[idx]
  800. //特殊公会列表数据处理
  801. if key == keyStr {
  802. //源区服工会列表
  803. ret, err := src.Get(keyStr).Result()
  804. if err != nil {
  805. if errors.Is(err, redis.Nil) {
  806. util.InfoF("key(%v) not exist in SrcDB, will copy directly", keyStr)
  807. continue
  808. }
  809. util.InfoF("LoadRecommendGuild get guildId key=%v err=%v\n", keyStr, err)
  810. return err
  811. }
  812. if ret == "" {
  813. util.InfoF("key(%v)->val empty", keyStr)
  814. return err
  815. }
  816. str, err := base64.StdEncoding.DecodeString(ret)
  817. if err != nil {
  818. util.InfoF("key(%v)->val DecodeString error", keyStr)
  819. return err
  820. }
  821. recommend := &serverproto.RecommendSet{}
  822. _ = rocommon.GetCodec().Unmarshal(str, recommend)
  823. //目标区服工会列表
  824. ret2, err := dst.Get(keyStr).Result()
  825. if err != nil {
  826. util.InfoF("LoadRecommendGuild get guildId key=%v err=%v\n", keyStr, err)
  827. return err
  828. }
  829. if ret2 == "" {
  830. util.InfoF("key(%v)->val empty", keyStr)
  831. return err
  832. }
  833. str2, err := base64.StdEncoding.DecodeString(ret2)
  834. if err != nil {
  835. util.InfoF("key(%v)->val DecodeString error", keyStr)
  836. return err
  837. }
  838. recommend2 := &serverproto.RecommendSet{}
  839. _ = rocommon.GetCodec().Unmarshal(str2, recommend2)
  840. recommend2.Guild = append(recommend2.Guild, recommend.Guild...)
  841. _, ss := model.GetEncodeMessage(recommend2)
  842. if e := dst.Set(keyStr, ss, 0).Err(); e != nil {
  843. util.ErrorF("key(%v)->val set error =%v", keyStr, e)
  844. return e
  845. }
  846. continue
  847. }
  848. srcType, err := src.Type(key).Result()
  849. if err != nil {
  850. util.ErrorF("type err sourceDB=%v key=%v err=%v", sourceDB, key, err)
  851. continue
  852. }
  853. srcTTL := int64(-1)
  854. if ttlDur, e := src.PTTL(key).Result(); e == nil {
  855. srcTTL = int64(ttlDur / time.Millisecond)
  856. }
  857. dstType, err := dst.Type(key).Result()
  858. if err != nil {
  859. util.ErrorF("dst type err targetDB=%v key=%v err=%v", targetDB, key, err)
  860. continue
  861. }
  862. if dstType == "none" || dstType == srcType {
  863. switch srcType {
  864. case "hash":
  865. srcMap, e := src.HGetAll(key).Result()
  866. if e != nil {
  867. util.ErrorF("hgetall err sourceDB=%v key=%v err=%v", sourceDB, key, e)
  868. continue
  869. }
  870. for field, val := range srcMap {
  871. if e = dst.HSet(key, field, val).Err(); e != nil {
  872. util.ErrorF("hset merge err targetDB=%v key=%v field=%v err=%v", targetDB, key, field, e)
  873. }
  874. }
  875. case "set":
  876. members, e := src.SMembers(key).Result()
  877. if e != nil {
  878. util.ErrorF("smembers err sourceDB=%v key=%v err=%v", sourceDB, key, e)
  879. continue
  880. }
  881. if len(members) > 0 {
  882. args := make([]interface{}, 0, len(members)+1)
  883. //args = append(args, key)
  884. for _, m := range members {
  885. args = append(args, m)
  886. }
  887. if e = dst.SAdd(key, args...).Err(); e != nil {
  888. util.ErrorF("sadd merge err targetDB=%v key=%v err=%v", targetDB, key, e)
  889. }
  890. }
  891. case "zset":
  892. zitems, e := src.ZRangeWithScores(key, 0, -1).Result()
  893. if e != nil {
  894. util.ErrorF("zrange withscores err sourceDB=%v key=%v err=%v", sourceDB, key, e)
  895. continue
  896. }
  897. for _, z := range zitems {
  898. if e = dst.ZAdd(key, z).Err(); e != nil {
  899. util.ErrorF("zadd merge err targetDB=%v key=%v member=%v err=%v", targetDB, key, z.Member, e)
  900. }
  901. }
  902. case "list":
  903. items, e := src.LRange(key, 0, -1).Result()
  904. if e != nil {
  905. util.ErrorF("lrange err sourceDB=%v key=%v err=%v", sourceDB, key, e)
  906. continue
  907. }
  908. if len(items) > 0 {
  909. args := make([]interface{}, 0, len(items)+1)
  910. //args = append(args, key)
  911. for _, it := range items {
  912. args = append(args, it)
  913. }
  914. if e = dst.RPush(key, args...).Err(); e != nil {
  915. util.ErrorF("rpush merge err targetDB=%v key=%v err=%v", targetDB, key, e)
  916. }
  917. }
  918. default:
  919. if srcType == "string" {
  920. val, e := src.Get(key).Result()
  921. if e != nil {
  922. util.ErrorF("get err sourceDB=%v key=%v err=%v", sourceDB, key, e)
  923. continue
  924. }
  925. if e = dst.Set(key, val, 0).Err(); e != nil {
  926. util.ErrorF("set err targetDB=%v key=%v err=%v", targetDB, key, e)
  927. }
  928. } else {
  929. util.ErrorF("set err targetDB=%v key=%v type unkowne", targetDB, key)
  930. }
  931. }
  932. if srcTTL > 0 {
  933. _ = dst.PExpire(key, time.Duration(srcTTL)*time.Millisecond).Err()
  934. }
  935. } else {
  936. dumpData := src.Dump(key).String()
  937. //if e != nil {
  938. // util.ErrorF("dump mismatch err sourceDB=%v key=%v err=%v", sourceDB, key, e)
  939. // continue
  940. //}
  941. dstKey := fmt.Sprintf("%s__m%d", key, sourceDB)
  942. restoreTTL := time.Duration(0)
  943. if srcTTL > 0 {
  944. restoreTTL = time.Duration(srcTTL) * time.Millisecond
  945. }
  946. if e := dst.RestoreReplace(dstKey, restoreTTL, dumpData).Err(); e != nil {
  947. util.ErrorF("restore mismatch err sourceDB=%v targetDB=%v key=%v dst=%v err=%v", sourceDB, targetDB, key, dstKey, e)
  948. }
  949. }
  950. }
  951. return nil
  952. }
  953. /*
  954. 注意:下面操作需要在同一个redis版本中操作,即需要在外网使用的redis版本下进行操作
  955. 新增同实例多DB模式(方案B):
  956. test.exe -ip 127.0.0.1:6379 -dbs 0,1,2
  957. 1.-ip 传完整redis地址(含端口)
  958. 2.-dbs 传要处理的db索引列表,逗号分隔
  959. 1.获取外网rdb文件,并重新修改启动该rdb文件的redis*.conf文件
  960. 修改conf文件如下:
  961. 1.在675行添加(表示生成的aof文件中不包行rdb文件,只有aof格式文件内容):aof-use-rdb-preamble no
  962. 2.port修改成当前外网的redis*.conf文件一致
  963. 3.appendfilename修改成appendonly[端口号].aof,appendonly7001.aof
  964. 4.修改appendonly为no(关闭appendonly,为了启动redis时直接读取rdb文件)
  965. 2.第1步的修改完成后,按照外网的方式利用获取到的外网rdb启动(需改后的redis*.conf文件和对应的rdb文件)
  966. 3.用命令行启动合服处理进程,格式如下:
  967. test.exe -ip 127.0.0.1 -diff 7001,7002,7003
  968. 1.test.exe为合服处理进程(负责清空redis中需要清空的数据)
  969. 2.-ip为第2步中redis启动时监听的ip地址
  970. 3.-diff为redis启动时坚挺的端口,多个端口中间用逗号隔开,例如:7001,7002,7003
  971. 4.合并第3步操作后生成的appendonly[端口号].aof文件,如下:
  972. cat appendonly7001.aof appendonly7002.aof appendonly7003.aof > new.aof
  973. 5.第4步生成的new.aof文件就是合服后的数据,需要转换成rdb文件
  974. 获取1步骤的redis*.conf文件修改如下:
  975. 1.appendonly修改为yes
  976. 2.删除之前添加的aof-use-rdb-preamble no
  977. 3.appendfilename修改成new.aof
  978. 4.启动端口修改成没有使用过的端口,例如6379
  979. 6.利用第4不生成的new.aof文件和第5不修改后的redis*.conf文件启动一个新的redis进程,并执行redis命令bgsave(或
  980. 者等待一段时间会自动生成对应的rdb文件),查看目录下是否生成dump.rdb文件,如果生成说明合服数据库已经成功生成
  981. 7.第6不生成的rdb文件即为合服后的数据库,把该rdb文件copy到外网然后根据外网的配置启动即可
  982. */