You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

214 lines
6.2 KiB

10 years ago
10 years ago
10 years ago
10 years ago
6 years ago
5 years ago
5 years ago
10 years ago
10 years ago
10 years ago
  1. package master_ui
  2. import (
  3. "fmt"
  4. "github.com/chrislusf/seaweedfs/weed/util"
  5. "html/template"
  6. "strconv"
  7. "strings"
  8. )
  9. func percentFrom(total uint64, part_of uint64) string {
  10. return fmt.Sprintf("%.2f", (float64(part_of)/float64(total))*100)
  11. }
  12. func join(data []int64) string {
  13. var ret []string
  14. for _, d := range data {
  15. ret = append(ret, strconv.Itoa(int(d)))
  16. }
  17. return strings.Join(ret, ",")
  18. }
  19. var funcMap = template.FuncMap{
  20. "join": join,
  21. "bytesToHumanReadable": util.BytesToHumanReadable,
  22. "percentFrom": percentFrom,
  23. }
  24. var StatusTpl = template.Must(template.New("status").Funcs(funcMap).Parse(`<!DOCTYPE html>
  25. <html>
  26. <head>
  27. <title>SeaweedFS {{ .Version }}</title>
  28. <link rel="stylesheet" href="/seaweedfsstatic/bootstrap/3.3.1/css/bootstrap.min.css">
  29. <script type="text/javascript" src="/seaweedfsstatic/javascript/jquery-2.1.3.min.js"></script>
  30. <script type="text/javascript" src="/seaweedfsstatic/javascript/jquery-sparklines/2.1.2/jquery.sparkline.min.js"></script>
  31. <script type="text/javascript">
  32. $(function() {
  33. var periods = ['second', 'minute', 'hour', 'day'];
  34. for (i = 0; i < periods.length; i++) {
  35. var period = periods[i];
  36. $('.inlinesparkline-'+period).sparkline('html', {
  37. type: 'line',
  38. barColor: 'red',
  39. tooltipSuffix:' request per '+period,
  40. });
  41. }
  42. });
  43. </script>
  44. <style>
  45. #jqstooltip{
  46. height: 28px !important;
  47. width: 150px !important;
  48. }
  49. </style>
  50. </head>
  51. <body>
  52. <div class="container">
  53. <div class="page-header">
  54. <h1>
  55. <a href="https://github.com/chrislusf/seaweedfs"><img src="/seaweedfsstatic/seaweed50x50.png"></img></a>
  56. SeaweedFS <small>{{ .Version }}</small>
  57. </h1>
  58. </div>
  59. <div class="row">
  60. <div class="col-sm-6">
  61. <h2>Disk Stats</h2>
  62. <table class="table table-striped">
  63. <thead>
  64. <tr>
  65. <th>Path</th>
  66. <th>Type</th>
  67. <th>Total</th>
  68. <th>Free</th>
  69. <th>Usage</th>
  70. </tr>
  71. </thead>
  72. <tbody>
  73. {{ range .DiskStatuses }}
  74. <tr>
  75. <td>{{ .Dir }}</td>
  76. <td>{{ .DiskType }}</td>
  77. <td>{{ bytesToHumanReadable .All }}</td>
  78. <td>{{ bytesToHumanReadable .Free }}</td>
  79. <td>{{ percentFrom .All .Used}}%</td>
  80. </tr>
  81. {{ end }}
  82. </tbody>
  83. </table>
  84. </div>
  85. <div class="col-sm-6">
  86. <h2>System Stats</h2>
  87. <table class="table table-condensed table-striped">
  88. <tr>
  89. <th>Masters</th>
  90. <td>{{.Masters}}</td>
  91. </tr>
  92. <tr>
  93. <th>Weekly # ReadRequests</th>
  94. <td><span class="inlinesparkline-day">{{ .Counters.ReadRequests.WeekCounter.ToList | join }}</span></td>
  95. </tr>
  96. <tr>
  97. <th>Daily # ReadRequests</th>
  98. <td><span class="inlinesparkline-hour">{{ .Counters.ReadRequests.DayCounter.ToList | join }}</span></td>
  99. </tr>
  100. <tr>
  101. <th>Hourly # ReadRequests</th>
  102. <td><span class="inlinesparkline-minute">{{ .Counters.ReadRequests.HourCounter.ToList | join }}</span></td>
  103. </tr>
  104. <tr>
  105. <th>Last Minute # ReadRequests</th>
  106. <td><span class="inlinesparkline-second">{{ .Counters.ReadRequests.MinuteCounter.ToList | join }}</span></td>
  107. </tr>
  108. {{ range $key, $val := .Stats }}
  109. <tr>
  110. <th>{{ $key }}</th>
  111. <td>{{ $val }}</td>
  112. </tr>
  113. {{ end }}
  114. </table>
  115. </div>
  116. </div>
  117. <div class="row">
  118. <h2>Volumes</h2>
  119. <table class="table table-striped">
  120. <thead>
  121. <tr>
  122. <th>Id</th>
  123. <th>Collection</th>
  124. <th>Data Size</th>
  125. <th>Files</th>
  126. <th>Trash</th>
  127. <th>TTL</th>
  128. <th>ReadOnly</th>
  129. </tr>
  130. </thead>
  131. <tbody>
  132. {{ range .Volumes }}
  133. <tr>
  134. <td><code>{{ .Id }}</code></td>
  135. <td>{{ .Collection }}</td>
  136. <td>{{ bytesToHumanReadable .Size }}</td>
  137. <td>{{ .FileCount }}</td>
  138. <td>{{ .DeleteCount }} / {{bytesToHumanReadable .DeletedByteCount}}</td>
  139. <td>{{ .Ttl }}</td>
  140. <td>{{ .ReadOnly }}</td>
  141. </tr>
  142. {{ end }}
  143. </tbody>
  144. </table>
  145. </div>
  146. <div class="row">
  147. <h2>Remote Volumes</h2>
  148. <table class="table table-striped">
  149. <thead>
  150. <tr>
  151. <th>Id</th>
  152. <th>Collection</th>
  153. <th>Size</th>
  154. <th>Files</th>
  155. <th>Trash</th>
  156. <th>Remote</th>
  157. <th>Key</th>
  158. </tr>
  159. </thead>
  160. <tbody>
  161. {{ range .RemoteVolumes }}
  162. <tr>
  163. <td><code>{{ .Id }}</code></td>
  164. <td>{{ .Collection }}</td>
  165. <td>{{ bytesToHumanReadable .Size }}</td>
  166. <td>{{ .FileCount }}</td>
  167. <td>{{ .DeleteCount }} / {{bytesToHumanReadable .DeletedByteCount}}</td>
  168. <td>{{ .RemoteStorageName }}</td>
  169. <td>{{ .RemoteStorageKey }}</td>
  170. </tr>
  171. {{ end }}
  172. </tbody>
  173. </table>
  174. </div>
  175. <div class="row">
  176. <h2>Erasure Coding Shards</h2>
  177. <table class="table table-striped">
  178. <thead>
  179. <tr>
  180. <th>Id</th>
  181. <th>Collection</th>
  182. <th>Shard Size</th>
  183. <th>Shards</th>
  184. <th>CreatedAt</th>
  185. </tr>
  186. </thead>
  187. <tbody>
  188. {{ range .EcVolumes }}
  189. <tr>
  190. <td><code>{{ .VolumeId }}</code></td>
  191. <td>{{ .Collection }}</td>
  192. <td>{{ bytesToHumanReadable .ShardSize }}</td>
  193. <td>{{ .ShardIdList }}</td>
  194. <td>{{ .CreatedAt.Format "02 Jan 06 15:04 -0700" }}</td>
  195. </tr>
  196. {{ end }}
  197. </tbody>
  198. </table>
  199. </div>
  200. </div>
  201. </body>
  202. </html>
  203. `))