2018-07-26 15:39:08 -05:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
import swsssdk
|
|
|
|
import time
|
|
|
|
|
|
|
|
def enable_counter_group(db, name):
|
|
|
|
info = {}
|
|
|
|
info['FLEX_COUNTER_STATUS'] = 'enable'
|
|
|
|
db.mod_entry("FLEX_COUNTER_TABLE", name, info)
|
|
|
|
|
|
|
|
def enable_counters():
|
|
|
|
db = swsssdk.ConfigDBConnector()
|
|
|
|
db.connect()
|
|
|
|
enable_counter_group(db, 'PORT')
|
2020-06-04 11:52:43 -05:00
|
|
|
enable_counter_group(db, 'RIF')
|
2018-07-26 15:39:08 -05:00
|
|
|
enable_counter_group(db, 'QUEUE')
|
|
|
|
enable_counter_group(db, 'PFCWD')
|
2019-03-22 18:56:46 -05:00
|
|
|
enable_counter_group(db, 'PG_WATERMARK')
|
|
|
|
enable_counter_group(db, 'QUEUE_WATERMARK')
|
2020-07-11 01:29:37 -05:00
|
|
|
enable_counter_group(db, 'BUFFER_POOL_WATERMARK')
|
2020-08-25 10:48:56 -05:00
|
|
|
enable_counter_group(db, 'PORT_BUFFER_DROP')
|
2018-07-26 15:39:08 -05:00
|
|
|
|
|
|
|
def get_uptime():
|
|
|
|
with open('/proc/uptime') as fp:
|
|
|
|
return float(fp.read().split(' ')[0])
|
|
|
|
|
|
|
|
def main():
|
|
|
|
# If the switch was just started (uptime less than 5 minutes),
|
|
|
|
# wait for 3 minutes and enable counters
|
|
|
|
# otherwise wait for 60 seconds and enable counters
|
|
|
|
uptime = get_uptime()
|
|
|
|
if uptime < 300:
|
|
|
|
time.sleep(180)
|
|
|
|
else:
|
|
|
|
time.sleep(60)
|
|
|
|
enable_counters()
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|