⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dumpsnmpoid.py

📁 Network Administration Visualized 网络管理可视化源码
💻 PY
字号:
#!/usr/bin/env python# -*- coding: ISO8859-1 -*-# Copyright 2004 Norwegian University of Science and Technology## This file is part of Network Administration Visualized (NAV)## NAV is free software; you can redistribute it and/or modify# it under the terms of the GNU General Public License as published by# the Free Software Foundation; either version 2 of the License, or# (at your option) any later version.## NAV is distributed in the hope that it will be useful,# but WITHOUT ANY WARRANTY; without even the implied warranty of# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the# GNU General Public License for more details.## You should have received a copy of the GNU General Public License# along with NAV; if not, write to the Free Software# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA### Authors: Morten Vold <morten.vold@itea.ntnu.no>#""" This script will connect to a live manage database and dump thecontents of the snmpoid table in a format suitable for re-insertion atthe same or a different site.Make sure the environment variable PGASSWORD is set before runningthe script.  Should be rewritten to ask for a password if none isknown."""import sysimport osimport psycopgimport timedef main(args):    dbname = "manage"    dbhost = os.getenv('PGHOST') or 'localhost'    dbport = os.getenv('PGPORT') or '5432'    dbuser = os.getenv('PGUSER') or 'postgres'    dbpasswd = os.getenv('PGPASSWORD')    connection = psycopg.connect(        'host=%s port=%s dbname=%s user=%s password=%s' %        (dbhost, dbport, dbname, dbuser, dbpasswd))    cursor = connection.cursor()    cursor.execute("SELECT oidkey, snmpoid, descr, oidsource, getnext, " +                   "match_regex, decodehex, oidname, mib FROM snmpoid " +                   "ORDER BY oidkey")    timeString = time.strftime("%Y-%m-%d %H:%M:%S GMT", time.gmtime())    print '--\n-- Automated dump by dumpsnmpoid.py initiated at ' + \          timeString + '\n--'    print "BEGIN;"    for row in cursor.fetchall():        newrow = []        for col in row:            if col is None:                newrow.append('NULL')            else:                newrow.append(str(psycopg.QuotedString(str(col))))        print "DELETE FROM snmpoid WHERE oidkey=%s;" % newrow[0]        print "INSERT INTO snmpoid (oidkey, snmpoid, descr, oidsource,",        print "getnext, match_regex, decodehex, oidname, mib)"        print "VALUES (%s);" % ",".join(newrow)        print    # We insert statements that will force getDeviceData to re-test all    # the boxes, as we've made changed to the list of known snmpoids.    print    print "UPDATE snmpoid SET getnext=true, uptodate=true;"    print "UPDATE netbox SET uptodate=false;"    print    print "COMMIT;"    print '--\n-- Automatic dump ends here\n--'############### begin here ###############if __name__ == '__main__':    main(sys.argv[1:])

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -