18个基础命令教你轻松拿捏华为设备的各种状态!-HCIA HCIP

Posted ie-lab网络实验室ccie认证之家

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了18个基础命令教你轻松拿捏华为设备的各种状态!-HCIA HCIP相关的知识,希望对你有一定的参考价值。

  • 1、display cpu-usage:
    用来查看设备CPU占用率的统计信息
    • 命令格式
      <Huawei>display cpu-usage ?
      configuration  Cpu usage configration
      slot           Slot
      <cr>           Please press ENTER to execute command
    • 使用示例
      <HUAWEI> display cpu-usage
      CPU   Usage Stat. Cycle: 30 (Second)
      CPU   Usage:  2.4%   Max: 90.2%
      CPU   Usage Stat. Time : 2023-03-07  05:29:48
      CPU   Usage Max.  Time : 2023-03-07  15:26:41 

  • 2、display cpu-usage configuration:
    用来查看设备CPU占用率的配置信息
    • 命令格式
      [Huawei]display cpu-usage configuration ?
      slot  Slot
      <cr>  Please press ENTER to execute command
    • 使用示例
      <HUAWEI> display cpu-usage configuration
      The CPU usage monitor is turned on.
      The current monitor cycle is 10 seconds.
      The current monitor warning threshold is 80%.
      The current monitor restore threshold is 75%.
      The cap current monitor warning threshold is 80%.
      The cap current monitor restore threshold is 75%.

  • 3、display device:
    用来查看设备的部件类型及状态信息
    • 命令格式
      [Huawei]display device ?
      slot  Slot
      <cr>  Please press ENTER to execute command
    • 使用示例
      [Huawei]display device
      AR2220's Device status:
      Slot Sub Type     Online   Power    Register   Alarm   Primary
      - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
      0    -   AR2220   Present  PowerOn  Registered Normal  Master
      7    -   PWR      Present  PowerOn  Registered Normal  NA

  • 4、display diagnostic-information:
    用来查看设备当前的诊断信息或将诊断信息存储在指定文件
    • 命令格式
      <Huawei>display diagnostic-information ?
      STRING<5-64>   Name of the file stored diagnostic information
                     (Default directory is flash:/,the postfix of
                     the filename must be .txt)
      <cr>          Please press ENTER to execute command
    • 使用示例
      <Huawei>display diagnostic-information
      ===================================================
        ===============display version===============
      ===================================================
      Huawei Versatile Routing Platform Software
      VRP (R) software, Version 5.130 (AR2200 V200R003C00)
      Copyright (C) 2011-2012 HUAWEI TECH CO., LTD
      Huawei AR2220 Router uptime is 0 week, 0 day, 0 hour, 21 minutes
      BKP 0 version information:
      1. PCB      Version  : AR01BAK2A VER.NC
      2. If Supporting PoE : No
      3. Board    Type     : AR2220
      4. MPU Slot Quantity : 1
      5. LPU Slot Quantity : 6

      MPU 0(Master) : uptime is 0 week, 0 day, 0 hour, 21 minutes
      MPU version information :
      1. PCB      Version  : AR01SRU2A VER.A
      2. MAB      Version  : 0
      3. Board    Type     : AR2220
      4. BootROM  Version  : 0
      ………………………………

  • 5、display elabel
    用来查看设备的电子标签信息
    • 命令格式
      <Huawei>display elabel ?
      <0>        The present MPU
      <7>        The present PWR
      backplane  Backplane
      brief      Display information briefly
      <cr>       Please press ENTER to execute command
    • 使用示例
      <Huawei>display elabel
       It is executing, please wait...


      /$[System Integration Version]
      /$SystemIntegrationVersion=3.0


      [Rack_1]
      [SubRack_0]


      [Slot_0]
      /$[Board Integration Version]
      /$BoardIntegrationVersion=3.0


      [Main_Board]
      /$[ArchivesInfo Version]
      /$ArchivesInfoVersion=3.0


      [Board Properties]
      BoardType=
      BarCode=
      Item=                                    
      Description=
      Manufactured=
      VendorName=
      IssueNumber=
      CLEICode=
      BOM=

  • 6、display esn:
    用来查看设备的序列号ESN(Equipment Serial Number)
    • 命令格式
      <Huawei>display esn ?
      <cr>  Please press ENTER to execute command
    • 使用示例
      <HUAWEI> display esn
      ESN of device: **********P0B4000046 

  • 7、display fan:
    用来查看风扇的状态(AC6508、AC6507S、AirEngine 9700S-S不支持此命令)
    • 命令格式
      (AR2220设备配置命令不支持,正常会包含slot和verbose)
      <Huawei>display fan ?
      <cr>  Please press ENTER to execute command
    • 使用示例
      <Huawei>display fan (查看设备的风扇状态)
      --------------------------------------------------
         FanId  FanNum  Present  Register  Speed  Mode
      --------------------------------------------------
          0      [1-4]   YES      YES          NA  AUTO
      <HUAWEI> display fan verbose(查看风扇状态的详细信息)
    • Slot #     FAN #  Status  Speed Rate  Mode  Airflow Direction
      --------------------------------------------------------------    
      0          0      Normal   70 %       AUTO       Back-to-Side  
  • 8、display health:
    用来查看设备的健康状况
    • 命令格式
      <Huawei>display health ?
      <cr>  Please press ENTER to execute command
    • 使用示例
      <Huawei>display health
      ---------------------------------------------------------
      Slot Card Sensor No. SensorName Status Upper Lower Temp(C)
      --------------------------------------------------------------
      0   -   1     AR2220 TEMP  NORMAL  73   0     0           
      -------------------------------------------------------------- PowerNo  Present  Mode   State  Current(A) Voltage(V) Power(W)  
      --------------------------------------------------------------
         7       YES    AC     Supply  N/A       12          150
      --------------------------------------------------------------
                FanId  FanNum  Present  Register  Speed  Mode
      --------------------------------------------------------------
                0      [1-4]   YES      YES          NA  AUTO
       The total  power is : 150.000(W)
       The used   power is : 0.000(W)
       The remain power is : 150.000(W)
       The system used power detail information :
      --------------------------------------------------------------
        SlotID  BoardType    Power-Used(W)  Power-Requested(W)
      --------------------------------------------------------------
        0       AR2220       0.000          0
      System CPU Usage Information:
      System cpu usage at 2023-03-07  13:59:51 984 ms
      -------------------------------------------------------------------------------
        SlotID  CPU Usage  Upper Limit
      --------------------------------------------------------------
        0       0 %        80%
      System Memory Usage Information:
       System memory usage at 2023-03-07  13:59:52 984 ms
      --------------------------------------------------------------
      SlotID  Total Memory(MB)  Used Memory(MB)  Used Percentage  Upper Limit
      --------------------------------------------------------------
        0    152            122           80%           95%
      System Disk Usage Information:
       System disk usage at 2023-03-07  13:59:52 984 ms
      --------------------------------------------------------------
      SlotID  Device  Total Memory(MB)  Used Memory(MB)  Used Percentage  
      --------------------------------------------------------------
        0    flash:  1065            299             28%

  • 9、display memory-usage:
    用来查看设备的内存占用率信息
    • 命令格式
      <Huawei>display memory-usage ?
      slot       Slot
      threshold  Memory usage threshold
      <cr>       Please press ENTER to execute command
    • 使用示例
      <Huawei>display memory-usage
      Memory utilization statistics at 2023-03-07 14:18:46 824 ms
      System Total Memory Is: 159383552 bytes
      Total Memory Used Is: 128099284 bytes
      Memory Using Percentage Is: 80%

