net-snmp-5.7.3配置編譯安裝

net-snmp-5.7.3配置編譯安裝

先看一下系統環境linux

o@o-pc:~/work/_snmp/net-snmp-5.7.3$ uname -a
Linux o-pc 3.16.0-30-generic #40~14.04.1-Ubuntu SMP Thu Jan 15 17:43:14 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux

1.下載net-snmp-5.7.3源碼包

net snmp的源碼包能夠到 net-snmp官網上去下載。也能夠到sourcefroce上去下載。
net-snmp-5.4.4版下載web

o@o-pc:~/work/_snmp$ wget  http://downloads.sourceforge.net/project/net-snmp/net-snmp/5.4.4/net-snmp-5.4.4.tar.gz

net-snmp-5.7.3版下載shell

o@o-pc:~/work/_snmp$ wget  http://downloads.sourceforge.net/project/net-snmp/net-snmp/5.7.3/net-snmp-5.7.3.tar.gz

2.解壓net-snmp源碼包

o@o-pc:~/work/_snmp$ tar -xzvf net-snmp-5.7.3.tar.gz

3.編譯安裝配置

進入解壓的 net-snmp-5.7.3文件夾。能夠看到configure文件,如今就使用這個文件來自動配置。
固然,自動配置也能夠定製一些內容,好比安裝路徑等。apache

 ./configure參數 含義
--prefix=/usr/local/net-snmp  net snmp的安裝路徑
--enable-mfd-rewrites 容許新的mfd重寫可用的mid模塊
--with-default-snmp-version="3" 默認的snmp版本
--with-sys-contact="name,E_mail:maileaddress " 該設備的聯繫人
--with-sys-location="China" 該設備的位置
--with-logfile="/var/log/snmpd.log" 日誌文件路徑
--with-persistent-directory="/var/net-snmp"  不變數據存儲目錄

咱們這裏只配置安裝路徑,其它的都使用默認設置。sass

o@o-pc:~/work/_snmp/net-snmp-5.7.3$ ./configure --prefix=/usr/local/net-snmp

配置時的輸出信息安全

checking what to build and install...  agent apps man local mibs
using default persistent mask 077
using default temporary file pattern /tmp/snmpdXXXXXX
using default AgentX socket /var/agentx/master
using default "enterprise.net-snmp"
using default enterprise sysOID "NET-SNMP-MIB::netSnmpAgentOIDs..."
using default notifications "NET-SNMP-MIB::netSnmpNotifications"
using OS default send buffer size for server sockets
using OS default recv buffer size for server sockets
using OS default send buffer size for client sockets
using OS default recv buffer size for client sockets
checking whether to prompt for values... configure:

     ************** Configuration Section **************

注意: 當輸入配置以後按回車鍵以後,系統會有一段時間執行配置。這段時間的執行過程是不會中止的,當出現中止要按某個鍵才能繼續往下執行,說明配置有問題,請取消當前執行從新檢查配置,確保配置正確無誤。 以避免之後的安裝出錯,或者安裝完成以後不能正常使用。 
執行完配置(沒有中斷,沒有要求按某個鍵)以後會出現以下所示的信息。有可能出現的和下面的不同,這取決於配置,但只要出現和這個類似的部分,說明配置是成功的。沒有必要仔細看這個配置摘要。bash

Net-SNMP configuration summary:
---------------------------------------------------------

  SNMP Versions Supported:    1 2c 3
  Building for:               linux
  Net-SNMP Version:           5.7.3
  Network transport support:  Callback Unix Alias TCP UDP IPv4Base SocketBase TCPBase UDPIPv4Base UDPBase
  SNMPv3 Security Modules:     usm
  Agent MIB code:            default_modules =>  snmpv3mibs mibII ucd_snmp notification notification-log-mib target agent_mibs agentx disman/event disman/schedule utilities host
  MYSQL Trap Logging:         unavailable
  Embedded Perl support:      disabled
  SNMP Perl modules:          building -- not embeddable
  SNMP Python modules:        disabled
  Crypto support from:        crypto
  Authentication support:     MD5 SHA1
  Encryption support:         DES AES
  Local DNSSEC validation:    disabled

---------------------------------------------------------

4.編譯安裝

make編譯

