cache.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  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. // var Τimeout *time.Ticker
  69. func (c *MlabCache) CleanCache() {
  70. c.Mux.Lock()
  71. c.Cache = map[string]map[string]float64{
  72. "kube-01": map[string]float64{
  73. "ipc": -1,
  74. "mem_read": -1,
  75. "mem_write": -1,
  76. "c6res": -1,
  77. },
  78. "kube-02": map[string]float64{
  79. "ipc": -1,
  80. "mem_read": -1,
  81. "mem_write": -1,
  82. "c6res": -1,
  83. },
  84. "kube-03": map[string]float64{
  85. "ipc": -1,
  86. "mem_read": -1,
  87. "mem_write": -1,
  88. "c6res": -1,
  89. },
  90. "kube-04": map[string]float64{
  91. "ipc": -1,
  92. "mem_read": -1,
  93. "mem_write": -1,
  94. "c6res": -1,
  95. },
  96. "kube-05": map[string]float64{
  97. "ipc": -1,
  98. "mem_read": -1,
  99. "mem_write": -1,
  100. "c6res": -1,
  101. },
  102. "kube-06": map[string]float64{
  103. "ipc": -1,
  104. "mem_read": -1,
  105. "mem_write": -1,
  106. "c6res": -1,
  107. },
  108. "kube-07": map[string]float64{
  109. "ipc": -1,
  110. "mem_read": -1,
  111. "mem_write": -1,
  112. "c6res": -1,
  113. },
  114. "kube-08": map[string]float64{
  115. "ipc": -1,
  116. "mem_read": -1,
  117. "mem_write": -1,
  118. "c6res": -1,
  119. },
  120. }
  121. //c.Timeout.Stop()
  122. //Timeout := time.NewTicker(time.Duration(10 * time.Second))
  123. c.Mux.Unlock()
  124. }
  125. func (c *MlabCache) UpdateCache(input map[string]float64, c6res float64, nodename string) error {
  126. c.Mux.Lock()
  127. c.Cache[nodename] = map[string]float64{
  128. "ipc": input["ipc"],
  129. "mem_read": input["mem_read"],
  130. "mem_write": input["mem_write"],
  131. "c6res": c6res,
  132. }
  133. // Reset the ticker
  134. c.Timeout = *time.NewTicker(time.Duration(duration) * time.Second)
  135. //klog.Infof("Reset the Ticker")
  136. c.Mux.Unlock()
  137. //klog.Infof("After cache update")
  138. c.printCached(nodename)
  139. return nil
  140. }
  141. func (c *MlabCache) AddAppMetrics(app map[string]float64, nodename string, numCores int) {
  142. c.Mux.Lock()
  143. c.Cache[nodename]["mem_read"] += app["mem_read"]
  144. c.Cache[nodename]["mem_write"] += app["mem_write"]
  145. //TODO
  146. // handle c6res addition
  147. c.Cache[nodename]["c6res"] -= (1 - app["c6res"]) / float64(100*numCores)
  148. if c.Cache[nodename]["c6res"] <= 0 {
  149. c.Cache[nodename]["c6res"] = 0.00000001
  150. }
  151. //TODO
  152. // handle ipc addition
  153. c.Mux.Unlock()
  154. //klog.Infof("After application metrics addition")
  155. c.printCached(nodename)
  156. }
  157. func (c *MlabCache) printCached(nodename string) {
  158. //klog.Infof("IPC: %v, Reads: %v, Writes: %v, C6res: %v", c.Cache[nodename]["ipc"], c.Cache[nodename]["mem_read"],
  159. //c.Cache[nodename]["mem_write"], c.Cache[nodename]["c6res"])
  160. }