Auto-Anfitrião
O exemplo SelfHost demonstra como implementar um serviço auto-hospedado em um aplicativo de console. Este exemplo é baseado em Introdução. O arquivo de configuração de serviço foi renomeado de Web.config para App.config e modificado para configurar um endereço base, que o host usa. O código-fonte do serviço foi modificado para implementar uma função estática Main
que cria e abre um host de serviço que fornece o endereço base configurado. A implementação do serviço foi modificada para gravar a saída no console para cada operação. O cliente não foi modificado, exceto para configurar o endereço de ponto de extremidade correto do serviço.
Nota
O procedimento de configuração e as instruções de compilação para este exemplo estão localizados no final deste tópico.
O exemplo implementa uma função principal estática para criar um ServiceHost para o tipo determinado CalculatorService
, conforme mostrado no código de exemplo a seguir.
// Host the service within this EXE console application.
public static void Main()
{
// Create a ServiceHost for the CalculatorService type.
using (ServiceHost serviceHost =
new ServiceHost(typeof(CalculatorService)))
{
// Open the ServiceHost to create listeners
// and start listening for messages.
serviceHost.Open();
// The service can now be accessed.
Console.WriteLine("The service is ready.");
Console.WriteLine("Press <ENTER> to terminate service.");
Console.WriteLine();
Console.ReadLine();
}
}
Quando um serviço é hospedado no IIS (Serviços de Informações da Internet) ou no Serviço de Ativação de Processos do Windows (WAS), o endereço base do serviço é fornecido pelo ambiente de hospedagem. No caso de auto-hospedagem, você mesmo deve especificar o endereço base. Isso é feito usando o add
elemento , filho de <baseAddresses>, filho do< host>, filho do serviço>, conforme demonstrado na configuração de <exemplo a seguir.
<service
name="Microsoft.ServiceModel.Samples.CalculatorService"
behaviorConfiguration="CalculatorServiceBehavior">
<host>
<baseAddresses>
<add baseAddress="http://localhost:8000/ServiceModelSamples/service"/>
</baseAddresses>
</host>
...
</service>
Quando você executa o exemplo, as solicitações de operação e as respostas são exibidas nas janelas do console de serviço e do cliente. Pressione ENTER em cada janela do console para desligar o serviço e o cliente.
Para configurar, compilar e executar o exemplo
Certifique-se de ter executado o procedimento de instalação única para os exemplos do Windows Communication Foundation.
Para criar a edição C# ou Visual Basic .NET da solução, siga as instruções em Criando os exemplos do Windows Communication Foundation.
Para executar o exemplo em uma configuração de computador único ou entre computadores, siga as instruções em Executando os exemplos do Windows Communication Foundation.