o@o-pc:~/work/_snmp/net-snmp-5.7.3$ make
...
/usr/bin/ld: cannot find -lperl
collect2: error: ld returned 1 exit status
make[1]: *** [libnetsnmpagent.la] 錯誤 1

cannot find -lperl問題

在make編譯的時候遇到了一個錯誤,提示找不到perl這個庫。緣由是由於個人電腦上沒有安裝perl開發環境,如今裝一個。session

o@o-pc:~/work/_snmp/net-snmp-5.7.3$ sudo apt-get install libperl-dev

也許還會碰到缺乏libtool,openssl,zlib庫的狀況,請直接安裝。
通常遇到這種缺乏了什麼庫的問題,都是經過安裝libXXX-dev或者安裝XXX-dev來解決。但也不絕對,有的時候是由於相關的庫不是安裝在系統的默認路徑,也沒用加入到環境變量中。app

make install安裝

編譯成功後就能夠安裝了,前面設置了安裝路徑是/usr/local/net-snmp,由於這個路徑是的全部者(own)和所在組(group)都是root,全部須要sudo來執行。

o@o-pc:~/work/_snmp/net-snmp-5.7.3$ sudo make install

安裝的時候會大量輸出相似於的消息,提示咱們安裝了某個配置文件到/usr/local/net-snmp/share/snmp目錄

install: installed XXX.conf in /usr/local/net-snmp/share/snmp

安裝完成後進入目錄/usr/local/net-snmp/sbin便可看到可執行文件snmpd,執行輸出一下版本信息。由於咱們這裏尚未把它的路徑添加到環境變量,全部還不能在任意位置直接輸入snmpd來運行。

o@o-pc:/usr/local/net-snmp/sbin$ ./snmpd -v

NET-SNMP version:  5.7.3
Web:               http://www.net-snmp.org/
Email:             net-snmp-coders@lists.sourceforge.net

5. snmpd.conf配置

snmpd.conf是snmp服務的配置文件。

5.1 snmpd.conf文件生成和修改

生成snmpd.conf

先將EXAMPLE.conf文件複製到/usr/local/net-snmp/share/snmp,並重命名爲snmpd.conf

o@o-pc:~/work/_snmp/net-snmp-5.7.3$ sudo cp EXAMPLE.conf /usr/local/net-snmp/share/snmp/snmpd.conf

上面是一個比較複雜的配置文件,其實能夠簡單一點。能夠只須要下面說的幾點內容寫到配置文件,其它的都是多餘的

修改snmpd.conf

snmpd.conf文件的修改能夠參考這些文章
1.net-snmp的配置文件snmpd.conf配置說明
2.snmpd.conf的基礎配置
這裏按照上面給出的兩篇文章內容來進行的修改(主要是第二篇)。
---
下面的配置中,使用到的com2sec/group/view/access的說明在EXAMPLE.conf文件的註釋中能夠看到(大體是65行)。
首先定義一個首共同體名稱(community),這裏是 public。以及能夠訪問這個 public 的用戶名(sec name),這裏是 notConfigUser 。public 至關於用戶 notConfigUser 的密碼。
在snmpd.conf文件中添加下面的語句。(第一句是註釋)

#          sec.name       source      community
  com2sec notConfigUser  default       public

而後定義一個組名(groupName)這裏是 notConfigGroup,以及組的安全級別,並把 notConfigGroup 這個用戶加到這個組中。
在snmpd.conf文件中添加下面的語句。(第一句是註釋)

#       groupName       securityModel    securityName
group   notConfigGroup      v1           notConfigUser  
group   notConfigGroup      v2c          notConfigUser

接着定義一個可操做的視圖(view)名, 這裏是 all,範圍是 .1。
在snmpd.conf文件中添加下面的語句。(第一句是註釋)

#       name     incl/excl     subtree         mask(optional)
  view  all      included        .1

最後定義 notConfigUser 這個組在 all 這個視圖範圍內可作的操做,這時定義了 notConfigUser 組的成員可對 .1 這個視圖作只讀操做。

#          group        context sec.model sec.level prefix read   write  notif
 access  notConfigGroup ""      any       noauth    exact  all  none none

還可使用snmpconf程序來設置,這個程序在安裝目錄的bin目錄下。它會提示你輸入相關的設置。

