index.html 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740
  1. <div class="wrapper wrapper-content">
  2. <div class="row">
  3. <div class="col-lg-3">
  4. <div class="ibox float-e-margins">
  5. <div class="ibox-title">
  6. <h5 langtag="word-connectionport"></h5>
  7. </div>
  8. <div class="ibox-content">
  9. <h1 class="no-margins">{{.p}}</h1>
  10. </div>
  11. </div>
  12. </div>
  13. <div class="col-lg-3">
  14. <div class="ibox float-e-margins">
  15. <div class="ibox-title">
  16. <h5 langtag="word-totalclients"></h5>
  17. </div>
  18. <div class="ibox-content">
  19. <h1 class="no-margins">{{.data.clientCount}}</h1>
  20. </div>
  21. </div>
  22. </div>
  23. <div class="col-lg-3">
  24. <div class="ibox float-e-margins">
  25. <div class="ibox-title">
  26. {{/*<span class="label label-primary pull-right">今日</span>*/}}
  27. <h5 langtag="word-onlineclients"></h5>
  28. </div>
  29. <div class="ibox-content">
  30. <h1 class="no-margins">{{.data.clientOnlineCount}}</h1>
  31. {{/*<div class="stat-percent font-bold text-navy">44% <i class="fa fa-level-up"></i></div>*/}}
  32. {{/*<small>新访客</small>*/}}
  33. </div>
  34. </div>
  35. </div>
  36. <div class="col-lg-3">
  37. <div class="ibox float-e-margins">
  38. <div class="ibox-title">
  39. <h5 langtag="word-tcpconnections"></h5>
  40. </div>
  41. <div class="ibox-content">
  42. <h1 class="no-margins">{{.data.tcpCount}}</h1>
  43. </div>
  44. </div>
  45. </div>
  46. </div>
  47. <div class="row">
  48. <div class="col-lg-6">
  49. <div class="ibox float-e-margins">
  50. <div class="ibox-title">
  51. <h5 langtag="word-configurationinformation"></h5>
  52. <div class="ibox-tools">
  53. <a class="collapse-link">
  54. <i class="fa fa-chevron-up"></i>
  55. </a>
  56. <a class="close-link">
  57. <i class="fa fa-times"></i>
  58. </a>
  59. </div>
  60. </div>
  61. <div class="ibox-content no-padding">
  62. <ul class="list-group">
  63. <li class="list-group-item">
  64. <div class="row">
  65. <div class="col-sm-6">
  66. <strong langtag="word-bridgingmode"></strong>
  67. </div>
  68. <div class="col-sm-6 text-right">
  69. <strong>{{.data.bridgeType}}</strong>
  70. </div>
  71. </div>
  72. </li>
  73. <li class="list-group-item">
  74. <div class="row">
  75. <div class="col-sm-6">
  76. <strong langtag="word-httpport"></strong>
  77. </div>
  78. <div class="col-sm-6 text-right">
  79. <strong>{{.data.httpProxyPort}}</strong>
  80. </div>
  81. </div>
  82. </li>
  83. <li class="list-group-item">
  84. <div class="row">
  85. <div class="col-sm-6">
  86. <strong langtag="word-httpsport"></strong>
  87. </div>
  88. <div class="col-sm-6 text-right">
  89. <strong>{{.data.httpsProxyPort}}</strong>
  90. </div>
  91. </div>
  92. </li>
  93. <li class="list-group-item ">
  94. <div class="row">
  95. <div class="col-sm-6">
  96. <strong langtag="word-iprestriction"></strong>
  97. </div>
  98. <div class="col-sm-6 text-right">
  99. <strong langtag="word-{{.data.ipLimit}}"></strong>
  100. </div>
  101. </div>
  102. </li>
  103. <li class="list-group-item ">
  104. <div class="row">
  105. <div class="col-sm-6">
  106. <strong langtag="word-trafficdatapersistence"></strong>
  107. </div>
  108. <div class="col-sm-6 text-right">
  109. <strong>{{.data.flowStoreInterval}}</strong>
  110. </div>
  111. </div>
  112. </li>
  113. <li class="list-group-item ">
  114. <div class="row">
  115. <div class="col-sm-6">
  116. <strong langtag="word-loglevel"></strong>
  117. </div>
  118. <div class="col-sm-6 text-right">
  119. <strong>{{.data.logLevel}}</strong>
  120. </div>
  121. </div>
  122. </li>
  123. <li class="list-group-item ">
  124. <div class="row">
  125. <div class="col-sm-6">
  126. <strong langtag="word-p2pport"></strong>
  127. </div>
  128. <div class="col-sm-6 text-right">
  129. <strong>{{.data.p2pPort}}</strong>
  130. </div>
  131. </div>
  132. </li>
  133. <li class="list-group-item ">
  134. <div class="row">
  135. <div class="col-sm-6">
  136. <strong langtag="word-serveriP"></strong>
  137. </div>
  138. <div class="col-sm-6 text-right">
  139. <strong>{{.data.serverIp}}</strong>
  140. </div>
  141. </div>
  142. </li>
  143. <li class="list-group-item ">
  144. <div class="row">
  145. <div class="col-sm-6">
  146. <strong langtag="word-serverversion"></strong>
  147. </div>
  148. <div class="col-sm-6 text-right">
  149. <strong>{{.data.version}}</strong>
  150. </div>
  151. </div>
  152. </li>
  153. </ul>
  154. </div>
  155. </div>
  156. </div>
  157. <div class="col-lg-6">
  158. <div class="ibox float-e-margins">
  159. <div class="ibox-title">
  160. <h5 langtag="word-systeminformation"></h5>
  161. <div class="ibox-tools">
  162. <a class="collapse-link">
  163. <i class="fa fa-chevron-up"></i>
  164. </a>
  165. <a class="close-link">
  166. <i class="fa fa-times"></i>
  167. </a>
  168. </div>
  169. </div>
  170. <div class="ibox-content no-padding">
  171. <ul class="list-group">
  172. <li class="list-group-item">
  173. <div class="row">
  174. <div class="col-sm-6">
  175. <strong langtag="word-cpu"></strong>
  176. </div>
  177. <div class="col-sm-6 text-right">
  178. <strong id="overview_cpu"></strong>
  179. </div>
  180. </div>
  181. <div class="progress progress-small">
  182. <div id="overview_cpu_bar" class="progress-bar"></div>
  183. </div>
  184. </li>
  185. <li class="list-group-item">
  186. <div class="row">
  187. <div class="col-sm-6">
  188. <strong langtag="word-memory"></strong>
  189. </div>
  190. <div class="col-sm-6 text-right">
  191. <strong id="overview_memory"></strong>
  192. </div>
  193. </div>
  194. <div class="progress progress-small">
  195. <div id="overview_memory_bar" class="progress-bar"></div>
  196. </div>
  197. </li>
  198. <li class="list-group-item">
  199. <div class="row">
  200. <div class="col-sm-6">
  201. <strong langtag="word-load"></strong>
  202. </div>
  203. <div class="col-sm-6 text-right">
  204. <strong id="overview_load"></strong>
  205. </div>
  206. </div>
  207. </li>
  208. <li class="list-group-item ">
  209. <div class="row">
  210. <div class="col-sm-6">
  211. <strong langtag="word-tcpconnections_established"></strong>
  212. </div>
  213. <div class="col-sm-6 text-right">
  214. <strong id="overview_tcp"></strong>
  215. </div>
  216. </div>
  217. </li>
  218. <li class="list-group-item ">
  219. <div class="row">
  220. <div class="col-sm-6">
  221. <strong langtag="word-udpconnections_established"></strong>
  222. </div>
  223. <div class="col-sm-6 text-right">
  224. <strong id="overview_udp"></strong>
  225. </div>
  226. </div>
  227. </li>
  228. <li class="list-group-item ">
  229. <div class="row">
  230. <div class="col-sm-6">
  231. <strong langtag="word-outbandwidth"></strong>
  232. </div>
  233. <div class="col-sm-6 text-right">
  234. <strong id="overview_send"></strong>
  235. </div>
  236. </div>
  237. </li>
  238. <li class="list-group-item ">
  239. <div class="row">
  240. <div class="col-sm-6">
  241. <strong langtag="word-inbandwidth"></strong>
  242. </div>
  243. <div class="col-sm-6 text-right">
  244. <strong id="overview_recv"></strong>
  245. </div>
  246. </div>
  247. </li>
  248. </ul>
  249. </div>
  250. </div>
  251. </div>
  252. </div>
  253. {{if eq true .system_info_display}}
  254. <div class="row">
  255. <div class="col-lg-6">
  256. <div class="ibox float-e-margins">
  257. <div class="ibox-title">
  258. <h5 langtag="word-load"></h5>
  259. <div class="ibox-tools">
  260. <a class="collapse-link">
  261. <i class="fa fa-chevron-up"></i>
  262. </a>
  263. <a class="close-link">
  264. <i class="fa fa-times"></i>
  265. </a>
  266. </div>
  267. </div>
  268. <div class="ibox-content">
  269. <div id="load" style="height: 300px"></div>
  270. </div>
  271. </div>
  272. </div>
  273. <div class="col-lg-6">
  274. <div class="ibox float-e-margins">
  275. <div class="ibox-title">
  276. <h5 langtag="word-cpu"></h5>
  277. <div class="ibox-tools">
  278. <a class="collapse-link">
  279. <i class="fa fa-chevron-up"></i>
  280. </a>
  281. <a class="close-link">
  282. <i class="fa fa-times"></i>
  283. </a>
  284. </div>
  285. </div>
  286. <div class="ibox-content">
  287. <div id="cpu" style="height: 300px"></div>
  288. </div>
  289. </div>
  290. </div>
  291. </div>
  292. <div class="row">
  293. <div class="col-lg-6">
  294. <div class="ibox float-e-margins">
  295. <div class="ibox-title">
  296. <h5 langtag="word-memory"></h5>
  297. <div class="ibox-tools">
  298. <a class="collapse-link">
  299. <i class="fa fa-chevron-up"></i>
  300. </a>
  301. <a class="close-link">
  302. <i class="fa fa-times"></i>
  303. </a>
  304. </div>
  305. </div>
  306. <div class="ibox-content">
  307. <div id="memory" style="height: 300px"></div>
  308. </div>
  309. </div>
  310. </div>
  311. <div class="col-lg-6">
  312. <div class="ibox float-e-margins">
  313. <div class="ibox-title">
  314. <h5 langtag="word-connections_established"></h5>
  315. <div class="ibox-tools">
  316. <a class="collapse-link">
  317. <i class="fa fa-chevron-up"></i>
  318. </a>
  319. <a class="close-link">
  320. <i class="fa fa-times"></i>
  321. </a>
  322. </div>
  323. </div>
  324. <div class="ibox-content">
  325. <div id="connections" style="height: 300px"></div>
  326. </div>
  327. </div>
  328. </div>
  329. </div>
  330. <div class="row">
  331. <div class="col-lg-12">
  332. <div class="ibox float-e-margins">
  333. <div class="ibox-title">
  334. <h5 langtag="word-bandwidth"></h5>
  335. <div class="ibox-tools">
  336. <a class="collapse-link">
  337. <i class="fa fa-chevron-up"></i>
  338. </a>
  339. <a class="close-link">
  340. <i class="fa fa-times"></i>
  341. </a>
  342. </div>
  343. </div>
  344. <div class="ibox-content">
  345. <div id="bandwidth" style="height: 300px"></div>
  346. </div>
  347. </div>
  348. </div>
  349. </div>
  350. {{end}}
  351. <div class="row">
  352. <div class="col-lg-6">
  353. <div class="ibox float-e-margins">
  354. <div class="ibox-title">
  355. <h5 langtag="word-trafficstatistics"></h5>
  356. <div class="ibox-tools">
  357. <a class="collapse-link">
  358. <i class="fa fa-chevron-up"></i>
  359. </a>
  360. <a class="close-link">
  361. <i class="fa fa-times"></i>
  362. </a>
  363. </div>
  364. </div>
  365. <div class="ibox-content">
  366. <div id="flow" style="height: 400px;"></div>
  367. </div>
  368. </div>
  369. </div>
  370. <div class="col-lg-6">
  371. <div class="ibox float-e-margins">
  372. <div class="ibox-title">
  373. <h5 langtag="word-type"></h5>
  374. <div class="ibox-tools">
  375. <a class="collapse-link">
  376. <i class="fa fa-chevron-up"></i>
  377. </a>
  378. <a class="close-link">
  379. <i class="fa fa-times"></i>
  380. </a>
  381. </div>
  382. </div>
  383. <div class="ibox-content">
  384. <div id="counts" style="height:400px;"></div>
  385. </div>
  386. </div>
  387. </div>
  388. </div>
  389. </div>
  390. <script>
  391. $("#overview_cpu").text("{{.data.cpu}}%")
  392. $("#overview_cpu_bar").width("{{.data.cpu}}%")
  393. $("#overview_memory").text("{{.data.virtual_mem}}%")
  394. $("#overview_memory_bar").width("{{.data.virtual_mem}}%")
  395. $.each( JSON.parse({{.data.load}}), function(i, value) { $("#overview_load").append('&emsp;' + value) });
  396. $("#overview_tcp").text("{{.data.tcp}}")
  397. $("#overview_udp").text("{{.data.udp}}")
  398. $("#overview_send").text(changeunit({{.data.io_send}}) + "/s")
  399. $("#overview_recv").text(changeunit({{.data.io_recv}}) + "/s")
  400. chartdatas['load'] = {
  401. tooltip: {
  402. trigger: 'axis',
  403. formatter: function (params) {
  404. var str = params[0].axisValue + '<br/>';
  405. for (i in params){
  406. str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ params[i].data +'</br>';
  407. }
  408. return str;
  409. }
  410. },
  411. grid: {
  412. left: '3%',
  413. right: '3%',
  414. top: '5%',
  415. bottom: '3%',
  416. containLabel: true
  417. },
  418. xAxis: {
  419. type: 'category',
  420. boundaryGap: false,
  421. data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
  422. },
  423. yAxis: {
  424. type: 'value'
  425. },
  426. series: [
  427. {
  428. name: '',
  429. type: 'line',
  430. stack: 'load1',
  431. smooth: true,
  432. data: [{{.data.sys1.load1}}, {{.data.sys2.load1}}, {{.data.sys3.load1}}, {{.data.sys4.load1}}, {{.data.sys5.load1}}, {{.data.sys6.load1}}, {{.data.sys7.load1}}, {{.data.sys8.load1}}, {{.data.sys9.load1}}, {{.data.sys10.load1}}]
  433. },
  434. {
  435. name: '',
  436. type: 'line',
  437. stack: 'load5',
  438. smooth: true,
  439. data: [{{.data.sys1.load5}}, {{.data.sys2.load5}}, {{.data.sys3.load5}}, {{.data.sys4.load5}}, {{.data.sys5.load5}}, {{.data.sys6.load5}}, {{.data.sys7.load5}}, {{.data.sys8.load5}}, {{.data.sys9.load5}}, {{.data.sys10.load5}}]
  440. },
  441. {
  442. name: '',
  443. type: 'line',
  444. stack: 'load15',
  445. smooth: true,
  446. data: [{{.data.sys1.load15}}, {{.data.sys2.load15}}, {{.data.sys3.load15}}, {{.data.sys4.load15}}, {{.data.sys5.load15}}, {{.data.sys6.load15}}, {{.data.sys7.load15}}, {{.data.sys8.load15}}, {{.data.sys9.load15}}, {{.data.sys10.load15}}]
  447. }
  448. ]
  449. };
  450. chartdatas['cpu'] = {
  451. tooltip: {
  452. trigger: 'axis',
  453. formatter: function (params) {
  454. var str = params[0].axisValue + '<br/>';
  455. for (i in params){
  456. str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ params[i].data +'%</br>';
  457. }
  458. return str;
  459. }
  460. },
  461. grid: {
  462. left: '3%',
  463. right: '3%',
  464. top: '5%',
  465. bottom: '3%',
  466. containLabel: true
  467. },
  468. xAxis: {
  469. type: 'category',
  470. boundaryGap: false,
  471. data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
  472. },
  473. yAxis: {
  474. type: 'value',
  475. axisLabel: {
  476. show: true,
  477. interval: 'auto',
  478. formatter: '{value} %'
  479. }
  480. },
  481. series: [
  482. {
  483. name: '',
  484. type: 'line',
  485. stack: 'cpu',
  486. smooth: true,
  487. data: [{{.data.sys1.cpu}}, {{.data.sys2.cpu}}, {{.data.sys3.cpu}}, {{.data.sys4.cpu}}, {{.data.sys5.cpu}}, {{.data.sys6.cpu}}, {{.data.sys7.cpu}}, {{.data.sys8.cpu}}, {{.data.sys9.cpu}}, {{.data.sys10.cpu}}]
  488. }
  489. ]
  490. };
  491. chartdatas['memory'] = {
  492. tooltip: {
  493. trigger: 'axis',
  494. formatter: function (params) {
  495. var str = params[0].axisValue + '<br/>';
  496. for (i in params){
  497. str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ params[i].data +'MB</br>';
  498. }
  499. return str;
  500. }
  501. },
  502. grid: {
  503. left: '3%',
  504. right: '3%',
  505. top: '5%',
  506. bottom: '3%',
  507. containLabel: true
  508. },
  509. xAxis: {
  510. type: 'category',
  511. boundaryGap: false,
  512. data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
  513. },
  514. yAxis: {
  515. type: 'value',
  516. axisLabel: {
  517. show: true,
  518. interval: 'auto',
  519. formatter: '{value} MB'
  520. }
  521. },
  522. series: [
  523. {
  524. name: '',
  525. type: 'line',
  526. stack: 'virtual_mem',
  527. smooth: true,
  528. data: [{{.data.sys1.virtual_mem}}, {{.data.sys2.virtual_mem}}, {{.data.sys3.virtual_mem}}, {{.data.sys4.virtual_mem}}, {{.data.sys5.virtual_mem}}, {{.data.sys6.virtual_mem}}, {{.data.sys7.virtual_mem}}, {{.data.sys8.virtual_mem}}, {{.data.sys9.virtual_mem}}, {{.data.sys10.virtual_mem}}]
  529. },
  530. {
  531. name: '',
  532. type: 'line',
  533. stack: 'swap_mem',
  534. smooth: true,
  535. data: [{{.data.sys1.swap_mem}}, {{.data.sys2.swap_mem}}, {{.data.sys3.swap_mem}}, {{.data.sys4.swap_mem}}, {{.data.sys5.swap_mem}}, {{.data.sys6.swap_mem}}, {{.data.sys7.swap_mem}}, {{.data.sys8.swap_mem}}, {{.data.sys9.swap_mem}}, {{.data.sys10.swap_mem}}]
  536. }
  537. ]
  538. };
  539. chartdatas['connections'] = {
  540. tooltip: {
  541. trigger: 'axis'
  542. },
  543. grid: {
  544. left: '3%',
  545. right: '3%',
  546. top: '5%',
  547. bottom: '3%',
  548. containLabel: true
  549. },
  550. xAxis: {
  551. type: 'category',
  552. boundaryGap: false,
  553. data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
  554. },
  555. yAxis: {
  556. type: 'value'
  557. },
  558. series: [
  559. {
  560. name: '',
  561. type: 'line',
  562. stack: 'tcp',
  563. smooth: true,
  564. data: [{{.data.sys1.tcp}}, {{.data.sys2.tcp}}, {{.data.sys3.tcp}}, {{.data.sys4.tcp}}, {{.data.sys5.tcp}}, {{.data.sys6.tcp}}, {{.data.sys7.tcp}}, {{.data.sys8.tcp}}, {{.data.sys9.tcp}}, {{.data.sys10.tcp}}]
  565. },
  566. {
  567. name: '',
  568. type: 'line',
  569. stack: 'udp',
  570. smooth: true,
  571. data: [{{.data.sys1.udp}}, {{.data.sys2.udp}}, {{.data.sys3.udp}}, {{.data.sys4.udp}}, {{.data.sys5.udp}}, {{.data.sys6.udp}}, {{.data.sys7.udp}}, {{.data.sys8.udp}}, {{.data.sys9.udp}}, {{.data.sys10.udp}}]
  572. }
  573. ]
  574. };
  575. chartdatas['bandwidth'] = {
  576. tooltip: {
  577. trigger: 'axis',
  578. formatter: function (params) {
  579. var str = params[0].axisValue + '<br/>';
  580. for (i in params){
  581. str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ changeunit(params[i].data) +'/s</br>';
  582. }
  583. return str;
  584. }
  585. },
  586. grid: {
  587. left: '3%',
  588. right: '3%',
  589. top: '5%',
  590. bottom: '3%',
  591. containLabel: true
  592. },
  593. xAxis: {
  594. type: 'category',
  595. boundaryGap: false,
  596. data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
  597. },
  598. yAxis: {
  599. type: 'value',
  600. axisLabel: {
  601. show: true,
  602. interval: 'auto',
  603. formatter: function (params){
  604. return changeunit (params);
  605. }
  606. }
  607. },
  608. series: [
  609. {
  610. name: '',
  611. type: 'line',
  612. stack: 'in',
  613. smooth: true,
  614. data: [{{.data.sys1.io_recv}}, {{.data.sys2.io_recv}}, {{.data.sys3.io_recv}}, {{.data.sys4.io_recv}}, {{.data.sys5.io_recv}}, {{.data.sys6.io_recv}}, {{.data.sys7.io_recv}}, {{.data.sys8.io_recv}}, {{.data.sys9.io_recv}}, {{.data.sys10.io_recv}}]
  615. },
  616. {
  617. name: '',
  618. type: 'line',
  619. stack: 'out',
  620. smooth: true,
  621. data: [{{.data.sys1.io_send}}, {{.data.sys2.io_send}}, {{.data.sys3.io_send}}, {{.data.sys4.io_send}}, {{.data.sys5.io_send}}, {{.data.sys6.io_send}}, {{.data.sys7.io_send}}, {{.data.sys8.io_send}}, {{.data.sys9.io_send}}, {{.data.sys10.io_send}}]
  622. }
  623. ]
  624. };
  625. chartdatas['flow'] = {
  626. tooltip: {
  627. trigger: 'item',
  628. formatter: function (p) {
  629. return p.seriesName + '<br>' + p.name + ':' + changeunit(p.data.value);
  630. }
  631. },
  632. legend: {
  633. orient: 'vertical',
  634. left: 'left',
  635. data: ['', '']
  636. },
  637. series: [
  638. {
  639. name: '',
  640. type: 'pie',
  641. radius: '55%',
  642. center: ['50%', '60%'],
  643. data: [
  644. {
  645. name: '',
  646. value:{{.data.inletFlowCount}}
  647. },
  648. {
  649. name: '',
  650. value:{{.data.exportFlowCount}}
  651. }
  652. ],
  653. itemStyle: {
  654. emphasis: {
  655. shadowBlur: 10,
  656. shadowOffsetX: 0,
  657. shadowColor: 'rgba(0, 0, 0, 0.5)'
  658. }
  659. }
  660. }
  661. ]
  662. };
  663. chartdatas['counts'] = {
  664. tooltip: {
  665. trigger: 'item',
  666. formatter: '{a} <br/>{b} : {c} ({d}%)'
  667. },
  668. legend: {
  669. orient: 'vertical',
  670. left: 'left',
  671. data: ['', '', '', '', '', '', '']
  672. },
  673. series: [
  674. {
  675. name: '',
  676. type: 'pie',
  677. radius: '55%',
  678. center: ['50%', '60%'],
  679. data: [
  680. {
  681. name: '',
  682. value:{{.data.hostCount}}
  683. },
  684. {
  685. name: '',
  686. value:{{.data.tcpC}}
  687. },
  688. {
  689. name: '',
  690. value:{{.data.udpCount}}
  691. },
  692. {
  693. name: '',
  694. value:{{.data.httpProxyCount}}
  695. },
  696. {
  697. name: '',
  698. value:{{.data.socks5Count}}
  699. },
  700. {
  701. name: '',
  702. value:{{.data.secretCount}}
  703. },
  704. {
  705. name: '',
  706. value:{{.data.p2pCount}}
  707. }
  708. ],
  709. itemStyle: {
  710. emphasis: {
  711. shadowBlur: 10,
  712. shadowOffsetX: 0,
  713. shadowColor: 'rgba(0, 0, 0, 0.5)'
  714. }
  715. }
  716. }
  717. ]
  718. };
  719. window.addEventListener('resize', () => {
  720. for(var key in charts){
  721. charts[key].resize();
  722. }
  723. });
  724. </script>