SNMP 関数
PHP Manual

snmpset

(PHP 4, PHP 5)

snmpsetSNMP オブジェクトの値を設定する

説明

bool snmpset ( string $host , string $community , string $object_id , string $type , mixed $value [, int $timeout = 1000000 [, int $retries = 5 ]] )

snmpset() 関数は、 object_idで指定した SNMP オブジェクトの 値を設定するために使用します。

パラメータ

host

SNMP エージェント (サーバ) のホスト名。

community

ライトコミュニティ。

object_id

SNMP オブジェクト ID。

type

オブジェクト ID の型を定義する MIB。以下の一覧のうちの一文字で指定しなければなりません。

=型を MIB から取得する
iINTEGER
uINTEGER
sSTRING
xHEX STRING
dDECIMAL STRING
nNULLOBJ
oOBJID
tTIMETICKS
aIPADDRESS
bBITS

SNMP ライブラリのコンパイル時に OPAQUE_SPECIAL_TYPES を定義した場合は、以下の型も使えます。

Uunsigned int64
Isigned int64
Ffloat
Ddouble

これらの大半は、対応する ASN.1 の型を使います。's', 'x', 'd' および 'b' はどれも OCTET STRING を異なる方法で表したものであり、'u' も Gauge32 値を扱うためのものです。

MIB ファイルが "snmp_read_mib" や libsnmp の設定で MIB ツリーに読み込まれている場合は、 type に '=' を使うことができます。 これはすべてのオブジェクト ID を表し、型は自動的に MIB から読み込みます。

"SYNTAX BITS {telnet(0), ftp(1), http(2), icmp(3), snmp(4), ssh(5), https(6)}" のような BITS 型の値変数を設定する方法は二通りあることに注意しましょう。

  • 型として "b" を使い、ビット番号の一覧を

    snmpset('FOO-MIB::bar.42', 'b', '0 1 2 3 4');
    のように指定する。 これは、同じ OID に対して snmpget() を実行しても 0xF8 などを返すので成功したかどうかを調べにくいという問題があります。

  • 型として "x" を使い、通常のプレフィックス "0x" をつけずに(!) 16 進数を指定する:

    snmpset('FOO-MIB::bar.42', 'x', 'F0');

value

新しい値。

timeout

最初のタイムアウトまでのマイクロ秒数。

retries

タイムアウト発生時の再試行回数。

返り値

成功した場合に TRUE を、失敗した場合に FALSE を返します。

SNMP ホストがデータ型を却下すると、"Warning: Error in packet. Reason: (badValue) The value given has the wrong type or length." のような’ E_WARNING メッセージが表示されます。未知の OID あるいは無効な OID を指定した場合は、おそらく "Could not add variable" のような警告となります。

例1 snmpset() の使用法

<?php
  snmpset
("localhost""public""IF-MIB::ifAlias.3""s""foo");
?>

参考


SNMP 関数
PHP Manual