o@o-pc:/usr/local/net-snmp/bin$ ./snmpconf -g basic_setup

The following installed configuration files were found:

   1:  /usr/local/net-snmp/share/snmp/snmpd.conf

Would you like me to read them in?  Their content will be merged with the
output files created by this session.

Valid answer examples: "all", "none","3","1,2,5"

Read in which (default = all): all
************************************************ 
*** Beginning basic system information setup ***
************************************************ 
Do you want to configure the information returned in the system MIB group (contact info, etc)? (default = y): 

...

啓動netsnmp服務

咱們可使用命令service --sratus-all來查看當前的服務狀態。能夠看到我這臺機器上是沒有netsnmp這個服務的。不要緊,咱們並非特別須要它。具體見下面

o@o-pc:/usr/local/net-snmp/share/snmp$ service --status-all
 [ + ]  acpid
 [ - ]  anacron
 [ + ]  apache
 [ - ]  apparmor
 [ ? ]  apport
 [ + ]  avahi-daemon
 [ + ]  bluetooth
 [ - ]  brltty
 [ ? ]  console-setup
 [ + ]  cron
 [ + ]  cups
 [ + ]  cups-browsed
 [ - ]  dbus
 [ ? ]  dns-clean
 [ + ]  friendly-recovery
 [ - ]  gdm
 [ - ]  grub-common
 [ ? ]  irqbalance
 [ + ]  kerneloops
 [ ? ]  killprocs
 [ ? ]  kmod
 [ ? ]  networking
 [ ? ]  ondemand
 [ ? ]  pppd-dns
 [ - ]  procps
 [ - ]  pulseaudio
 [ ? ]  rc.local
 [ + ]  resolvconf
 [ - ]  rsync
 [ + ]  rsyslog
 [ + ]  saned
 [ ? ]  sendsigs
 [ - ]  spamassassin
 [ ? ]  speech-dispatcher
 [ - ]  sudo
 [ - ]  udev
 [ ? ]  umountfs
 [ ? ]  umountnfs.sh
 [ ? ]  umountroot
 [ - ]  unattended-upgrades
 [ - ]  urandom
 [ - ]  x11-common
o@o-pc:/usr/local/net-snmp/share/snmp$

如今尚未netsnmp這個服務,那麼是否是必定要這個服務呢?不是必定的。由於linux的服務,能夠說就是一個守護進程,咱們找到這個進程的可執行文件來執行它就是。而這個文件就在安裝目錄下的sbin目錄中。

o@o-pc:/usr/local/net-snmp/sbin$ ls
snmpd  snmptrapd

執行它的時候可指定配置文件(若是不帶,默認就是這個),下面來執行一下試試

o@o-pc:/usr/local/net-snmp/sbin$ ./snmpd -c ../share/snmp/snmpd.conf

若是執行失敗,程序直接退出了,可使用-f -Le參數來查看錯誤信息。
其中-f是do not fork from the shell不從shell派生子進程
-L toggle options controlling where to log to切換到相關的日誌控制,它後面須要跟參數。 e:log to standard error 日誌到標準錯誤。
這些相關的參數能夠經過 ./snmpd -h獲取。
我這邊出現了這樣的錯誤。

o@o-pc:/usr/local/net-snmp/sbin$ ./snmpd -f -Le
Turning on AgentX master support.
Error opening specified endpoint "udp:127.0.0.1:161"
Server Exiting with code 1

這個錯誤的緣由很簡單,那就是權限問題。使用sudo來執行就沒有問題了。linux上不少問題都是權限的問題。

o@o-pc:/usr/local/net-snmp/sbin$ sudo ./snmpd -f -Le
[sudo] password for o: 
NET-SNMP version 5.7.3

這裏沒有加配置文件路徑,是由於使用的默認配置文件/usr/local/net-snmp/share/snmp/snmpd.conf,若是還有別的錯誤,那麼就修改配置文件,只保留上面說到的四點,其他的都刪除掉來試試。
其實配置文件還能夠這樣,這也是從網上找的。

#設置區域
syslocation  "SHANGHAI P.R.China" 
#設置系統聯繫人
syscontact  webmaster@domainname.com 
#設置一個只讀帳戶 read-only community
#下面的 whatever 至關於密碼,後面還能夠跟一個IP地址,表示監控點主機
rocommunity  whatever 
#設置一個讀寫帳戶 read-write community
rwcommunity  whoareyou