设备如何使用go sdk轻松连接华为云IoT平台

本文分享自华为云社区《设备如何使用go sdk轻松连接华为云IoT平台》,作者:华为云IoT专家团 。

本文介绍使用huaweicloud-iot-device-sdk-go 连接华为云IoT平台,实现简单的华为云文档介绍的四个功能:设备连接鉴权、设备命令、设备消息和设备属性。huaweicloud-iot-device-sdk-go提供设备接入华为云IoT物联网平台的Go版本的SDK,提供设备和平台之间通讯能力,以及设备服务、网关服务、OTA等高级服务。IoT设备开发者使用SDK可以大大简化开发复杂度,快速的接入平台。

Gihub项目地址:huaweicloud-iot-device-sdk-go

安装和构建

安装和构建的过程取决于使用go的 modules(推荐) 还是还是GOPATH

Modules

如果你使用 modules 只需要导入包"github.com/ctlove0523/huaweicloud-iot-device-sdk-go"即可使用。当你使用go build命令构建项目时,依赖的包会自动被下载。注意使用go build命令构建时会自动下载最新版本,最新版本还没有达到release的标准可能存在一些尚未修复的bug。如果想使用稳定的发布版本可以从release 获取最新稳定的版本号,并在go.mod文件中指定版本号。

module example

