cache.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. package customcache
  2. import (
  3. "sync"
  4. "time"
  5. )
  6. var LabCache *MlabCache
  7. var duration int = 10
  8. type MlabCache struct {
  9. Cache map[string]map[string]float64
  10. Mux sync.Mutex
  11. Timeout *time.Ticker
  12. }
  13. func init() {
  14. LabCache = &MlabCache{
  15. Cache: map[string]map[string]float64{
  16. "kube-01": map[string]float64{
  17. "ipc": -1,
  18. "mem_read": -1,
  19. "mem_write": -1,
  20. "c6res": -1,
  21. },
  22. "kube-02": map[string]float64{
  23. "ipc": -1,
  24. "mem_read": -1,
  25. "mem_write": -1,
  26. "c6res": -1,
  27. },
  28. "kube-03": map[string]float64{
  29. "ipc": -1,
  30. "mem_read": -1,
  31. "mem_write": -1,
  32. "c6res": -1,
  33. },
  34. "kube-04": map[string]float64{
  35. "ipc": -1,
  36. "mem_read": -1,
  37. "mem_write": -1,
  38. "c6res": -1,
  39. },
  40. "kube-05": map[string]float64{
  41. "ipc": -1,
  42. "mem_read": -1,
  43. "mem_write": -1,
  44. "c6res": -1,
  45. },
  46. "kube-06": map[string]float64{
  47. "ipc": -1,
  48. "mem_read": -1,
  49. "mem_write": -1,
  50. "c6res": -1,
  51. },
  52. "kube-07": map[string]float64{
  53. "ipc": -1,
  54. "mem_read": -1,
  55. "mem_write": -1,
  56. "c6res": -1,
  57. },
  58. "kube-08": map[string]float64{
  59. "ipc": -1,
  60. "mem_read": -1,
  61. "mem_write": -1,
  62. "c6res": -1,
  63. },
  64. },
  65. }
  66. LabCache.Timeout = time.NewTicker(time.Duration(10) * time.Second)
  67. }
  68. // func New() {
  69. // }
  70. // var Τimeout *time.Ticker
  71. func (c *MlabCache) CleanCache() {
  72. c.Mux.Lock()
  73. c.Cache = map[string]map[string]float64{
  74. "kube-01": map[string]float64{
  75. "ipc": -1,
  76. "mem_read": -1,
  77. "mem_write": -1,
  78. "c6res": -1,
  79. },
  80. "kube-02": map[string]float64{
  81. "ipc": -1,
  82. "mem_read": -1,
  83. "mem_write": -1,
  84. "c6res": -1,
  85. },
  86. "kube-03": map[string]float64{
  87. "ipc": -1,
  88. "mem_read": -1,
  89. "mem_write": -1,
  90. "c6res": -1,
  91. },
  92. "kube-04": map[string]float64{
  93. "ipc": -1,
  94. "mem_read": -1,
  95. "mem_write": -1,
  96. "c6res": -1,
  97. },
  98. "kube-05": map[string]float64{
  99. "ipc": -1,
  100. "mem_read": -1,
  101. "mem_write": -1,
  102. "c6res": -1,
  103. },
  104. "kube-06": map[string]float64{
  105. "ipc": -1,
  106. "mem_read": -1,
  107. "mem_write": -1,
  108. "c6res": -1,
  109. },
  110. "kube-07": map[string]float64{
  111. "ipc": -1,
  112. "mem_read": -1,
  113. "mem_write": -1,
  114. "c6res": -1,
  115. },
  116. "kube-08": map[string]float64{
  117. "ipc": -1,
  118. "mem_read": -1,
  119. "mem_write": -1,
  120. "c6res": -1,
  121. },
  122. }
  123. //c.Timeout.Stop()
  124. //Timeout := time.NewTicker(time.Duration(10 * time.Second))
  125. c.Mux.Unlock()
  126. }
  127. func (c *MlabCache) UpdateCache(input map[string]float64, c6res float64, nodename string) error {
  128. c.Mux.Lock()
  129. c.Cache[nodename] = map[string]float64{
  130. "ipc": input["ipc"],
  131. "mem_read": input["mem_read"],
  132. "mem_write": input["mem_write"],
  133. "c6res": c6res,
  134. }
  135. // Reset the ticker
  136. c.Timeout = time.NewTicker(time.Duration(duration) * time.Second)
  137. //klog.Infof("Reset the Ticker")
  138. c.Mux.Unlock()
  139. //klog.Infof("After cache update")
  140. c.printCached(nodename)
  141. return nil
  142. }
  143. func (c *MlabCache) AddAppMetrics(app map[string]float64, nodename string, numCores int) {
  144. c.Mux.Lock()
  145. c.Cache[nodename]["mem_read"] += app["mem_read"]
  146. c.Cache[nodename]["mem_write"] += app["mem_write"]
  147. //TODO
  148. // handle c6res addition
  149. c.Cache[nodename]["c6res"] -= (1 - app["c6res"]) / float64(100*numCores)
  150. if c.Cache[nodename]["c6res"] <= 0 {
  151. c.Cache[nodename]["c6res"] = 0.00000001
  152. }
  153. //TODO
  154. // handle ipc addition
  155. c.Mux.Unlock()
  156. //klog.Infof("After application metrics addition")
  157. c.printCached(nodename)
  158. }
  159. func (c *MlabCache) printCached(nodename string) {
  160. //klog.Infof("IPC: %v, Reads: %v, Writes: %v, C6res: %v", c.Cache[nodename]["ipc"], c.Cache[nodename]["mem_read"],
  161. //c.Cache[nodename]["mem_write"], c.Cache[nodename]["c6res"])
  162. }