1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752
|
<!--
%CopyrightBegin%
SPDX-License-Identifier: Apache-2.0
Copyright Ericsson AB 2023-2025. All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
%CopyrightEnd%
-->
# SNMP Application
## Description
This chapter describes the `snmp` application in OTP. The SNMP application
provides the following services:
- a multilingual extensible SNMP agent
- a SNMP manager
- a MIB compiler
## Configuration
The following configuration parameters are defined for the SNMP application.
Refer to application(3) for more information about configuration parameters.
The snmp part of the config file specifying the configuration parameters is
basically the following tuple:
```text
{snmp, snmp_components_config()}
```
A minimal config file for starting a node with both a manager and an agent:
```erlang
[{snmp,
[{agent, [{db_dir, "/tmp/snmp/agent/db"},
{config, [{dir, "/tmp/snmp/agent/conf"}]}]},
{manager, [{config, [{dir, "/tmp/snmp/manager/conf"},
{db_dir, "/tmp/snmp/manager/db"}]}]}]}
]
}
].
```
Each snmp component has its own set of configuration parameters, even though
some of the types are common to both components.
```erlang
snmp_components_config() -> [snmp_component_config()]
snmp_component_config() -> {agent, agent_options()} | {manager, manager_options()}
agent_options() = [agent_option()]
agent_option() = {restart_type, restart_type()} |
{agent_type, agent_type()} |
{agent_verbosity, verbosity()} |
{discovery, agent_discovery()} |
{versions, versions()} |
{gb_max_vbs, gb_max_vbs()} |
{priority, priority()} |
{multi_threaded, multi_threaded()} |
{db_dir, db_dir()} |
{db_init_error, db_init_error()} |
{local_db, local_db()} |
{net_if, agent_net_if()} |
{mibs, mibs()} |
{mib_storage, mib_storage()} |
{mib_server, mib_server()} |
{audit_trail_log, audit_trail_log()} |
{error_report_mod, error_report_mod()} |
{note_store, note_store()} |
{symbolic_store, symbolic_store()} |
{target_cache, target_cache()} |
{config, agent_config()}
manager_options() = [manager_option()]
manager_option() = {restart_type, restart_type()} |
{net_if, manager_net_if()} |
{server, server()} |
{note_store, note_store()} |
{config, manager_config()} |
{inform_request_behaviour, manager_irb()} |
{mibs, manager_mibs()} |
{priority, priority()} |
{audit_trail_log, audit_trail_log()} |
{versions, versions()} |
{def_user_mod, def_user_module() |
{def_user_data, def_user_data()}
```
[](){: #agent_opts_and_types }
Agent specific config options and types:
- **`agent_type() = master | sub <optional>`{: #agent_type }** - If `master`,
one master agent is started. Otherwise, no agents are started.
Default is `master`.
- **`agent_discovery() = [agent_discovery_opt()] <optional>`{: #agent_disco }** -
`agent_discovery_opt() = {terminating, agent_terminating_discovery_opts()} | {originating, agent_originating_discovery_opts()}`
The `terminating` options effects discovery initiated by a manager.
The `originating` options effects discovery initiated by this agent.
For defaults see the options in `agent_discovery_opt()`.
- **`agent_terminating_discovery_opts() = [agent_terminating_discovery_opt()] <optional>`{: #agent_term_disco_opts }** -
`agent_terminating_discovery_opt() = {enable, boolean()} | {stage2, discovery | plain} | {trigger_username, string()}`
These are options effecting discovery `terminating` in this agent (i.e.
initiated by a manager).
The default values for the `terminating` discovery options are:
- enable: `true`
- stage2: `discovery`
- trigger_username: `""`
- **`agent_originating_discovery_opts() = [agent_originating_discovery_opt()] <optional>`{: #agent_orig_disco_opts }** -
`agent_originating_discovery_opt() = {enable, boolean()}`
These are options effecting discovery `originating` in this agent.
The default values for the `originating` discovery options are:
- enable: `true`
- **`multi_threaded() = bool() | extended <optional>`{: #agent_mt }** - If
`true` (or `extended`), the agent is multi-threaded, with one thread for each
get request.
The value `extended` means that a special 'process' is also created intended
to handle _all_ notifications.
- `true` \- One worker dedicated to 'set-requests' and one (main) worker for
all other requests ('get-request' and notifications).
If the 'main' worker is busy, a temporary process is spawned to handle that
job ('get-request' or notification).
- `extended` \- One worker dedicated to 'set-requests', one worker dedicated
to notifications and one (main) worker for all 'get-requests'.
If the 'main' worker is busy, a temporary process is spawned to handle that
'get-request'.
> #### Note {: .info }
>
> Even with multi-threaded set to `extended` there is still a risk for
> 'reorder' when sending inform-requsts, which require a response (and may
> therefore require resending).
>
> Also, there is of course no way to guarantee order once the package is on
> the network.
Default is `false`.
- **`db_dir() = string() <mandatory>`{: #agent_data_dir }** - Defines where the
SNMP agent internal db files are stored.
- **`gb_max_vbs() = pos_integer() | infinity <optional>`{: #agent_gb_max_vbs }** - Defines the maximum number of varbinds allowed in a Get-BULK response.
Default is `1000`.
- **`local_db() = [local_db_opt()] <optional>`{: #agent_local_db }** -
`local_db_opt() = {repair, agent_repair()} | {auto_save, agent_auto_save()} | {verbosity, verbosity()}`
Defines options specific for the SNMP agent local database.
For defaults see the options in `local_db_opt()`.
- **`agent_repair() = false | true | force <optional>`{: #agent_ldb_repair }** -
When starting snmpa_local_db it always tries to open an existing database. If
`false`, and some errors occur, a new database is created instead. If `true`,
an existing file will be repaired. If `force`, the table will be repaired even
if it was properly closed.
Default is `true`.
- **`agent_auto_save() = integer() | infinity <optional>`{: #agent_ldb_auto_save }** - The auto save interval. The table is flushed to disk whenever not
accessed for this amount of time.
Default is `5000`.
- **`agent_net_if() = [agent_net_if_opt()] <optional>`{: #agent_net_if }** -
`agent_net_if_opt() = {module, agent_net_if_module()} | {verbosity, verbosity()} | {options, agent_net_if_options()}`
Defines options specific for the SNMP agent network interface entity.
For defaults see the options in `agent_net_if_opt()`.
- **`agent_net_if_module() = atom() <optional>`{: #agent_ni_module }** - Module
which handles the network interface part for the SNMP agent. Must implement
the `m:snmpa_network_interface` behaviour.
Default is `snmpa_net_if`.
- **`agent_net_if_options() = [agent_net_if_option()] <optional>`{: #agent_ni_opts }** -
`agent_net_if_option() = {bind_to, bind_to()} | {sndbuf, sndbuf()} | {recbuf, recbuf()} | {no_reuse, no_reuse()} | {req_limit, req_limit()} | {filter, agent_net_if_filter_options()} | {open_err_filters, agent_net_if_open_err_filters()} | {extra_sock_opts, extra_socket_options()} | {inet_backend, inet_backend()}`
These options are actually specific to the used module. The ones shown here
are applicable to the default `agent_net_if_module()`.
> #### Note {: .info }
>
> If the user has configured transports _with_ options then those will take
> precedence over these options. See
> [agent information](snmp_agent_config_files.md#agent_information) for more
> info.
For defaults see the options in `agent_net_if_option()`.
- **`req_limit() = integer() | infinity <optional>`{: #agent_ni_req_limit }** -
Max number of simultaneous requests handled by the agent.
Default is `infinity`.
- **`agent_net_if_filter_options() = [agent_net_if_filter_option()] <optional>`{: #agent_ni_filter_opts }** -
`agent_net_if_filter_option() = {module, agent_net_if_filter_module()}`
These options are actually specific to the used module. The ones shown here
are applicable to the default `agent_net_if_filter_module()`.
For defaults see the options in `agent_net_if_filter_option()`.
- **`agent_net_if_filter_module() = atom() <optional>`{: #agent_ni_filter_module }** - Module which handles the network interface filter part for the SNMP
agent. Must implement the `m:snmpa_network_interface_filter` behaviour.
Default is `snmpa_net_if_filter`.
- **`agent_net_if_open_err_filters() = [agent_net_if_open_err_filter()] <optional>`{: #agent_ni_open_err_filters }** - `agent_net_if_open_err_filter() = atom()`
During agent initiation, the transports UDP sockets are opened. If this
operation fails, the net-if (and the agent) fails to start (crash). This
(filter) list contains error (reasons) that will make net-if fail "nicely".
This (filter) list, is supposed to contain errors that can be returned by
[gen_udp:open/1,2](`gen_udp:open/1`). The effect is that any error returned by
[gen_udp:open](`gen_udp:open/1`) which _are_ in this list, will be considered
"non-fatal" and will only result in an info message, rather than an error
message. Net If, and the agent, will still crash, but will produce a less
obnoxious message.
- **`agent_mibs() = [string()] <optional>`{: #agent_mibs }** - Specifies a list
of MIBs (including path) that defines which MIBs are initially loaded into the
SNMP master agent.
Note that the following mibs will always be loaded:
- version v1: `STANDARD-MIB`
- version v2: `SNMPv2`
- version v3: `SNMPv2`, `SNMP-FRAMEWORK-MIB` and `SNMP-MPD-MIB`
Default is `[]`.
- **`mib_storage() = [mib_storage_opt()] <optional>`{: #agent_mib_storage }** -
`mib_storage_opt() = {module, mib_storage_module()} | {options, mib_storage_options()}`
This option specifies how basic mib data is stored. This option is used by two
parts of the snmp agent: The mib-server and the symbolic-store.
Default is `[{module, snmpa_mib_storage_ets}]`.
- **`mib_storage_module() = snmpa_mib_data_ets | snmpa_mib_data_dets | snmpa_mib_data_mnesia | module()`{: #agent_mst_module }** - Defines the mib storage module of the SNMP agent as
defined by the `m:snmpa_mib_storage` behaviour.
Several entities (`mib-server` via the its data module and the
`symbolic-store`) of the snmp agent uses this for storage of miscellaneous mib
related data retrieved while loading a mib.
There are several implementations provided with the agent:
`snmpa_mib_storage_ets`, `snmpa_mib_storage_dets` and
`snmpa_mib_storage_mnesia`.
Default module is `snmpa_mib_storage_ets`.
- **`mib_storage_options() = list() <optional>`{: #agent_mst_options }** - This
is implementation depended. That is, it depends on the module. For each module
a specific set of options are valid. For the module provided with the app,
these options are supported:
- `snmpa_mib_storage_ets`:
`{dir, filename()} | {action, keep | clear}, {checksum, boolean()}`
- `dir` \- If present, points to a directory where a file to which all data
in the ets table is "synced".
Also, when a table is opened this file is read, if it exists.
By default, this will _not_ be used.
- `action` \- Specifies the behaviour when a non-empty file is found: Keep
its content or clear it out.
Default is `keep`.
- `checksum` \- Defines if the file is checksummed or not.
Default is `false`.
- `snmpa_mib_storage_dets`:
`{dir, filename()} | {action, keep | clear}, {auto_save, default | pos_integer()} | {repair, force | boolean()}`
- `dir` \- This _mandatory_ option points to a directory where to place the
file of a dets table.
- `action` \- Specifies the behaviour when a non-empty file is found: Keep
its content or clear it out.
Default is `keep`.
- `auto_save` \- Defines the dets auto-save frequency.
Default is `default`.
- `repair` \- Defines the dets repair behaviour.
Default is `false`.
- `snmpa_mib_storage_mnesia`: `{action, keep | clear}, {nodes, [node()]}`
- `action` \- Specifies the behaviour when a non-empty, already existing,
table: Keep its content or clear it out.
Default is `keep`.
- `nodes` \- A list of node names (or an atom describing a list of nodes)
defining where to open the table. Its up to the user to ensure that mnesia
is actually running on the specified nodes.
The following distinct values are recognised:
- `[]` \- Translated into a list of the own node: `[node()]`
- `all` \- `erlang:nodes()`
- `visible` \- `erlang:nodes(visible)`
- `connected` \- `erlang:nodes(connected)`
- `db_nodes` \- `mnesia:system_info(db_nodes)`
Default is the result of the call: `erlang:nodes()`.
- **`mib_server() = [mib_server_opt()] <optional>`{: #agent_mib_server }** -
`mib_server_opt() = {mibentry_override, mibentry_override()} | {trapentry_override, trapentry_override()} | {verbosity, verbosity()} | {cache, mibs_cache()} | {data_module, mib_server_data_module()}`
Defines options specific for the SNMP agent mib server.
For defaults see the options in `mib_server_opt()`.
- **`mibentry_override() = bool() <optional>`{: #agent_ms_meo }** - If this
value is false, then when loading a mib each mib- entry is checked prior to
installation of the mib. The purpose of the check is to prevent that the same
symbolic mibentry name is used for different oid's.
Default is `false`.
- **`trapentry_override() = bool() <optional>`{: #agent_ms_teo }** - If this
value is false, then when loading a mib each trap is checked prior to
installation of the mib. The purpose of the check is to prevent that the same
symbolic trap name is used for different trap's.
Default is `false`.
- **`mib_server_data_module() = snmpa_mib_data_tttn | module() <optional>`{: #agent_ms_data_module }** - Defines the backend data module of the SNMP agent
mib-server as defined by the `m:snmpa_mib_data` behaviour.
At present only the default module is provided with the agent,
`snmpa_mib_data_tttn`.
Default module is `snmpa_mib_data_tttn`.
- **`mibs_cache() = bool() | mibs_cache_opts() <optional>`{: #agent_ms_cache }** - Shall the agent utilize the mib server lookup cache or not.
Default is `true` (in which case the `mibs_cache_opts()` default values
apply).
- **`mibs_cache_opts() = [mibs_cache_opt()] <optional>`{: #agent_ms_cache_opts }** -
`mibs_cache_opt() = {autogc, mibs_cache_autogc()} | {gclimit, mibs_cache_gclimit()} | {age, mibs_cache_age()}`
Defines options specific for the SNMP agent mib server cache.
For defaults see the options in `mibs_cache_opt()`.
- **`mibs_cache_autogc() = bool() <optional>`{: #agent_ms_cache_autogc }** -
Defines if the mib server shall perform cache gc automatically or leave it to
the user (see [gc_mibs_cache/0,1,2,3](`snmpa:gc_mibs_cache/0`)).
Default is `true`.
- **`mibs_cache_age() = integer() > 0 <optional>`{: #agent_ms_cache_age }** -
Defines how old the entries in the cache will be allowed to become before they
are GC'ed (assuming GC is performed). Each entry in the cache is "touched"
whenever it is accessed.
The age is defined in milliseconds.
Default is `10 timutes`.
- **`mibs_cache_gclimit() = infinity | integer() > 0 <optional>`{: #agent_ms_cache_gclimit }** - When performing a GC, this is the max number of
cache entries that will be deleted from the cache.
The reason why its possible to set a limit, is that if the cache is large, the
GC can potentially take a long time, during which the agent is "busy". _But_
on a heavily loaded system, we also risk not removing enough elements in the
cache, instead causing it to grow over time. This is the reason the default
value is `infinity`, which will ensure that _all_ candidates are removed as
soon as possible.
Default is `infinity`.
- **`error_report_mod() = atom() <optional>`{: #agent_error_report_mod }** -
Defines an error report module, implementing the `m:snmpa_error_report`
behaviour. Two modules are provided with the toolkit: `snmpa_error_logger` and
`snmpa_error_io`.
Default is `snmpa_error_logger`.
- **`symbolic_store() = [symbolic_store_opt()]`{: #agent_symbolic_store }** -
`symbolic_store_opt() = {verbosity, verbosity()}`
Defines options specific for the SNMP agent symbolic store.
For defaults see the options in `symbolic_store_opt()`.
- **`target_cache() = [target_cache_opt()]`{: #agent_target_cache }** -
`target_cache_opt() = {verbosity, verbosity()}`
Defines options specific for the SNMP agent target cache.
For defaults see the options in `target_cache_opt()`.
- **`agent_config() = [agent_config_opt()] <mandatory>`{: #agent_config }** -
`agent_config_opt() = {dir, agent_config_dir()} | {force_load, force_load()} | {verbosity, verbosity()}`
Defines specific config related options for the SNMP agent.
For defaults see the options in `agent_config_opt()`.
- **`agent_config_dir = dir() <mandatory>`{: #agent_config_dir }** - Defines
where the SNMP agent configuration files are stored.
- **`force_load() = bool() <optional>`{: #agent_force_load }** - If `true` the
configuration files are re-read during start-up, and the contents of the
configuration database ignored. Thus, if `true`, changes to the configuration
database are lost upon reboot of the agent.
Default is `false`.
[](){: #manager_opts_and_types }
Manager specific config options and types:
- **`server() = [server_opt()] <optional>`{: #manager_server }** -
`server_opt() = {timeout, server_timeout()} | {verbosity, verbosity()} | {cbproxy, server_cbproxy()} | {netif_sup, server_nis()}`
Specifies the options for the manager server process.
Default is `silence`.
- **`server_timeout() = integer() <optional>`{: #manager_server_timeout }** -
Asynchronous request cleanup time. For every requests, some info is stored
internally, in order to be able to deliver the reply (when it arrives) to the
proper destination. If the reply arrives, this info will be deleted. But if
there is no reply (in time), the info has to be deleted after the _best
before_ time has been passed. This cleanup will be performed at regular
intervals, defined by the `server_timeout()` time. The information will have
an _best before_ time, defined by the `Expire` time given when calling the
request function (see [async_get](`snmpm:async_get2/4`),
[async_get_next](`snmpm:async_get_next2/4`) and
[async_set](`snmpm:async_set2/4`)).
Time in milli-seconds.
Default is `30000`.
- **`server_cbproxy() = temporary (default) | permanent <optional>`{: #manager_server_cbproxy }** - This option specifies how the server will handle
callback calls.
- **`temporary (default)`{: #manager_server_cbproxy_temporary }** - A
temporary process will be created for each callback call.
- **`permanent`{: #manager_server_cbproxy_permanent }** - With this the server
will create a permanent (named) process that in effect serializes all
callback calls.
Default is `temporary`.
- **`server_nis() = none (default) | {PingTO, PongTO} <optional>`{: #manager_server_nis }** - This option specifies if the server should actively
supervise the net-if process. Note that this will only work if the used net-if
process actually supports the protocol. See `m:snmpm_network_interface`
behaviour for more info.
- **`none (default)`{: #manager_server_nis_none }** - No active supervision of
the net-if process.
- **`{PingTO :: pos_integer(), PongTO :: pos_integer()}`{: #manager_server_nis_active }** - The `PingTO` time specifies the between a
successful ping (or start) and the time when a ping message is to be sent to
the net-if process (basically the time between ping).
The `PongTO` time specifies how long time the net-if process has to respond
to a ping message, with a _pong_ message. Its starts counting when the ping
message has been sent.
Both times are in milli seconds.
Default is `none`.
- **`manager_config() = [manager_config_opt()] <mandatory>`{: #manager_config }** -
`manager_config_opt() = {dir, manager_config_dir()} | {db_dir, manager_db_dir()} | {db_init_error, db_init_error()} | {repair, manager_repair()} | {auto_save, manager_auto_save()} | {verbosity, verbosity()}`
Defines specific config related options for the SNMP manager.
For defaults see the options in `manager_config_opt()`.
- **`manager_config_dir = dir() <mandatory>`{: #manager_config_dir }** - Defines
where the SNMP manager configuration files are stored.
- **`manager_db_dir = dir() <mandatory>`{: #manager_config_db_dir }** - Defines
where the SNMP manager store persistent data.
- **`manager_repair() = false | true | force <optional>`{: #manager_config_repair }** - Defines the repair option for the persistent
database (if and how the table is repaired when opened).
Default is `true`.
- **`manager_auto_save() = integer() | infinity <optional>`{: #manager_config_auto_save }** - The auto save interval. The table is flushed
to disk whenever not accessed for this amount of time.
Default is `5000`.
- **`manager_irb() = auto | user | {user, integer()} <optional>`{: #manager_irb }** - This option defines how the manager will handle the sending of response
(acknowledgment) to received inform-requests.
- `auto` \- The manager will autonomously send response (acknowledgment> to
inform-request messages.
- `{user, integer()}` \- The manager will send response (acknowledgment) to
inform-request messages when the
[handle_inform](`c:snmpm_user:handle_inform/3`) function completes. The
integer is the time, in milli-seconds, that the manager will consider the
stored inform-request info valid.
- `user` \- Same as `{user, integer()}`, except that the default time, 15
seconds (15000), is used.
See `m:snmpm_network_interface`, [handle_inform](`m:snmpm_user`) and
[definition of the manager net if](snmp_manager_netif.md) for more info.
Default is `auto`.
- **`manager_mibs() = [string()] <optional>`{: #manager_mibs }** - Specifies a
list of MIBs (including path) and defines which MIBs are initially loaded into
the SNMP manager.
Default is `[]`.
- **`manager_net_if() = [manager_net_if_opt()] <optional>`{: #manager_net_if }** -
`manager_net_if_opt() = {module, manager_net_if_module()} | {verbosity, verbosity()} | {options, manager_net_if_options()}`
Defines options specific for the SNMP manager network interface entity.
For defaults see the options in `manager_net_if_opt()`.
- **`manager_net_if_options() = [manager_net_if_option()] <optional>`{: #manager_ni_opts }** -
`manager_net_if_option() = {bind_to, bind_to()} | {sndbuf, sndbuf()} | {recbuf, recbuf()} | {no_reuse, no_reuse()} | {filter, manager_net_if_filter_options()} | {extra_sock_opts, extra_socket_options()}} | {inet_backend, inet_backend()}`
These options are actually specific to the used module. The ones shown here
are applicable to the default `manager_net_if_module()`.
For defaults see the options in `manager_net_if_option()`.
- **`manager_net_if_module() = atom() <optional>`{: #manager_ni_module }** - The
module which handles the network interface part for the SNMP manager. It must
implement the `m:snmpm_network_interface` behaviour.
Default is `snmpm_net_if`.
- **`manager_net_if_filter_options() = [manager_net_if_filter_option()] <optional>`{: #manager_ni_filter_opts }** -
`manager_net_if_filter_option() = {module, manager_net_if_filter_module()}`
These options are actually specific to the used module. The ones shown here
are applicable to the default `manager_net_if_filter_module()`.
For defaults see the options in `manager_net_if_filter_option()`.
- **`manager_net_if_filter_module() = atom() <optional>`{: #manager_ni_filter_module }** - Module which handles the network interface
filter part for the SNMP manager. Must implement the
`m:snmpm_network_interface_filter` behaviour.
Default is `snmpm_net_if_filter`.
- **`def_user_module() = atom() <optional>`{: #manager_def_user_module }** - The
module implementing the default user. See the `m:snmpm_user` behaviour.
Default is `snmpm_user_default`.
- **`def_user_data() = term() <optional>`{: #manager_def_user_data }** - Data
for the default user. Passed to the user module when calling the callback
functions.
Default is `undefined`.
[](){: #common_types }
Common config types:
- **`restart_type() = permanent | transient | temporary`{: #restart_type }** -
See [supervisor](`m:supervisor#child_spec`) documentation for more info.
Default is `permanent` for the agent and `transient` for the manager.
- **`db_init_error() = terminate | create | create_db_and_dir`{: #db_init_error }** - Defines what to do if the agent or manager is unable to open an existing
database file. `terminate` means that the agent/manager will terminate and
`create` means that the agent/manager will remove the faulty file(s) and
create new ones, and `create_db_and_dir` means that the agent/manager will
create the database file along with any missing parent directories for the
database file.
Default is `terminate`.
- **`priority() = atom() <optional>`{: #prio }** - Defines the Erlang priority
for all SNMP processes.
Default is `normal`.
- **`versions() = [version()] <optional>`{: #versions }** -
`version() = v1 | v2 | v3`
Which SNMP versions shall be accepted/used.
Default is `[v1,v2,v3]`.
- **`verbosity() = silence | info | log | debug | trace <optional>`{: #verbosity }** - Verbosity for a SNMP process. This specifies now much debug info is
printed.
Default is `silence`.
- **`bind_to() = bool() <optional>`{: #bind_to }** - If `true`, net_if binds to
the IP address. If `false`, net_if listens on any IP address on the host where
it is running.
Default is `false`.
- **`no_reuse() = bool() <optional>`{: #no_reuse }** - If `true`, net_if does
not specify that the IP and port address should be reusable. If `false`, the
address is set to reusable.
Default is `false`.
- **`recbuf() = integer() <optional>`{: #recbuf }** - Receive buffer size.
Default value is defined by `gen_udp`.
- **`sndbuf() = integer() <optional>`{: #sndbuf }** - Send buffer size.
Default value is defined by `gen_udp`.
- **`extra_socket_options() = list() <optional>`{: #extra_sock_opts }** - A list
of arbitrary socket options.
This list is not inspected by snmp (other then checking that its a list). Its
the users responsibility to ensure that these are valid options and does not
conflict with the "normal" options.
Default is `[]`.
- **`inet_backend() = inet | socket <optional>`{: #inet_backend }** - Choose the
inet-backend.
This option make it possible to use net_if (gen_udp) with a different
inet-backend ('inet' or 'socket').
Default is `inet`.
- **`note_store() = [note_store_opt()] <optional>`{: #note_store }** -
`note_store_opt() = {timeout, note_store_timeout()} | {verbosity, verbosity()}`
Specifies the start-up verbosity for the SNMP note store.
For defaults see the options in `note_store_opt()`.
- **`note_store_timeout() = integer() <optional>`{: #ns_timeout }** - Note
cleanup time. When storing a note in the note store, each note is given
lifetime. Every `timeout` the note_store process performs a GC to remove the
expired note's. Time in milli-seconds.
Default is `30000`.
- **`audit_trail_log() = [audit_trail_log_opt()] <optional>`{: #audit_trail_log }** -
`audit_trail_log_opt() = {type, atl_type()} | {dir, atl_dir()} | {size, atl_size()} | {repair, atl_repair()} | {seqno, atl_seqno()}`
If present, this option specifies the options for the audit trail logging. The
`disk_log` module is used to maintain a wrap log. If present, the `dir` and
`size` options are mandatory.
If not present, audit trail logging is not used.
- **`atl_type() = read | write | read_write <optional>`{: #atl_type }** -
Specifies what type of an audit trail log should be used. The effect of the
type is actually different for the the agent and the manager.
For the agent:
- If `write` is specified, only set requests are logged.
- If `read` is specified, only get requests are logged.
- If `read_write`, all requests are logged.
For the manager:
- If `write` is specified, only sent messages are logged.
- If `read` is specified, only received messages are logged.
- If `read_write`, both outgoing and incoming messages are logged.
Default is `read_write`.
- **`atl_dir = dir() <mandatory>`{: #atl_dir }** - Specifies where the audit
trail log should be stored.
If `audit_trail_log` specifies that logging should take place, this parameter
_must_ be defined.
- **`atl_size() = {integer(), integer()} <mandatory>`{: #atl_size }** -
Specifies the size of the audit trail log. This parameter is sent to
`disk_log`.
If `audit_trail_log` specifies that logging should take place, this parameter
_must_ be defined.
- **`atl_repair() = true | false | truncate | snmp_repair <optional>`{: #atl_repair }** - Specifies if and how the audit trail log shall be repaired
when opened. Unless this parameter has the value `snmp_repair` it is sent to
`disk_log`. If, on the other hand, the value is `snmp_repair`, snmp attempts
to handle certain faults on its own. And even if it cannot repair the file, it
does not truncate it directly, but instead _moves it aside_ for later off-line
analysis.
Default is `true`.
- **`atl_seqno() = true | false <optional>`{: #atl_seqno }** - Specifies if the
audit trail log entries will be (sequence) numbered or not. The range of the
sequence numbers are according to RFC 5424, i.e. 1 through 2147483647.
Default is `false`.
## See Also
application(3), disk_log(3)
|