go 1.15

require github.com/ctlove0523/huaweicloud-iot-device-sdk-go v0.0.1-alpha

GOPATH

如果你使用GOPATH,下面的一条命令即可实现安装

go get github.com/ctlove0523/huaweicloud-iot-device-sdk-go

使用API

创建设备并初始化

1、首先,在华为云IoT平台创建一个设备,设备的信息如下:

设备ID:5fdb75cccbfe2f02ce81d4bf_go-mqtt

设备密钥:123456789

2、使用SDK创建一个Device对象,并初始化Device。

// 创建一个设备并初始化
device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
device.Init()

完整样例

import (
    "fmt"
    "github.com/ctlove0523/huaweicloud-iot-device-sdk-go"
    "time"
)

func main() 
    // 创建一个设备并初始化
    device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
    device.Init()
    if device.IsConnected() 
        fmt.Println("device connect huawei iot platform success")
     else 
        fmt.Println("device connect huawei iot platform failed")
    

iot-mqtts.cn-north-4.myhuaweicloud.com为华为IoT平台(基础班)在华为云北京四的访问端点,如果你购买了标准版或企业版,请将iot-mqtts.cn-north-4.myhuaweicloud.com更换为对应的MQTT协议接入端点。

设备处理平台下发的命令

1、首先,在华为云IoT平台创建一个设备,设备的信息如下:

设备ID:5fdb75cccbfe2f02ce81d4bf_go-mqtt

设备密钥:123456789

2、使用SDK创建一个Device对象,并初始化Device。

// 创建一个设备并初始化
device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
device.Init()
if device.IsConnected() 
    fmt.Println("device connect huawei iot platform success")
 else 
    fmt.Println("device connect huawei iot platform failed")

3、注册命令处理handler,支持注册多个handler并且按照注册的顺序回调

// 添加用于处理平台下发命令的callback
device.AddCommandHandler(func(command iot.Command) bool 
    fmt.Println("First command handler begin to process command.")
    return true
)

device.AddCommandHandler(func(command iot.Command) bool 
    fmt.Println("Second command handler begin to process command.")
    return true
)

4、通过应用侧API向设备下发一个命令,可以看到程序输出如下:

device connect huawei iot platform success
First command handler begin to process command.
Second command handler begin to process command.

完整样例

import (
    "fmt"
    "github.com/ctlove0523/huaweicloud-iot-device-sdk-go"
    "time"
)

// 处理平台下发的同步命令
func main() 
    // 创建一个设备并初始化
    device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
    device.Init()
    if device.IsConnected() 
        fmt.Println("device connect huawei iot platform success")
     else 
        fmt.Println("device connect huawei iot platform failed")
    

    // 添加用于处理平台下发命令的callback
    device.AddCommandHandler(func(command iot.Command) bool 
        fmt.Println("First command handler begin to process command.")
        return true
    )

    device.AddCommandHandler(func(command iot.Command) bool 
        fmt.Println("Second command handler begin to process command.")
        return true
    )
    time.Sleep(1 * time.Minute)

设备支持的命令定义在产品中

设备消息

1、首先,在华为云IoT平台创建一个设备,设备的信息如下:

设备ID:5fdb75cccbfe2f02ce81d4bf_go-mqtt

设备密钥:123456789

2、使用SDK创建一个Device对象,并初始化Device。

device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
    device.Init()

设备消息上报

message := iot.Message
    ObjectDeviceId: uuid.NewV4().String(),
    Name:           "Fist send message to platform",
    Id:             uuid.NewV4().String(),
    Content:        "Hello Huawei IoT Platform",

device.SendMessage(message)

平台消息下发

接收平台下发的消息,只需注册消息处理handler,支持注册多个handler并按照注册顺序回调。

// 注册平台下发消息的callback,当收到平台下发的消息时,调用此callback.
// 支持注册多个callback,并且按照注册顺序调用
device.AddMessageHandler(func(message iot.Message) bool 
    fmt.Println("first handler called" + iot.Interface2JsonString(message))
    return true
)

