OpenThread ofrece servidor SRP y funcionalidad de cliente, lo que permite que los dispositivos para registrar servicios basados en DNS con la actualización de DNS estándar enviada como unidifusión en paquetes. Esta funcionalidad habilita el descubrimiento de servicios basado en DNS.
En esta guía, se proporcionan tareas básicas que usan algunos de los srp server
más comunes
y srp client
.
Comandos del servidor SRP
Para obtener una lista de comandos srp server
, escribe help
:
srp server help
addrmode
auto
disable
domain
enable
help
host
lease
seqnum
service
state
Done
Comandos del cliente de SRP
Para obtener una lista de comandos srp client
, escribe help
:
srp client help
autostart
callback
help
host
keyleaseinterval
leaseinterval
service
start
state
stop
ttl
Done
Referencia de comandos de la CLI
Para obtener descripciones y sintaxis de todos los comandos, consulta la Referencia de comandos de la CLI. Los comandos del servidor de SRP comienzan alfabéticamente con srp server (enable,disable). Los comandos del cliente de SRP comienzan alfabéticamente con srp client autostart (get):
Codelab del router de borde de Thread
Codelab del router de borde de OpenThread incluye información para configurar el dispositivo final del cliente de SRP.
Descripciones generales de algunos comandos básicos de SRP
Los comandos del servidor y del cliente de SRP pueden utilizarse en secuencia para realizar tareas típicas de SRP:
-
srp server enable
habilita el servidor de SRP una vez que creas la red Thread. -
srp client host name
establece el nombre de host que usará el cliente.srp client host address (set)
habilita el modo de dirección de cliente de host automático o establece de manera explícita la lista de direcciones de clientes del host.srp client service add
agrega un servicio con un nombre de instancia, servicio y el número de puerto.srp client autostart enable
habilita el modo de inicio automático. También puedes iniciar el cliente ejecutandosrp client start
.
Verifica el estado del servicio.
srp client host
ysrp client service
indican el estado El host y el servicio del cliente se registraron correctamente en el nodo del cliente.srp server host
ysrp server service
proporcionan el estado del host y del servicio en el nodo del servidor.
-
srp client service remove
quita un servicio, pero conserva su nombre. Quita los nombres de host y de servicio.
srp client host remove
quita el host y todos los servicios registrados.
Ejemplos de uso de comandos de clientes y servidores SRP
Estos ejemplos usan comandos básicos de la CLI para configurar una red Thread, comienza el servidor y el cliente de SRP, verificar el estado del servidor y quitar un servicio. Datos de muestra se usa con fines ilustrativos.
Inicia el servidor de SRP
Inicia el nodo del servidor de SRP:
./output/simulation/bin/ot-cli-ftd 1
Configura una red Thread y, luego, habilita el servidor de SRP con el comando
srp server enable
:dataset init new
Donedataset
Active Timestamp: 1 Channel: 22 Channel Mask: 0x07fff800 Ext PAN ID: 8d6ed7a05a28fb3b Mesh Local Prefix: fded:5114:8263:1fe1::/64 Network Key: 7fcbae4153cc2955c28440c15d4d4219 Network Name: OpenThread-f7af PAN ID: 0xf7af PSKc: b658e40f174e3a11be149b302ef07a0f Security Policy: 672, onrc Donedataset commit active
Doneifconfig up
Donethread start
Donestate
leader Doneipaddr
fded:5114:8263:1fe1:0:ff:fe00:fc00 fded:5114:8263:1fe1:0:ff:fe00:c000 fded:5114:8263:1fe1:68bc:ec03:c1ad:9325 fe80:0:0:0:a8cd:6e23:df3d:4193 Donesrp server enable
Done
Inicia el cliente de SRP
Inicia el nodo del cliente de SRP:
./output/simulation/bin/ot-cli-ftd 2
Únete a la red de Thread, establece el nombre y la dirección de host del cliente. registrar un servicio:
dataset networkkey 7fcbae4153cc2955c28440c15d4d4219
Donedataset commit active
Doneifconfig up
Donethread start
Donestate
child Doneipaddr
fded:5114:8263:1fe1:0:ff:fe00:c001 fded:5114:8263:1fe1:44f9:cc06:4a2d:534 fe80:0:0:0:38dd:fdf7:5fd:24e Donesrp client host name my-host
Donesrp client host address fded:5114:8263:1fe1:44f9:cc06:4a2d:534
Donesrp client service add my-service _ipps._tcp 12345
Donesrp client autostart enable
DoneComo se mostró anteriormente, usa el comando
srp client autostart enable
para habilitar modo de inicio automático en el cliente. El cliente supervisa los datos de red para detectar servidores SRP disponibles en la red de Thread, el cliente automáticamente.Si inicias el cliente de forma manual, ejecuta lo siguiente y, además, incluye la dirección de SRP y el puerto:
srp client start fded:5114:8263:1fe1:68bc:ec03:c1ad:9325 49154
DoneEn el ejemplo anterior, el servidor de SRP que escucha el puerto UDP es
c002(49154)
.
Verifica el estado del servicio
Verifica si el host y el servicio se registraron correctamente en el nodo de cliente:
srp client host
name:"my-host", state:Registered, addrs:[fded:5114:8263:1fe1:44f9:cc06:4a2d:534] Donesrp client service
instance:"my-service", name:"_ipps._tcp", state:Registered, port:12345, priority:0, weight:0 DoneAsegúrate de que el resultado muestre
state:Registered
para los comandos de host y de servicio. como en el ejemplo anterior.Verifica el host y el servicio en el nodo del servidor:
srp server host
my-host.default.service.arpa. deleted: false addresses: [fded:5114:8263:1fe1:44f9:cc06:4a2d:534] Donesrp server service
my-service._ipps._tcp.default.service.arpa. deleted: false port: 12345 priority: 0 weight: 0 ttl: 7200 lease: 7200 key-lease: 1209600 TXT: [] host: my-host.default.service.arpa. addresses: [fded:5114:8263:1fe1:44f9:cc06:4a2d:534] DoneAsegúrate de que el resultado muestre
deleted: false
parasrp server host
. ysrp server service
, como en el ejemplo anterior.
Quita el servicio
Quita el servicio a través del nodo cliente:
srp client service remove my-service _ipps._tcp
DoneMediante el nodo del servidor, confirma que se haya quitado el servicio:
srp server service
my-service._ipps._tcp.default.service.arpa. deleted: true DoneLa entrada Service aparece en la salida porque el nombre del Service no se quitó.
Quita los nombres de host y de servicio
Quita el host y todos sus servicios registrados:
srp client host remove 1
DoneConfirma en el nodo del servidor que no haya entradas de host ni de servicio:
srp server host
Donesrp server service
Done >