Service Fabric, Remoting V2 для Stateful Service не работает
Я не могу заставить это работать, я гуглил и, вероятно, нашел каждую страницу о том, как это сделать, все две из них!
По сути, я просто пытаюсь заставить SF Remoting V2 работать из приложения.NET Core 2 MVC без сохранения состояния в службу Statefull.
Вот что я сделал:
Код клиента в контроллере: (максимально упрощен):
public class ValuesController : Controller
{
[HttpGet]
public async Task<IEnumerable<string>> Get()
{
// Provide certificate details.
var serviceProxyFactory = new ServiceProxyFactory((c) => new FabricTransportServiceRemotingClientFactory());
var proxy = serviceProxyFactory.CreateServiceProxy<ICallMe>(new Uri("fabric:/SFExperiment/Stateful1"));
var value3 = await proxy.GetGreeeting("Bob");
return new[] { "value1", "value2", value3 };
}
Интерфейс сервисного кода:
using System.Threading.Tasks;
using Microsoft.ServiceFabric.Services.Remoting;
using Microsoft.ServiceFabric.Services.Remoting.FabricTransport;
[assembly: FabricTransportServiceRemotingProvider(RemotingListener =
RemotingListener.V2Listener, RemotingClient = RemotingClient.V2Client)]
namespace Stateful1.Abstractions
{
public interface ICallMe : IService
{
Task<string> GetGreeeting(string name);
}
}
Сервисный код:
Public sealed class Stateful1 : StatefulService, ICallMe
{
public Stateful1(StatefulServiceContext context)
: base(context)
{ }
protected override IEnumerable<ServiceReplicaListener> CreateServiceReplicaListeners()
{
return this.CreateServiceRemotingReplicaListeners();
}
public Task<string> GetGreeeting(string name)
{
return Task.FromResult(@"Congratulations, you have remoting working. :-) ");
}
Я добавил ниже в ServiceManifest.xml
<Resources>
<Endpoints>
<!-- To enable Service remonting for remoting services V2-->
<Endpoint Name="ServiceEndpointV2" />
<Endpoint Name="ReplicatorEndpoint" />
</Endpoints>
</Resources>
И это не работает.. Я получаю следующее исключение:
Недопустимый ключ раздела /ID '{0}' для селектора {1}
Что я делаю неправильно?
1 ответ
При вызове для создания прокси службы вы должны указать ключ раздела, потому что вы подключаетесь к службе с отслеживанием состояния.
long partitionKey = 0L; //TODO: Determine partition key
var proxy = serviceProxyFactory.CreateServiceProxy<ICallMe>(new Uri("fabric:/SFExperiment/Stateful1"), new ServicePartitionKey(partitionKey), TargetReplicaSelector.PrimaryReplica);
Кроме того, убедитесь, что вы повторно используете фабрику прокси-служб вместо создания новой. Посмотрите на этот код, например.