device.AddMessageHandler(func(message iot.Message) bool 
    fmt.Println("second handler called" + iot.Interface2JsonString(message))
    return true
)

完整样例

import (
    "fmt"
    iot "github.com/ctlove0523/huaweicloud-iot-device-sdk-go"
    uuid "github.com/satori/go.uuid"
    "time"
)

func main() 
    // 创建一个设备并初始化
    device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
    device.Init()

    // 注册平台下发消息的callback,当收到平台下发的消息时,调用此callback.
    // 支持注册多个callback,并且按照注册顺序调用
    device.AddMessageHandler(func(message iot.Message) bool 
        fmt.Println("first handler called" + iot.Interface2JsonString(message))
        return true
    )

    device.AddMessageHandler(func(message iot.Message) bool 
        fmt.Println("second handler called" + iot.Interface2JsonString(message))
        return true
    )

    //向平台发送消息
    message := iot.Message
        ObjectDeviceId: uuid.NewV4().String(),
        Name:           "Fist send message to platform",
        Id:             uuid.NewV4().String(),
        Content:        "Hello Huawei IoT Platform",
    
    device.SendMessage(message)
    time.Sleep(2 * time.Minute)


设备属性

1、首先,在华为云IoT平台创建一个设备,并在该设备下创建3个子设备,设备及子设备的信息如下:

设备ID:5fdb75cccbfe2f02ce81d4bf_go-mqtt

设备密钥:123456789

子设备ID:5fdb75cccbfe2f02ce81d4bf_sub-device-1

子设备ID:5fdb75cccbfe2f02ce81d4bf_sub-device-2

子设备ID:5fdb75cccbfe2f02ce81d4bf_sub-device-3

2、使用SDK创建一个Device对象,并初始化Device。

// 创建设备并初始化
device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
device.Init()
fmt.Printf("device connected: %v\\n", device.IsConnected())

设备属性上报

使用ReportProperties(properties ServiceProperty) bool 上报设备属性

// 设备上报属性
props := iot.ServicePropertyEntry
    ServiceId: "value",
    EventTime: iot.DataCollectionTime(),
    Properties: DemoProperties
        Value:   "chen tong",
        MsgType: "23",
    ,


var content []iot.ServicePropertyEntry
content = append(content, props)
services := iot.ServiceProperty
    Services: content,

device.ReportProperties(services)

网关批量设备属性上报

使用BatchReportSubDevicesProperties(service DevicesService) 实现网关批量设备属性上报

// 批量上报子设备属性
subDevice1 := iot.DeviceService
    DeviceId: "5fdb75cccbfe2f02ce81d4bf_sub-device-1",
    Services: content,

subDevice2 := iot.DeviceService
    DeviceId: "5fdb75cccbfe2f02ce81d4bf_sub-device-2",
    Services: content,


subDevice3 := iot.DeviceService
    DeviceId: "5fdb75cccbfe2f02ce81d4bf_sub-device-3",
    Services: content,


var devices []iot.DeviceService
devices = append(devices, subDevice1, subDevice2, subDevice3)

device.BatchReportSubDevicesProperties(iot.DevicesService
    Devices: devices,
)

平台设置设备属性

使用AddPropertiesSetHandler(handler DevicePropertiesSetHandler) 注册平台设置设备属性handler,当接收到平台的命令时SDK回调。

// 注册平台设置属性callback,当应用通过API设置设备属性时,会调用此callback,支持注册多个callback
device.AddPropertiesSetHandler(func(propertiesSetRequest iot.DevicePropertyDownRequest) bool 
    fmt.Println("I get property set command")
    fmt.Printf("request is %s", iot.Interface2JsonString(propertiesSetRequest))
    return true
)

平台查询设备属性

使用SetPropertyQueryHandler(handler DevicePropertyQueryHandler)注册平台查询设备属性handler,当接收到平台的查询请求时SDK回调。

// 注册平台查询设备属性callback,当平台查询设备属性时此callback被调用,仅支持设置一个callback
device.SetPropertyQueryHandler(func(query iot.DevicePropertyQueryRequest) iot.ServicePropertyEntry 
    return iot.ServicePropertyEntry
        ServiceId: "value",
        Properties: DemoProperties
            Value:   "QUERY RESPONSE",
            MsgType: "query property",
        ,
        EventTime: "2020-12-19 02:23:24",
    
)

