В нашем основном приложении у нас есть следующая функция (в VB. Net):
Public Overrides Function GetNewResults(setToProcessed As Boolean) As List(Of ReceivedData)
Dim client = New NamedPipeClientStream(".", "PipesOfPiece",
PipeDirection.InOut, PipeOptions.None,
TokenImpersonationLevel.Impersonation)
client.Connect()
Dim reader = New StreamReader(client)
Dim writer = New StreamWriter(client)
writer.AutoFlush = True
writer.WriteLine(DbPath)
Dim serialized = reader.ReadLine
client.Close()
Dim newResults = JsonConvert.DeserializeObject(Of List(Of ReceivedData))(serialized)
Return newResults
End Function
NamedPipeServer был написан на C# и на данный момент размещается в консольном приложении. :
static void StartServer()
{
server = new NamedPipeServerStream("PipesOfPiece", direction: PipeDirection.InOut,maxNumberOfServerInstances:10);
server.WaitForConnection();
StreamReader reader = new StreamReader(server);
StreamWriter writer= new StreamWriter(server);
writer.AutoFlush = true;
while (true)
{
var dbPath = reader.ReadLine();
if (string.IsNullOrEmpty(dbPath)) continue;
if (!File.Exists(dbPath))
{
writer.WriteLine($"{dbPath} does not exist.");
continue;
}
var communicator = new DapperBwsCommunicator(dbPath,provider: "Microsoft.Jet.OLEDB.4.0");
var newResults = communicator.GetAllResults(setToProcessed: true);
var serialized = JsonConvert.SerializeObject(newResults);
writer.WriteLine(serialized);
}
}
Функция GetNewResults
вызывается каждые три секунды. При первом вызове этой функции она работает правильно. Но второй раз код блокируется на Client.Connect
. Тогда кажется, что сервер больше не отвечает.
Куда я иду не так?
РЕДАКТИРОВАТЬ Благодаря ответу Fandan go я пришел с другая реализация. Кажется, это работает:
static void StartServer()
{
server = new NamedPipeServerStream("PipesOfPiece", direction: PipeDirection.InOut,maxNumberOfServerInstances:10);
server.WaitForConnection();
StreamReader reader = new StreamReader(server);
StreamWriter writer= new StreamWriter(server);
writer.AutoFlush = true;
while (true)
{
var dbPath = reader.ReadLine();
if (string.IsNullOrEmpty(dbPath)) continue;
if (!File.Exists(dbPath))
{
writer.WriteLine($"{dbPath} does not exist.");
continue;
}
var communicator = new DapperBwsCommunicator(dbPath,provider: "Microsoft.Jet.OLEDB.4.0");
var newResults = communicator.GetAllResults(setToProcessed: true);
var serialized = JsonConvert.SerializeObject(newResults);
writer.WriteLine(serialized);
server.Disconnnect();
server.WaitForConnection();
}
}