我正在为我们的一个C#应用程序编写一个代理程序,它使用SharpSnmpLib通过SNMP GET公开各种应用程序属性,我已经成功发送了陷阱并检索了GET。我能够公开单个属性,但是我无法弄清楚如何在我的应用程序中定义表。
这个表应该为我的应用程序中的每个流概念实例公开一组GET参数(流的数量在启动时是固定的),每个流应该表示为表中的一行。
在MIB中定义它很容易,并且我过去使用C ++库成功定义并实现了这样的表,所以我知道它是可能的。
以下是我如何在MIB中定义应用版本的简单GET:
dtStream OBJECT IDENTIFIER ::= {dtApps 3}
dtVersion OBJECT-TYPE
SYNTAX DisplayString
MAX-ACCESS read-only
STATUS current
DESCRIPTION
"The version number of the application"
::= {dtStream 1}
在代码中:
public class StringVar : ScalarObject
{
private ISnmpData _data;
private string _value;
public StringVar(ObjectIdentifier oid, string value) : base(oid)
{
Value = value;
}
public override ISnmpData Data
{
get { return _data; }
set { throw new AccessFailureException(); }
}
public string Value
{
set { _data = new OctetString(_value = value); }
get { return _value; }
}
}
...
ObjectStore os = new ObjectStore();
os.Add(Version = new StringVar(OID_STREAM_VERSION, System.Reflection.Assembly.GetExecutingAssembly().GetName().Version.ToString()));
以下是我尝试创建的表格的示例MIB定义:
dtStreamTable OBJECT-TYPE
SYNTAX SEQUENCE OF DtStreamEntry
MAX-ACCESS not-accessible
STATUS current
DESCRIPTION
"Statistics on the status and performance of the streams"
::= {dtStream 5}
DtStreamEntry OBJECT-TYPE
SYNTAX DtStreamEntry
MAX-ACCESS not-accessible
STATUS current
DESCRIPTION
"Status of a particular stream."
INDEX {dtStreamID}
::= {dtStreamTable 1}
DtStreamEntry ::= SEQUENCE {
dtmStreamID Integer32,
dtStreamName DisplayString
dtStreamHost DisplayString
dtStreamType Integer32
}
dtStreamID OBJECT-TYPE
SYNTAX Integer32 (0..255)
MAX-ACCESS not-accessible
STATUS current
DESCRIPTION
"Index of the stream entry in the table."
::= {DtStreamEntry 1}
dtStreamName OBJECT-TYPE
SYNTAX DisplayString
MAX-ACCESS read-only
STATUS current
DESCRIPTION
"Name of the stream."
::= {DtStreamEntry 2}
dtStreamHost OBJECT-TYPE
SYNTAX DisplayString
MAX-ACCESS read-only
STATUS current
DESCRIPTION
"Hostname that the stream is connected to."
::= {DtStreamEntry 3}
dtStreamType OBJECT-TYPE
SYNTAX Integer32(1..2)
MAX-ACCESS read-only
STATUS current
DESCRIPTION
"Type of stream"
::= {DtStreamEntry 4}
在iReasoning MIB Browser中看起来像这样:
我已经定义了我认为是" row",作为派生自TableObject
的类:
class StreamEntry : TableObject
{
private readonly IList<ScalarObject> _elements = new List<ScalarObject>();
public StreamEntry(int id, string name, string host, int type)
: base()
{
_elements.Add(StreamId = new IntVar(OID_STREAM_ID, id));
_elements.Add(Name = new StringVar(OID_STREAM_NAME, name));
_elements.Add(Host = new StringVar(OID_STREAM_HOST, host));
_elements.Add(Type = new IntVar(OID_STREAM_TYPE, type));
}
public IntVar StreamId { get; private set; }
public StringVar Name { get; private set; }
public StringVar Host { get; private set; }
public IntVar Type { get; private set; }
protected override IEnumerable<ScalarObject> Objects
{
get { return _elements; }
}
}
毕竟,我想我的问题是,如何将这些关联到与表或条目的OID一起返回的表中?
我尝试在ObjectStore中添加多个StreamEntry
对象:
foreach(Stream s in Streams)
{
os.Add(new StreamEntry(s.ID, s.Name, s.HostName, s.Type));
}
有了这个,我只能检索第一个数据(使用单独的GET,或MIB浏览器中的dtStreamEntry上的WALK)。
答案 0 :(得分:1)
好的,我明白了。所有ScalarObjects
都需要以OID顺序添加到ObjectStore
- 否则一切都会中断。
所以我需要在一个封闭的StreamEntry
对象中创建多个TableObject
对象(不再有StreamTable
作为基类),该对象派生自TableObject
,我需要从每个ScalarObjects
中提取StreamEntry
并在将它们作为Objects集合覆盖返回之前按OID对它们进行排序。
我现在有一个工作的SNMP表。 :)