Ошибка сокета, когда удаленное взаимодействие .NET между двумя машинами - PullRequest
2 голосов
/ 09 ноября 2010

Для проекта, над которым мы работаем, мы используем .NET remoting для связи между сервером и клиентом. До сих пор мы тестировали его на той же машине, и он работал, используя localhost и произвольный номер порта. Однако при тестировании между двумя компьютерами в одной сети с использованием основного компонента работает, но объект прокси не работает.

Мы используем файлы конфигурации для установки имени сервера и порта, например:

<setting name="ServerName" serializeAs="String">
    <value>192.168.1.141</value>
</setting>
<setting name="Port" serializeAs="String">
    <value>9932</value>
</setting>

Клиент устанавливает объект удаленного взаимодействия следующим образом:

_port = global::ConsoleClient.Properties.Settings.Default.Port;
_servername = global::ConsoleClient.Properties.Settings.Default.ServerName;

string url = "tcp://" + _servername + ":" + _port + "/Lobby";

try
{
    ChannelServices.RegisterChannel(new TcpClientChannel(), false);
    Lobby lobby = (Lobby)Activator.GetObject(
        typeof(Lobby), url);
}
catch (Exception e)
{
}

Это прекрасно работает, и мы можем вызывать методы для объекта лобби. Однако позже в коде мы возвращаем другой объект, таблицу следующим образом:

table_proxy = lobby_proxy.joinTable(userID, i);

гдеobby_proxy - это тот же лобби-объект в предыдущем коде. Сервер настроен следующим образом:

_port = global::Server.Properties.Settings.Default.Port;
_lobby = new Lobby(_db);

try
{
    TcpServerChannel channel = new TcpServerChannel(_port);
    ChannelServices.RegisterChannel(channel, false);
    RemotingConfiguration.RegisterWellKnownServiceType(typeof(Lobby),
            "Lobby", WellKnownObjectMode.Singleton);
    RemotingServices.Marshal((_lobby), "Lobby");
    System.Console.WriteLine("Press Any Key");
}
catch (Exception e)
{
    System.Console.WriteLine(e);
}

Это прекрасно работает при запуске на той же машине, но выдает следующую ошибку при запуске на разных машинах:

System.Net.Sockets.SocketException (0x80004005): A socket operation was attempte
d to an unreachable network 169.254.171.86:9932
   Exit
Server stack trace:
   at System.Net.Sockets.Socket.DoConnect(EndPoint endPointSnapshot, SocketAddre
ss socketAddress)
   at System.Net.Sockets.Socket.Connect(EndPoint remoteEP)
   at System.Runtime.Remoting.Channels.RemoteConnection.CreateNewSocket(EndPoint
 ipEndPoint)
   at System.Runtime.Remoting.Channels.RemoteConnection.CreateNewSocket()
   at System.Runtime.Remoting.Channels.RemoteConnection.GetSocket()
   at System.Runtime.Remoting.Channels.SocketCache.GetSocket(String machinePortA
ndSid, Boolean openNew)
   at System.Runtime.Remoting.Channels.Tcp.TcpClientTransportSink.SendRequestWit
hRetry(IMessage msg, ITransportHeaders requestHeaders, Stream requestStream)
   at System.Runtime.Remoting.Channels.Tcp.TcpClientTransportSink.ProcessMessage
(IMessage msg, ITransportHeaders requestHeaders, Stream requestStream, ITranspor
tHeaders& responseHeaders, Stream& responseStream)
   at System.Runtime.Remoting.Channels.BinaryClientFormatterSink.SyncProcessMess
age(IMessage msg)

Exception rethrown at [0]:
   at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage req
Msg, IMessage retMsg)
   at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgDa
ta, Int32 type)
   at JackOfTrades.Common.Table.GetTableData(Boolean full)

Глядя сверху, есть IP-адрес, который я не распознаю, он не находится ни в сети, ни в IP-адресе маршрутизатора.

Есть мысли о том, что не так? Помощь будет принята с благодарностью!

Ответы [ 2 ]

4 голосов
/ 09 ноября 2010

Вам необходимо настроить TcpServerChannel со следующим параметром:

bindTo
Строка, которая указывает IP-адрес сетевой интерфейсной платы (NIC), с которой должен быть связан канал сервера. Значением по умолчанию является System.Net.IPAddress.Any.

http://msdn.microsoft.com/en-us/library/bb397831.aspx

ОБНОВЛЕНИЕ:

IDictionary properties = new Hashtable();
properties["port"] = 9932;
properties["bindTo"] = "192.168.1.141";
TcpServerChannel channel = new TcpServerChannel(properties, null);
ChannelServices.RegisterChannel(channel,  false);
1 голос
/ 09 ноября 2010

Адрес 168.254.xx обычно виден, когда сетевой адаптер не может получить адрес DHCP.

Я бы хотел убедиться, что на машине, на которой вы запускаете этот код, действительный IP-адрес.*

...