HPE Networking Comware 5120v3 Switch Series Telemetry Configuration Guide

  • Hello! I've reviewed the Telemetry Configuration Guide for the HPE Networking Comware 5120v3 Switch Series. This document describes how to configure telemetry using gRPC, and push data to collectors, and explains both dial-in and dial-out connection modes. I'm familiar with sensor, collector, and subscription configuration details, and I can help you with any questions about using protocol buffers for data encoding. Please feel free to ask any questions you might have regarding the switch configuration or telemetry setup.
  • What is gRPC?
    What are the telemetry modes supported?
    What is the default port for the gRPC service?
    What kind of data sampling types are supported?
HPE Networking Comware
5120v3 Switch
Series
Telemetry Configuration Guide
Software
version: Release 6352P02 and later
Document version: 6W100-20230715
© Copyright 2023 Hewlett Packard Enterprise Development LP
The information contained herein is subject to change without notice. The only warranties for Hewlett Packard
Enterprise products and services are set forth in the express warranty statements accompanying such
products and services. Nothing herein should be construed as constituting an additional warranty. Hewlett
Packard Enterprise shall not be liable for technical or editorial errors or omissions contained herein.
Confidential computer software. Valid license from Hewlett Packard Enterprise required for possession, use, or
copying. Consistent with FAR 12.211 and 12.212, Commercial Computer Software, Computer Software
Documentation, and Technical Data for Commercial Items are licensed to the U.S. Government under vendor’s
standard commercial license.
Links to third-party websites take you outside the Hewlett Packard Enterprise website. Hewlett Packard
Enterprise has no control over and is not responsible for information outside the Hewlett Packard Enterprise
website.
Acknowledgments
Intel®, Itanium®, Pentium®, Intel Inside®, and the Intel Inside logo are trademarks of Intel Corporation in the
United States and other countries.
Microsoft® and Windows® are either registered trademarks or trademarks of Microsoft Corporation in the
United States and/or other countries.
Adobe® and Acrobat® are trademarks of Adobe Systems Incorporated.
Java and Oracle are registered trademarks of Oracle and/or its affiliates.
UNIX® is a registered trademark of The Open Group.
i
Contents
Configuring gRPC ·························································································· 1
About gRPC ······················································································································································· 1
gRPC protocol stack layers ························································································································ 1
Network architecture ·································································································································· 1
Telemetry technology based on gRPC ······································································································ 1
Telemetry modes ······································································································································· 2
Protocols ···················································································································································· 2
FIPS compliance ················································································································································ 2
Prerequisites for gRPC ······································································································································ 2
Configuring the gRPC dial-in mode···················································································································· 2
gRPC dial-in mode configuration tasks at a glance ··················································································· 2
Configuring the gRPC service ···················································································································· 3
Configuring a gRPC user ··························································································································· 3
Configuring the gRPC dial-out mode ················································································································· 4
gRPC dial-out mode configuration tasks at a glance ················································································· 4
Enabling the gRPC service ························································································································ 4
Configuring sensors ··································································································································· 4
Configuring collectors ································································································································· 5
Configuring a subscription ·························································································································· 6
Display and maintenance commands for gRPC ································································································ 6
gRPC configuration examples ··························································································································· 6
Example: Configuring the gRPC dial-in mode ···························································································· 7
Example: Configuring the gRPC dial-out mode ························································································· 8
Protocol buffer code ····················································································· 10
Protocol buffer code format ······························································································································ 10
Proto definition files ·································································································································· 11
Proto definition files in dial-in mode ········································································································· 11
Proto definition file in dial-out mode ········································································································· 12
Obtaining proto definition files ·················································································································· 13
Example: Developing a gRPC collector-side application ················································································· 13
Prerequisites ············································································································································ 13
Generating the C++ code for the proto definition files·············································································· 14
Developing the collector-side application ································································································· 14
Document conventions and icons ································································ 19
Conventions ····················································································································································· 19
Network topology icons ···································································································································· 20
Support and other resources ······································································· 20
Accessing Hewlett Packard Enterprise Support······························································································· 20
Accessing updates ··········································································································································· 21
Websites ·················································································································································· 21
Customer self repair ································································································································· 22
Remote support ········································································································································ 22
Documentation feedback ························································································································· 22
Index ············································································································ 24
1
Configuring gRPC
About gRPC
gRPC is an open source remote procedure call (RPC) system initially developed at Google. It uses
HTTP 2.0 for transport and provides network device configuration and management methods that
support multiple programming languages.
gRPC protocol stack layers
Table 1 describes the gRPC protocol stack layers.
Table 1 gRPC protocol stack layers
Layer
Description
Content layer Defines the data of the service module.
Two peers must notify each other of the data models that they are using.
Protocol buffer encoding layer Encodes data by using the protocol buffer code format.
gRPC layer Defines the protocol interaction format for remote procedure calls.
HTTP 2.0 layer Carries gRPC.
TCP layer Provides connection-oriented reliable data links.
Network architecture
As shown in Figure 1, the gRPC network uses the client/server model. It uses HTTP 2.0 for packet
transport.
Figure 1 gRPC network architecture
The gRPC network uses the following mechanism:
1. The gRPC server listens to connection requests from clients at the gRPC service port.
2. A user runs the gRPC client application to log in to the gRPC server, and uses methods
provided in the .proto file to send requests.
3. The gRPC server responds to requests from the gRPC client.
The device can act as the gRPC server or client.
Telemetry technology based on gRPC
Telemetry is a remote data collection technology for monitoring device performance and operating
status. Telemetry technology uses gRPC to push data from the device to the collectors on the NMSs.
As shown in Figure 2, after a gRPC connection is established between the device and NMSs, the
NMSs can subscribe to data of modules on the device.
gRPC server gRPC client
HTTP 2.0
2
Figure 2 Telemetry technology based on gRPC
Telemetry modes
The device supports the following telemetry modes:
Dial-in modeThe device acts as a gRPC server and the collectors act as gRPC clients. A
collector initiates a gRPC connection to the device to subscribe to device data.
Dial-in mode applies to small networks where collectors need to deploy configurations to
devices.
Dial-out modeThe device acts as a gRPC client and the collectors act as gRPC servers. The
device initiates a gRPC connection to the collectors and pushes subscribed device data to the
collectors.
Dial-out mode applies to larger networks where devices need to push device data to collectors.
Protocols
RFC 7540, Hypertext Transfer Protocol version 2 (HTTP/2)
FIPS compliance
The device supports the FIPS mode that complies with NIST FIPS 140-2 requirements. Support for
features, commands, and parameters might differ in FIPS mode and non-FIPS mode. For more
information about FIPS mode, see Security Configuration Guide.
gRPC is not supported in FIPS mode.
Prerequisites for gRPC
Before you can configure gRPC, you must install a gRPC feature software image compatible with the
device software version. For information about the installation procedure, see software upgrade in
Fundamentals Configuration Guide.
Configuring the gRPC dial-in mode
gRPC dial-in mode configuration tasks at a glance
To configure the gRPC dial-in mode, perform the following tasks:
1. Configuring the gRPC service
2. Configuring a gRPC user
Device
IP network
3
Configuring the gRPC service
Restrictions and guidelines
If the gRPC service fails to be enabled, use the display tcp or display ipv6 tcp command
to verify whether the gRPC service port number has been used by another feature. If yes, specify a
free port as the gRPC service port number and try to enable the gRPC service again. For more
information about the display tcp and display ipv6 tcp commands, see Layer 3IP
Services Command Reference.
Procedure
1. Enter system view.
system-view
2. (Optional.) Set the gRPC service port number.
grpc port port-number
By default, the gRPC service port number is 50051.
Changing the gRPC service port number when the gRPC service is enabled reboots the gRPC
service and closes gRPC connections to gRPC clients. The gRPC clients must re-initiate the
connections.
3. Enable the gRPC service.
grpc enable
By default, the gRPC service is disabled.
4. (Optional.) Set the gRPC session idle timeout timer.
grpc idle-timeout minutes
By default, the gRPC session idle timeout timer is 5 minutes.
Configuring a gRPC user
About gRPC users
For gRPC clients to establish gRPC sessions with the device, you must configure local users for the
gRPC clients.
Procedure
1. Enter system view.
system-view
2. Add a local user with the device management right.
local-user user-name [ class manage ]
3. Configure a password for the user.
password [ { hash | simple } password ]
By default, no password is configured for a local user. A non-password-protected user can pass
authentication after providing the correct username and passing attribute checks.
4. Assign user role network-admin to the user.
authorization-attribute user-role user-role
By default, a local user is assigned the network-operator role.
5. Authorize the user to use the HTTPS service.
service-type https
By default, no service types are authorized to a local user.
4
For more information about the local-user, password, authorization-attribute, and
service-type commands, see AAA configuration in Security Command Reference.
Configuring the gRPC dial-out mode
gRPC dial-out mode configuration tasks at a glance
To configure the gRPC dial-out mode, perform the following tasks:
1. Enabling the gRPC service
2. Configuring sensors
3. Configuring collectors
4. Configuring a subscription
Enabling the gRPC service
1. Enter system view.
system-view
2. Enable the gRPC service.
grpc enable
By default, the gRPC service is disabled.
Configuring sensors
About sensors
The device uses sensors to sample data. A sensor path indicates a data source.
Supported data sampling types include:
Event-triggered samplingSensors in a sensor group sample data when certain events
occur. For sensor paths of this data sampling type, see NETCONF XML API Event Reference
for the module.
Periodic samplingSensors in a sensor group sample data at intervals. For sensor paths of
this data sampling type, see the NETCONF XML API references for the module except for
NETCONF XML API Event Reference.
Procedure
1. Enter system view.
system-view
2. Enter telemetry view.
telemetry
3. Create a sensor group and enter sensor group view.
sensor-group group-name
4. Specify a sensor path.
sensor path path
To specify multiple sensor paths, execute this command multiple times.
5
Configuring collectors
About collectors
Collectors are used to receive sampled data from network devices. For the device to communicate
with collectors, you must create a destination group and add collectors to the destination group.
You can add collectors to a destination group by their IP addresses. You can also add collectors to a
destination group also by their domain names. When you specify collectors by their domain names,
use the following restrictions and guidelines:
You must configure DNS to make sure the device can translate the domain names of the
collectors to IP addresses. For more information about DNS, see Layer 3IP Services
Configuration Guide.
To view domain name and IP address mappings, use the display dns host command. If a
domain name maps to multiple IP addresses, the device pushes data to the first reachable IP
address.
Restrictions and guidelines
As a best practice, configure a maximum of five destination groups. If you configure too many
destination groups, system performance might degrade.
Procedure
1. Enter system view.
system-view
2. Enter telemetry view.
telemetry
3. Create a destination group and enter destination group view.
destination-group group-name
4. Specify a collector.
IPv4:
ipv4-address ipv4-address [ port port-number ]
IPv6:
ipv6-address ipv6-address [ port port-number ]
To add multiple collectors, repeat this command. A collector is uniquely identified by a
three-tuple of IP address, port number, and VPN instance name. One collector must have a
different IP address, port number, or VPN instance name than the other collectors in the
destination group.
5. Add a collector to the destination group by its domain name.
IPv4:
domain-name domain-name [ port port-number ] [ vpn-instance
vpn-instance-name ]
IPv6:
ipv6 domain-name domain-name [ port port-number ] [ vpn-instance
vpn-instance-name ]
To add multiple collectors, repeat this command. A collector is uniquely identified by a
three-tuple of domain name, port number, and VPN instance name. One collector must have a
different domain name, port number, or VPN instance name than the other collectors in the
destination group.
6
Configuring a subscription
About configuring a subscription
A subscription binds sensor groups to destination groups. Then, the device pushes data from the
specified sensors to the collectors.
Procedure
1. Enter system view.
system-view
2. Enter telemetry view.
telemetry
3. Create a subscription and enter subscription view.
subscription subscription-name
4. (Optional.) Specify the source IP address for packets sent to collectors.
source-address { ipv4-address | interface interface-type
interface-number | ipv6 ipv6-address }
By default, the device uses the primary IPv4 address of the output interface for the route to the
collectors as the source address.
Changing the source IP address for packets sent to collectors causes the device to re-establish
the connection to the gRPC server.
5. Specify a sensor group.
sensor-group group-name [ sample-interval interval ]
Specify the sample-interval interval option for periodic sensor paths and only for
periodic sensor paths.
If you specify the option for event-triggered sensor paths, the sensor paths do not take
effect.
If you do not specify the option for periodic sensor paths, the device does not sample or
push data.
6. Specify a destination group.
destination-group group-name
Display and maintenance commands for gRPC
Execute display commands in any view.
Task
Command
Display gRPC information.
display grpc [ verbose
]
gRPC configuration examples
These configuration examples describe only CLI configuration tasks on the device. The collectors
need to run an extra application. For information about collector-side application development, see
"Developing the collector-side application."
7
Example: Configuring the gRPC dial-in mode
Network configuration
As shown in Figure 3, configure the gRPC dial-in mode on the device so the device acts as the gRPC
server and the gRPC client can subscribe to LLDP events on the device.
Figure 3 Network diagram
Prerequisites
Before you can configure gRPC, you must install a gRPC feature software image compatible with the
device software version. For more information about the installation procedure, see software
upgrade configuration in Fundamentals Configuration Guide.
To install a gRPC feature software image:
1. Download the gRPC feature software image compatible with the device software version from
the website to the root directory of the flash memory on the device. On an IRF fabric, use FTP
or TFTP commands to transfer the image file to the root directory of the default file system on
the master device. (Details not shown.)
2. Install the feature software image on the device and commit the software change. On an IRF
fabric, install the image on each member device. For example, install the image on the member
device with an IRF member ID of 1 for the slot number.
<Device> install activate feature flash:/grpc-01.bin slot 1
Verifying the file flash:/grpc-01.bin on slot 1....Done.
Identifying the upgrade methods....Done.
Upgrade summary according to following table:
flash:/grpc-01.bin
Running Version New Version
None Demo 01
Slot Upgrade Way
1 Service Upgrade
Upgrading software images to compatible versions. Continue? [Y/N]:y
This operation might take several minutes, please wait....................Done.
<Device> install commit
This operation will take several minutes, please wait.......................Done.
3. Log in to the device or the IRF fabric again.
Procedure
1. Assign IP addresses to interfaces on the gRPC server and client and configure routes. Make
sure the server and client can reach each other.
2. Configure the device as the gRPC server:
# Enable the gRPC service.
<Device> system-view
[Device] grpc enable
# Create a local user named test. Set the password to test, and assign user role network-admin
and the HTTPS service to the user.
[Device] local-user test
8
[Device-luser-manage-test] password simple test
[Device-luser-manage-test] authorization-attribute user-role network-admin
[Device-luser-manage-test] service-type https
[Device-luser-manage-test] quit
3. Configure the gRPC client.
a. Prepare a PC and install the gRPC environment on the PC. For more information, see the
user guide for the gRPC environment.
b. Obtain the proto definition file and uses the protocol buffer compiler to generate code of a
specific language, for example, Java, Python, C/C++, or Go.
c. Create a client application to call the generated code.
d. Start the application to log in to the gRPC server.
Verifying the configuration
When an LLDP event occurs on the gRPC server, verify that the gRPC client receives the event.
Example: Configuring the gRPC dial-out mode
Network configuration
As shown in Figure 4, the device is connected to a collector. The collector uses port 50050.
Configure gRPC dial-out mode on the device so the device pushes the device capability information
of its interface module to the collector at 10-second intervals.
Figure 4 Network diagram
Prerequisites
Before you can configure gRPC, you must install a gRPC feature software image compatible with the
device software version. For more information about the installation procedure, see software
upgrade configuration in Fundamentals Configuration Guide.
To install a gRPC feature software image:
1. Download the gRPC feature software image compatible with the device software version from
the website to the root directory of the flash memory on the device. On an IRF fabric, use FTP or
TFTP commands to transfer the image file or patch to the root directory of the default file system
on the master device. (Details not shown.)
2. Install the feature software image on the device and commit the software change. On an IRF
fabric, install the image on each member device. For example, install the image on the member
device with an IRF member ID of 1 for the slot number.
<Device> install activate feature flash:/grpc-01.bin slot 1
Verifying the file flash:/grpc-01.bin on slot 1....Done.
Identifying the upgrade methods....Done.
Upgrade summary according to following table:
flash:/grpc-01.bin
Running Version New Version
None Demo 01
Slot Upgrade Way
192.168.1.1 192.168.2.1
Device
(gRPC client) Collector
(gRPC server)
9
1 Service Upgrade
Upgrading software images to compatible versions. Continue? [Y/N]:y
This operation might take several minutes, please wait....................Done.
<Device> install commit
This operation will take several minutes, please wait.......................Done.
3. Log in to the device or the IRF fabric again.
Procedure
# Configure IP addresses as required so the device and the collector can reach each other. (Details
not shown.)
# Enable the gRPC service.
<Device> system-view
[Device] grpc enable
# Create a sensor group named test, and add sensor path ifmgr/devicecapabilities/.
[Device] telemetry
[Device-telemetry] sensor-group test
[Device-telemetry-sensor-group-test] sensor path ifmgr/devicecapabilities/
[Device-telemetry-sensor-group-test] quit
# Create a destination group named collector1. Specify a collector that uses IPv4 address
192.168.2.1 and port number 50050.
[Device-telemetry] destination-group collector1
[Device-telemetry-destination-group-collector1] ipv4-address 192.168.2.1 port 50050
[Device-telemetry-destination-group-collector1] quit
# Configure a subscription named A to bind sensor group test with destination group collector1. Set
the sampling interval to 10 seconds.
[Device-telemetry] subscription A
[Device-telemetry-subscription-A] sensor-group test sample-interval 10
[Device-telemetry-subscription-A] destination-group collector1
[Device-telemetry-subscription-A] quit
Verifying the configuration
# Verify that the collector receives the device capability information of the interface module from the
device at 10-second intervals. (Details not shown.)
10
Protocol buffer code
Protocol buffer code format
Google Protocol Buffers provide a flexible mechanism for serializing structured data. Different from
XML code and JSON code, the protocol buffer code is binary and provides higher performance.
Table 2 compares a protocol buffer code format example and the corresponding JSON code format
example.
Table 2 Protocol buffer and JSON code format examples
Protocol buffer code format example
Corresponding JSON code format example
{
1:HPE
2:“HPE”
3:“HPE Simware”
4:Syslog/LogBuffer
5:"notification": {
"Syslog": {
"LogBuffer": {
"BufferSize": 512,
"BufferSizeLimit": 1024,
"DroppedLogsCount": 0,
"LogsCount": 100,
"LogsCountPerSeverity": {
"Alert": 0,
"Critical": 1,
"Debug": 0,
"Emergency": 0,
"Error": 3,
"Informational": 80,
"Notice": 15,
"Warning": 1
},
"OverwrittenLogsCount": 0,
"State": "enable"
}
},
"Timestamp": "1527206160022"
}
}
{
"producerName": "HPE",
"deviceName": "HPE",
"deviceModel": "HPE Simware",
"sensorPath": "Syslog/LogBuffer",
"jsonData": {
"notification": {
"Syslog": {
"LogBuffer": {
"BufferSize": 512,
"BufferSizeLimit": 1024,
"DroppedLogsCount": 0,
"LogsCount": 100,
"LogsCountPerSeverity": {
"Alert": 0,
"Critical": 1,
"Debug": 0,
"Emergency": 0,
"Error": 3,
"Informational": 80,
"Notice": 15,
"Warning": 1
},
"OverwrittenLogsCount": 0,
"State": "enable"
}
},
"Timestamp": "1527206160022"
}
}
}
11
Proto definition files
You can define data structures in a proto definition file. Then, you can compile the file with utility
protoc to generate code in a programing language such as Java and C++. Using the generated code,
you can develop an application for a collector to communicate with the device.
HPE provides proto definition files for both dial-in mode and dial-out mode.
Proto definition files in dial-in mode
Public proto definition files
The grpc_service.proto file defines the public RPC methods in dial-in mode, for example, login
method and logout method.
The following are the contents of the grpc_service.proto file:
syntax = "proto2";
package grpc_service;
message GetJsonReply { // Reply to the Get method
required string result = 1;
}
message SubscribeReply { // Subscription result
required string result = 1;
}
message ConfigReply { // Configuration result
required string result = 1;
}
message ReportEvent { // Subscribed event
required string token_id = 1; // Login token_id
required string stream_name = 2; // Event stream name
required string event_name = 3; // Event name
required string json_text = 4; // Subscription result, a JSON string
}
message GetReportRequest{ // Obtains the event subscription result
required string token_id = 1; // Returns the token_id upon a successful login
}
message LoginRequest { // Login request parameters
required string user_name = 1; // Username
required string password = 2; // Password
}
message LoginReply { // Reply to a login request
required string token_id = 1; // Returns the token_id upon a successful login
}
message LogoutRequest { // Logout parameter
required string token_id = 1; // token_id
}
message LogoutReply { // Reply to a logout request
required string result = 1; // Logout result
}
message SubscribeRequest { // Event stream name
required string stream_name = 1;
12
}
service GrpcService { // gRPC methods
rpc Login (LoginRequest) returns (LoginReply) {} // Login method
rpc Logout (LogoutRequest) returns (LogoutReply) {} // Logout method
rpc SubscribeByStreamName (SubscribeRequest) returns (SubscribeReply) {} // Event
subscription method
rpc GetEventReport (GetReportRequest) returns (stream ReportEvent) {} // Method for
obtaining the subscribed event
}
Proto definition files for service modules
The dial-in mode supports proto definition files for the following service modules: Device, Ifmgr,
IPFW, LLDP, and Syslog.
The following are the contents of the Device.proto file, which defines the RPC methods for the
Device module:
syntax = "proto2";
import "grpc_service.proto";
package device;
message DeviceBase { // Structure for obtaining basic device information
optional string HostName = 1; // Device name
optional string HostOid = 2; // sysoid
optional uint32 MaxChassisNum = 3; //Maximum number of chassis
optional uint32 MaxSlotNum = 4; // Maximum number of slots
optional string HostDescription = 5; // Device description
}
message DevicePhysicalEntities { // Structure for obtaining physical entity information
of the device
message Entity {
optional uint32 PhysicalIndex = 1; // Entity index
optional string VendorType = 2; // Vendor type
optional uint32 EntityClass = 3; // Entity class
optional string SoftwareRev = 4; // Software version
optional string SerialNumber = 5; // Serial number
optional string Model = 6; // Model
}
repeated Entity entity = 1;
}
service DeviceService { // RPC methods
rpc GetJsonDeviceBase(DeviceBase) returns (grpc_service.GetJsonReply) {} // Method
for obtaining basic device information
rpc GetJsonDevicePhysicalEntities(DevicePhysicalEntities) returns
(grpc_service.GetJsonReply) {} // Method for obtaining physical entity information of
the device
}
Proto definition file in dial-out mode
The grpc_dialout.proto file defines the public RPC methods in dial-out mode. The following are the
contents of the file:
syntax = "proto2";
13
package grpc_dialout;
message DeviceInfo{ // Pushed device information
required string producerName = 1; // Vendor name
required string deviceName = 2; // Device name
required string deviceModel = 3; // Device model
optional string deviceIpAddr = 4; // Device IP
optional string eventType = 5; // Type of the sensor path
optional string deviceSerialNumber = 6; // Serial number of the device
optional string deviceMac= 7; // Bridge MAC address of the device
}
message DialoutMsg{ // Format of the pushed data
required DeviceInfo deviceMsg = 1; // Device information described by DeviceInfo
required string sensorPath = 2; // Sensor path, which corresponds to xpath in NETCONF
required string jsonData = 3; // Sampled data, a JSON string
}
message DialoutResponse{ // Response from the collector. Reserved. The value is not
processed.
required string response = 1;
}
service gRPCDialout { // Data push method
rpc Dialout(stream DialoutMsg) returns (DialoutResponse);
}
Obtaining proto definition files
Contact the technical support.
Example: Developing a gRPC collector-side
application
Use a language (for example, C++) to develop a gRPC collector-side application on Linux to enable
a collector to collect device data.
Prerequisites
1. Obtain HPE proto definition files.
For dial-in mode, obtain the grpc_service.proto file and proto definition files for service
modules.
For dial-out mode, obtain the grpc_dialout.proto file.
2. Obtain utility protoc from https://github.com/google/protobuf/releases.
3. Obtain the protobuf plug-in for C++ (protobuf-cpp) from
https://github.com/google/protobuf/releases.
14
Generating the C++ code for the proto definition files
Dial-in mode
# Copy the required proto definition files to the current directory, for example, grpc_service.proto
and BufferMonitor.proto.
$protoc --plugin=./grpc_cpp_plugin --grpc_out=. --cpp_out=. *.proto
Dial-out mode
# Copy proto definition file grpc_dialout.proto to the current directory.
$ protoc --plugin=./grpc_cpp_plugin --grpc_out=. --cpp_out=. *.proto
Developing the collector-side application
Dial-in mode
In dial-in mode, the application needs to provide the code to be run on the gRPC client.
The C++ code generated from the proto definition files already encapsulates the service classes,
which are GrpcService and BufferMonitorService in this example. For the gRPC client to initiate RPC
requests, you only need to call the RPC method in the application.
The application performs the following operations:
Log in to obtain the token_id.
Prepare parameters for the RPC method, use the service classes generated from the proto
definition files to call the RPC method, and resolve the returned result.
Log out.
To develop the collector-side application in dial-in mode:
1. Create a GrpcServiceTest class.
# In the class, use the GrpcService::Stub class generated from grpc_service.proto. Implement
login and logout with the Login and Logout methods generated from grpc_service.proto.
class GrpcServiceTest
{
public:
/* Constructor functions */
GrpcServiceTest(std::shared_ptr<Channel> channel):
GrpcServiceStub(GrpcService::NewStub(channel)) {}
/* Member functions */
int Login(const std::string& username, const std::string& password);
void Logout();
void listen();
/* Member variable */
std::string token;
private:
std::unique_ptr<GrpcService::Stub> GrpcServiceStub; // Use the
GrpcService::Stub class generated from grpc_service.proto.
};
2. Customize the Login method.
15
# Call the Login method of the GrpcService::Stub class to allow a user who provides the correct
the username and password to log in.
int GrpcServiceTest::Login(const std::string& username, const std::string& password)
{
LoginRequest request; // Username and password.
request.set_user_name(username);
request.set_password(password);
LoginReply reply;
ClientContext context;
// Call the Login method.
Status status = GrpcServiceStub->Login(&context, request, &reply);
if (status.ok())
{
std::cout << "login ok!" << std::endl;
std::cout <<"token id is :" << reply.token_id() << std::endl;
token = reply.token_id(); // The login succeeds. The token is obtained.
return 0;
}
else{
std::cout << status.error_code() << ": " << status.error_message()
<< ". Login failed!" << std::endl;
return -1;
}
}
3. Initiate an RPC request to the device. In this example, the application subscribes to interface
packet drop events.
rpc SubscribePortQueDropEvent(PortQueDropEvent) returns
(grpc_service.SubscribeReply) {}
4. Create the BufMon_GrpcClient class to encapsulate the RPC method.
# Use the BufferMonitorService::Stub class generated from BufferMonitor.proto to call the RPC
method.
class BufMon_GrpcClient
{
public:
BufMon_GrpcClient(std::shared_ptr<Channel> channel):
mStub(BufferMonitorService::NewStub(channel))
{
}
std::string BufMon_Sub_AllEvent(std::string token);
std::string BufMon_Sub_BoardEvent(std::string token);
std::string BufMon_Sub_PortOverrunEvent(std::string token);
std::string BufMon_Sub_PortDropEvent(std::string token);
/* Get entries */
std::string BufMon_Sub_GetStatistics(std::string token);
std::string BufMon_Sub_GetGlobalCfg(std::string token);
16
std::string BufMon_Sub_GetBoardCfg(std::string token);
std::string BufMon_Sub_GetNodeQueCfg(std::string token);
std::string BufMon_Sub_GetPortQueCfg(std::string token);
private:
std::unique_ptr<BufferMonitorService::Stub> mStub; // Use the class generated
from BufferMonitor.proto.
};
5. Use std::string BufMon_Sub_PortDropEvent(std::string token) to implement interface packet
drop event subscription.
std::string BufMon_GrpcClient::BufMon_Sub_PortDropEvent(std::string token)
{
std::cout << "-------BufMon_Sub_PortDropEvent-------- " << std::endl;
PortQueDropEvent stNodeEvent;
PortQueDropEvent_PortQueDrop* pstParam = stNodeEvent.add_portquedrop();
UINT uiIfIndex = 0;
UINT uiQueIdx = 0;
UINT uiAlarmType = 0;
std::cout<<"Please input interface queue info : ifIndex queIdx alarmtype " <<
std::endl;
cout<<"alarmtype : 1 for ingress; 2 for egress; 3 for port headroom"<<endl;
std::cin>>uiIfIndex>>uiQueIdx>>uiAlarmType; // Set the subscription parameters
and interface index.
pstParam->set_ifindex(uiIfIndex);
pstParam->set_queindex(uiQueIdx);
pstParam->set_alarmtype(uiAlarmType);
ClientContext context;
/* Token needs to be added to context */ // Set the token_id to be returned after
a successful login
std::string key = "token_id";
std::string value = token;
context.AddMetadata(key, value);
SubscribeReply reply;
Status status = mStub->SubscribePortQueDropEvent(&context,stNodeEvent,&reply);
// Call the RPC method.
return reply.result();
}
6. Use a loop to listen to event reports.
# Implement this method in the GrpcServiceTest class.
void GrpcServiceTest::listen()
{
17
GetReportRequest reportRequest;
ClientContext context;
ReportEvent reportedEvent;
/* Add the token to the request */
reportRequest.set_token_id(token);
std::unique_ptr< ClientReader< ReportEvent>>
reader(GrpcServiceStub->GetEventReport(&context, reportRequest)); // Use
GetEventReport (which is generated from grpc_service.proto) to obtain event
information.
std::string streamName;
std::string eventName;
std::string jsonText;
std::string token;
JsonFormatTool jsonTool;
std::cout << "Listen to server for Event" << std::endl;
while(reader->Read(&reportedEvent) ) // Read the received event report.
{
streamName = reportedEvent.stream_name();
eventName = reportedEvent.event_name();
jsonText = reportedEvent.json_text();
token = reportedEvent.token_id();
std::cout << "/**********************EVENT COME************************/"
<< std::endl;
std::cout << "TOKEN: " << token << std::endl;
std::cout << "StreamName: "<< streamName << std::endl;
std::cout << "EventName: " << eventName << std::endl;
std::cout << "JsonText without format: " << std::endl << jsonText << std::endl;
std::cout << std::endl;
std::cout << "JsonText Formated: " << jsonTool.formatJson(jsonText) <<
std::endl;
std::cout << std::endl;
}
Status status = reader->Finish();
std::cout << "Status Message:" << status.error_message() << "ERROR code :" <<
status.error_code();
} // Login and RPC request finished.
7. To log out, call the Logout method. (Details not shown.)
Dial-out mode
In dial-out mode, the application needs to provide the gRPC server code so the collector can receive
and resolve data obtained from the device.
The application performs the following operations:
/