From 90ee75c3f96441fd053cc3d7494a382de6e5bf75 Mon Sep 17 00:00:00 2001 From: Savorboard Date: Sat, 23 Sep 2017 21:54:29 +0800 Subject: [PATCH] add NodeId config to options. --- src/DotNetCore.CAP/NodeDiscovery/CAP.DiscoveryOptions.cs | 2 ++ .../NodeDiscovery/INodeDiscoveryProvider.Consul.cs | 6 ++++-- src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.cs | 2 +- src/DotNetCore.CAP/NodeDiscovery/Node.cs | 2 +- 4 files changed, 8 insertions(+), 4 deletions(-) diff --git a/src/DotNetCore.CAP/NodeDiscovery/CAP.DiscoveryOptions.cs b/src/DotNetCore.CAP/NodeDiscovery/CAP.DiscoveryOptions.cs index 70d1c71..aeadd5e 100644 --- a/src/DotNetCore.CAP/NodeDiscovery/CAP.DiscoveryOptions.cs +++ b/src/DotNetCore.CAP/NodeDiscovery/CAP.DiscoveryOptions.cs @@ -26,6 +26,8 @@ public string CurrentNodeHostName { get; set; } public int CurrentNodePort { get; set; } + + public int NodeId { get; set; } public string NodeName { get; set; } public string MatchPath { get; set; } } diff --git a/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.Consul.cs b/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.Consul.cs index 1e05533..e0f197b 100644 --- a/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.Consul.cs +++ b/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.Consul.cs @@ -4,11 +4,11 @@ using System.Collections.Generic; using System.Text; using System.Threading.Tasks; using Consul; -using System.Security.Cryptography; +using System.Net; namespace DotNetCore.CAP.NodeDiscovery { - class ConsulNodeDiscoveryProvider : INodeDiscoveryProvider, IDisposable + public class ConsulNodeDiscoveryProvider : INodeDiscoveryProvider, IDisposable { private ConsulClient _consul; private readonly DiscoveryOptions _options; @@ -34,6 +34,7 @@ namespace DotNetCore.CAP.NodeDiscovery var nodes = services.Response.Select(x => new Node { + Id = x.Key, Name = x.Value.Service, Address = x.Value.Address, Port = x.Value.Port, @@ -47,6 +48,7 @@ namespace DotNetCore.CAP.NodeDiscovery { return _consul.Agent.ServiceRegister(new AgentServiceRegistration { + ID = _options.NodeId.ToString(), Name = _options.NodeName, Address = _options.CurrentNodeHostName, Port = _options.CurrentNodePort, diff --git a/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.cs b/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.cs index 06ff5aa..c9a3720 100644 --- a/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.cs +++ b/src/DotNetCore.CAP/NodeDiscovery/INodeDiscoveryProvider.cs @@ -5,7 +5,7 @@ using System.Threading.Tasks; namespace DotNetCore.CAP.NodeDiscovery { - interface INodeDiscoveryProvider + public interface INodeDiscoveryProvider { Task> GetNodes(); diff --git a/src/DotNetCore.CAP/NodeDiscovery/Node.cs b/src/DotNetCore.CAP/NodeDiscovery/Node.cs index c77d1d9..fd3d382 100644 --- a/src/DotNetCore.CAP/NodeDiscovery/Node.cs +++ b/src/DotNetCore.CAP/NodeDiscovery/Node.cs @@ -4,7 +4,7 @@ using System.Text; namespace DotNetCore.CAP.NodeDiscovery { - class Node + public class Node { public string Id { get; set; }