Recuperando variáveis controladas do Repositório de Monitoramento do AppFabric
Este exemplo mostra como usar o Entity Framework para recuperar e desserializar variáveis de fluxo de trabalho rastreadas do banco de dados de monitoramento do AppFabric. Você vai aprender sobre alguns dos modos de exibição públicos expostos do banco de dados de monitoramento que tornam isso possível. Esse exemplo funcionará com qualquer aplicativo. É recomendável o Aplicativo comum de exemplo do AppFabric, que foi criado para ser usado com exemplos do AppFabric. Para encontrar esse aplicativo, vá para a pasta <samples>\SampleApplication\OrderApplication, em que <samples> é o caminho em que você instalou as amostras do AppFabric.
Dica
Os exemplos são fornecidos apenas para fins educacionais. Eles não devem ser usados em um ambiente de produção e não foram testados em um ambiente de produção. A Microsoft não dá suporte técnico para esses exemplos.
Pré-requisitos
Uma instalação do Microsoft AppFabric 1.1 para Windows Server com o monitoramento configurado
Pelo menos um serviço WCF ou WF hospedado em AppFabric.
Dica
Esse exemplo ilustrará melhor os recursos de monitoramento se o serviço for configurado para rastrear uma variável de um tipo complexo.
Se você estiver desserializando variáveis rastreadas de um conjunto personalizado, certifique-se de adicionar o conjunto (por exemplo, o Exemplo de Aplicativo do AppFabric) como referência para este projeto de modo que ele possa desserializar adequadamente esses objetos.
Arquivos de exemplo
Esse exemplo vem com os seguintes arquivos:
Estrutura da solução e arquivos de código de apoio do Visual Studio 2010
TrackedWFVariable.cs
Program.cs
Configurando e executando esse exemplo
Verifique se as variáveis foram rastreadas e armazenadas no banco de dados de monitoramento. Você pode fazer isso inspecionando o modo de exibição WFEventProperties e verificando se há linhas presentes.
Abra a solução Visual Studio que acompanha esse exemplo.
Importante
Verifique se você está trabalhando com uma conta que tenha acesso de leitura ao banco de dados de monitoramento do AppFabric.
Edite o valor Banco de Dados em Program.cs para que ele aponte para o seu banco de dados desejado.
Edite o valor que é passado para o construtor AppFabricMonitoringEntities em Program.cs. Por padrão, ele aponta para uma instância do SQL Express. Um nome da instância SQL padrão foi incluído na parte superior do arquivo para simplificar.
Crie e execute o exemplo, pressionando F5.
Noções básicas sobre esse exemplo
O Program.cs usa o Entity Framework para consultar no banco de dados os eventos de fluxo de trabalho mais recentes. A classe TrackedWFVariable usa o contexto de dados do Entity Framework para conectar-se e acessar qualquer linha WFEventProperty que esteja relacionada aos eventos recentes. As propriedades são então desserializadas em seus tipos originais do .NET. Esse processo varia de acordo com o tipo de objeto a ser desserializado.
Os seguintes tipos são armazenados como representação simples de cadeia de caracteres na coluna Valor do modo de exibição WFEventProperties:
System.String
System.Char
System.Boolean
System.Int32
System.Int16
System.Int64
System.UInt32
System.UInt16
System.UInt64
System.Single
System.Double
System.Guid
System.DateTimeOffset
System.DateTime
Esses tipos podem ser desserializados, chamando os métodos estáticos Análise que esses tipos definem, transmitindo os valores de cadeia de caracteres como um parâmetro. Todos os outros tipos têm seu valor armazenado na coluna ValueBlob do modo de exibição WFEventProperties e devem ser desserializados usando o System.Runtime.Serialization.NetDataContractSerializer. Isso requer que o assembly, que declara o tipo a ser desserializado, seja carregado. Os objetos são armazenados dessa forma no banco de dados para que os tipos mais simples listados acima possam ser facilmente consultados pelos clientes SQL.
Removendo esse exemplo
Esse exemplo não deixa nenhum artefato para trás. Você poderá excluir os arquivos de exemplo se quiser.
2012-03-05