设备侧获取平台的设备影子数据

使用QueryDeviceShadow(query DevicePropertyQueryRequest, handler DevicePropertyQueryResponseHandler) 可以查询平台的设备影子数据,当接收到平台的响应后SDK自动回调DevicePropertyQueryResponseHandler

// 设备查询设备影子数据
device.QueryDeviceShadow(iot.DevicePropertyQueryRequest
    ServiceId: "value",
, func(response iot.DevicePropertyQueryResponse) 
    fmt.Printf("query device shadow success.\\n,device shadow data is %s\\n", iot.Interface2JsonString(response))
)

完整样例

import (
    "fmt"
    iot "github.com/ctlove0523/huaweicloud-iot-device-sdk-go"
    "time"
)

func main() 
    // 创建设备并初始化
    device := iot.CreateIotDevice("5fdb75cccbfe2f02ce81d4bf_go-mqtt", "123456789", "tcp://iot-mqtts.cn-north-4.myhuaweicloud.com:1883")
    device.Init()
    fmt.Printf("device connected: %v\\n", device.IsConnected())

    // 注册平台设置属性callback,当应用通过API设置设备属性时,会调用此callback,支持注册多个callback
    device.AddPropertiesSetHandler(func(propertiesSetRequest iot.DevicePropertyDownRequest) bool 
        fmt.Println("I get property set command")
        fmt.Printf("request is %s", iot.Interface2JsonString(propertiesSetRequest))
        return true
    )

    // 注册平台查询设备属性callback,当平台查询设备属性时此callback被调用,仅支持设置一个callback
    device.SetPropertyQueryHandler(func(query iot.DevicePropertyQueryRequest) iot.ServicePropertyEntry 
        return iot.ServicePropertyEntry
            ServiceId: "value",
            Properties: DemoProperties
                Value:   "QUERY RESPONSE",
                MsgType: "query property",
            ,
            EventTime: "2020-12-19 02:23:24",
        
    )

    // 设备上报属性
    props := iot.ServicePropertyEntry
        ServiceId: "value",
        EventTime: iot.DataCollectionTime(),
        Properties: DemoProperties
            Value:   "chen tong",
            MsgType: "23",
        ,
    

    var content []iot.ServicePropertyEntry
    content = append(content, props)
    services := iot.ServiceProperty
        Services: content,
    
    device.ReportProperties(services)

    // 设备查询设备影子数据
    device.QueryDeviceShadow(iot.DevicePropertyQueryRequest
        ServiceId: "value",
    , func(response iot.DevicePropertyQueryResponse) 
        fmt.Printf("query device shadow success.\\n,device shadow data is %s\\n", iot.Interface2JsonString(response))
    )

    // 批量上报子设备属性
    subDevice1 := iot.DeviceService
        DeviceId: "5fdb75cccbfe2f02ce81d4bf_sub-device-1",
        Services: content,
    
    subDevice2 := iot.DeviceService
        DeviceId: "5fdb75cccbfe2f02ce81d4bf_sub-device-2",
        Services: content,
    

    subDevice3 := iot.DeviceService
        DeviceId: "5fdb75cccbfe2f02ce81d4bf_sub-device-3",
        Services: content,
    

    var devices []iot.DeviceService
    devices = append(devices, subDevice1, subDevice2, subDevice3)

    device.BatchReportSubDevicesProperties(iot.DevicesService
        Devices: devices,
    )
    time.Sleep(1 * time.Minute)


type DemoProperties struct 
    Value   string `json:"value"`
    MsgType string `json:"msgType"`

更多学习内容,请前往IoT物联网社区 

如果您也对物联网感兴趣,欢迎评论区交流或私聊~

点击关注,第一时间了解华为云新鲜技术~​
 

以上是关于18个基础命令教你轻松拿捏华为设备的各种状态!-HCIA HCIP的主要内容,如果未能解决你的问题,请参考以下文章

华为云算法零门槛:零基础教你AI试伊妆

Java基础四张图轻松拿捏Java VisualVM添加Visual GC插件实现JVM性能调优

Java基础四张图轻松拿捏Java VisualVM添加Visual GC插件实现JVM性能调优

Docker-教你如何通过 Docker 快速搭建各种测试环境

H3C产品简介及基础配置命令

掌握 Dowanward API 的妙用,轻松拿捏 kubernetes 环境变量