Dlink config backup
Материал из noname.com.ua
Версия от 14:24, 9 марта 2009; Sirmax (обсуждение | вклад) (→Загрузка конфигурационного файла на TFTP-сервер)
Резервное копирование конфигов
Загрузка конфигурационного файла на TFTP-сервер
1. На коммутаторе создать view и community
create snmp view test 1 view_type included create snmp community my_community view test read_write
2. Задать IP-адрес TFTP-сервера:
snmpset -v2c -c my_community 172.29.14.122 1.3.6.1.4.1.171.12.1.2.1.1.3.3 a 172.29.14.1 SNMPv2-SMI::enterprises.171.12.1.2.1.1.3.3 = IpAddress: 172.29.14.1
3 - (последняя цифра OIDа) - Конфигурационный файл (config file) 172.29.14.1 - IP-адрес TFTP-сервера
3. Выбрать тип передачи файла:
snmpset -v2c -c my_comunity 172.29.14.122 1.3.6.1.4.1.171.12.1.2.1.1.4.3 i 2 SNMPv2-SMI::enterprises.171.12.1.2.1.1.4.3 = INTEGER: 2
2 - Загрузка по сети (1 и 3 по-видимому смысла не имеют, 1 - other, 3 - out-of-band load )
4. Задать имя конфигурационного файла:
snmpset -v2c -c my_community 172.29.14.122 1.3.6.1.4.1.171.12.1.2.1.1.5.3 s DES3526.cfg SNMPv2-SMI::enterprises.171.12.1.2.1.1.5.3 = STRING: "DES3526.cfg"
DES3526.cfg - Имя файла
5. Выбрать либо загрузку файла на коммутатор, либо на TFTP-сервер (download или upload):
snmpset -v2c -c my_community 172.29.14.122 1.3.6.1.4.1.171.12.1.2.1.1.7.3 i 2 SNMPv2-SMI::enterprises.171.12.1.2.1.1.7.3 = INTEGER: 2
2 - Upload
6. Начать передачу файла:
snmpset -v2c -c my_community 172.29.14.122 1.3.6.1.4.1.171.12.1.2.1.1.8.3 i 3
3 -> Начать операцию
Можно все комманды выполнить одним snmpset (подсказал voron ) (это позволит сэконосить в скриптах когда нужно сохранить конфиги со многих коммутаторов)
snmpset -v2c -c my_community 172.29.14.122 1.3.6.1.4.1.171.12.1.2.1.1.3.3 a 172.29.14.1 \ 1.3.6.1.4.1.171.12.1.2.1.1.4.3 i 2 \ 1.3.6.1.4.1.171.12.1.2.1.1.5.3 s DES3526.cfg \ 1.3.6.1.4.1.171.12.1.2.1.1.7.3 i 2 \ 1.3.6.1.4.1.171.12.1.2.1.1.8.3 i 3
Скрипт mass-backup
У меня получился такой скриптик
#!/bin/bash MYSQL=`which mysql` MYSQL_CONNECT_INFO="-u my_database -pPASSWORD USERNAME --skip-column-names -e" SNMPSET=` which snmpset` TFTP_SERVER_IP='172.16.0.1' DATE=`date +%d%m%Y` TAR=`which tar` $MYSQL $MYSQL_CONNECT_INFO "SELECT IP,DESCRIPTION,rw_community from switch where is_backup=1" | while read LINE do IP=`echo $LINE | awk '{print $1}'` DESCRIPTION=`echo $LINE | awk '{print $2}'` RW_COMMUNITY=`echo $LINE | awk '{print $3}'` FILE_NAME=`echo $DESCRIPTION | sed -e 's/\./_/' | sed -e 's/ /_/'` touch /tftproot/$FILE_NAME'_'${DATE}_DLINK_CFG chmod 777 /tftproot/$FILE_NAME'_'${DATE}_DLINK_CFG $SNMPSET -v2c -c $RW_COMMUNITY $IP 1.3.6.1.4.1.171.12.1.2.1.1.3.3 a $TFTP_SERVER_IP \ 1.3.6.1.4.1.171.12.1.2.1.1.4.3 i 2 \ 1.3.6.1.4.1.171.12.1.2.1.1.5.3 s $FILE_NAME'_'${DATE}_DLINK_CFG \ 1.3.6.1.4.1.171.12.1.2.1.1.7.3 i 2 \ 1.3.6.1.4.1.171.12.1.2.1.1.8.3 i 3 done # Выждать завершение всех процессов sleep 5 cd /tftproot $TAR -cf dlink-cfg-$DATE.tar *_DLINK_CFG