執行成功後咱們能夠進入到bin目錄,而後執行snmpwalk,snmpget等命令來查看一下。

o@o-pc:/usr/local/net-snmp/bin$ ./snmpget -v 1 -c public localhost sysUpTime.0 
o@o-pc:/usr/local/net-snmp/bin$ ./snmpwalk -v 1 localhost -c public system
o@o-pc:/usr/local/net-snmp/bin$ ./snmpwalk -v 2c -c whatever -m ALL localhost .1.3
o@o-pc:/usr/local/net-snmp/bin$ ./snmpwalk -v 1 172.0.0.1 -c whatever system
Timeout: No Response from 172.0.0.1
o@o-pc:/usr/local/net-snmp/bin$ ./snmpwalk -v 1 localhost -c whatever system
SNMPv2-MIB::sysDescr.0 = STRING: Linux o-pc 3.16.0-30-generic #40~14.04.1-Ubuntu SMP Thu Jan 15 17:43:14 UTC 2015 x86_64
SNMPv2-MIB::sysObjectID.0 = OID: NET-SNMP-MIB::netSnmpAgentOIDs.10
DISMAN-EVENT-MIB::sysUpTimeInstance = Timeticks: (21134) 0:03:31.34
SNMPv2-MIB::sysContact.0 = STRING: webmaster@domainname.com
SNMPv2-MIB::sysName.0 = STRING: o-pc
SNMPv2-MIB::sysLocation.0 = STRING: \"SHANGHAI P.R.China\"
SNMPv2-MIB::sysORLastChange.0 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORID.1 = OID: SNMP-MPD-MIB::snmpMPDCompliance
SNMPv2-MIB::sysORID.2 = OID: SNMP-USER-BASED-SM-MIB::usmMIBCompliance
SNMPv2-MIB::sysORID.3 = OID: SNMP-FRAMEWORK-MIB::snmpFrameworkMIBCompliance
SNMPv2-MIB::sysORID.4 = OID: SNMPv2-MIB::snmpMIB
SNMPv2-MIB::sysORID.5 = OID: SNMP-VIEW-BASED-ACM-MIB::vacmBasicGroup
SNMPv2-MIB::sysORID.6 = OID: TCP-MIB::tcpMIB
SNMPv2-MIB::sysORID.7 = OID: IP-MIB::ip
SNMPv2-MIB::sysORID.8 = OID: UDP-MIB::udpMIB
SNMPv2-MIB::sysORID.9 = OID: SNMP-NOTIFICATION-MIB::snmpNotifyFullCompliance
SNMPv2-MIB::sysORID.10 = OID: NOTIFICATION-LOG-MIB::notificationLogMIB
SNMPv2-MIB::sysORDescr.1 = STRING: The MIB for Message Processing and Dispatching.
SNMPv2-MIB::sysORDescr.2 = STRING: The management information definitions for the SNMP User-based Security Model.
SNMPv2-MIB::sysORDescr.3 = STRING: The SNMP Management Architecture MIB.
SNMPv2-MIB::sysORDescr.4 = STRING: The MIB module for SNMPv2 entities
SNMPv2-MIB::sysORDescr.5 = STRING: View-based Access Control Model for SNMP.
SNMPv2-MIB::sysORDescr.6 = STRING: The MIB module for managing TCP implementations
SNMPv2-MIB::sysORDescr.7 = STRING: The MIB module for managing IP and ICMP implementations
SNMPv2-MIB::sysORDescr.8 = STRING: The MIB module for managing UDP implementations
SNMPv2-MIB::sysORDescr.9 = STRING: The MIB modules for managing SNMP Notification, plus filtering.
SNMPv2-MIB::sysORDescr.10 = STRING: The MIB module for logging SNMP Notifications.
SNMPv2-MIB::sysORUpTime.1 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.2 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.3 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.4 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.5 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.6 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.7 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.8 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.9 = Timeticks: (0) 0:00:00.00
SNMPv2-MIB::sysORUpTime.10 = Timeticks: (0) 0:00:00.00
相關文章
相關標籤/搜索