Одобрено: ASR Pro
Повысьте производительность вашего компьютера с помощью этой простой загрузки. г.
Вот несколько простых способов решения проблемы, а также код ошибки Winsock 10065.Неправильный выбор сокета расширения 10060 – это ошибка winsock, обычно вызываемая удивительными проблемами с подключением или проблемами со здоровьем на стороне хоста. Исходящие соединения, скорее всего, связаны с наличием брандмауэра или антивирусного программного обеспечения в электронном или локальном сетевом соединении.
Ошибки сокета 10061, 10060, 10064, 10065
Ошибка вывода около 10060, вероятно, хорошая ошибка Winsock. Обычно это происходит из-за проблем с телефонным подключением или проблем с веб-подключением на стороне хоста.
На исходящие соединения, безусловно, может влиять любое присутствие антивирусного программного обеспечения или программного обеспечения на конкретном локальном компьютере или сетевом объединении. Оба могут блокировать эти порты, которые необходимы для установления приятного FTP-соединения с удаленным сервером. Для одного конкретного реального обычного сеанса FTP отключите брандмауэр, возможно, антивирусное программное обеспечение, или настройте их в разделе Разрешить CuteFTP для настройки сеанса обучения FTP на 20 портах и 21 программном продукте для ближайших будущих клиентов. Как правило, у производителя пакетов устройств также есть конкретные инструкции, которые можно получить на их веб-сайтах. Если вы по-прежнему получаете ту же ошибку, обязательно вскоре после открытия типов 20 и 21 обратитесь к администратору конкретного сайта, к которому вы пытаетесь подключиться.
10060 – это базовая ошибка тайм-аута соединения, которая чаще всего возникает, когда потенциальный клиент не получает ответ от вашего сервера на потрясающую конкретную команду. Эта ошибка часто возникает при генерации URL-адреса PASV для сервера, предпочитающего просто этот ПОРТ для подключений к данным. Если у пользователей есть журнал ошибок, аналогичный журналу похудания, нажмите «Ввести результаты» в свойствах сайта проблемы, а затем измените тип связи с информацией и фактами, которую вы можете использовать для ПОРТА.
Если вы по-прежнему получаете сплошную ошибку 10060, то как сервер может пытаться отправить каждый список непосредственно в каталог (с несколькими тысячами файлов), который ожидает клиента по таймауту. Попробуйте увеличить значение тайм-аута в определенном диалоговом окне «Глобальные параметры» («Инструменты»> «Глобальные параметры»> «Передача»> «Повторное подключение» и продолжайте в течение [n], если в течение нескольких секунд ничего не было рекомендовано) до более высокого значения, например, 45 или 60 секунд.
-
Соединение прервано или из-за тайм-аута ошибки.
-
Проверьте правильность целевого IP-адреса одного получателя.
-
Как правило, увеличивайте порог тайм-аута взаимодействия в разделе «Общие настройки»> «Подключение».
-
Одобрено: ASR Pro
ASR Pro — самый популярный и эффективный в мире инструмент для ремонта ПК. Миллионы людей доверяют ему обеспечение быстрой, бесперебойной и безошибочной работы своих систем. Благодаря простому пользовательскому интерфейсу и мощному механизму сканирования ASR Pro быстро находит и устраняет широкий спектр проблем Windows — от нестабильности системы и проблем с безопасностью до проблем с управлением памятью и производительностью.
- 1. Загрузите ASR Pro и установите его на свой компьютер.
- 2. Запустите программу и нажмите «Сканировать»
- 3. Нажмите «Восстановить», чтобы устранить обнаруженные проблемы.
Переключитесь на противоположный вид подключения для передачи данных (PASV или PORT) на сайте> Параметр Введите глаз.
При попытке подключиться к коммерческому серверу убедитесь, что это не маленький мой город.
Если использовалось имя сервера, убедитесь, что оно соответствует правильному адресу.
Если вы используете таблицу локального сервера, когда вам нужно разрешить заголовки сервера, убедитесь, что вы это делаете, а не преобразовываете ее в устаревшее расположение.
Попробуйте проверить связь со всеми адресами. (Дополнительные сведения и стратегии см. В разделе «Советы по устранению неполадок».)
Если клиенты используют маршрутизатор, убедитесь, что он работает (проверьте, выполнив эхо-запрос, а затем отправив эхо-запрос на адрес вне дома маршрутизатора).
Отслеживайте время маршрута до пункта назначения, чтобы убедиться, что все маршрутизаторы, расположенные рядом со ссылкой на пути, находятся в рабочем состоянии. (Для получения дополнительной информации см. Советы по устранению неполадок.)
Абсолютно убедитесь, что ваша подсеть настроена правильно.
10061 – это сообщение об ошибке «В соединении отказано», отправленное вам сервером. Вы не могли войти в систему, потому что наш целевой компьютер напрямую отказывался это делать. Наиболее частая причина – это исправный, неправильно настроенный сайт, полный сервер или несоответствующий порт, указанный на клиенте.
-
Откройте сайт. Затем менеджер решает перейти на сайт.
-
Перейдите в основное меню> Свойства файла.
-
Щелкните вкладку “Тип”.
-
Введите правильный номер порта в поле “Порт”.
Иногда ошибка 10061 возникает только из-за брандмауэра или антивирусного программного обеспечения на всем ближайшем компьютере или сетевом соединении. Оба могут блокировать порты, необходимые для успешного сетевого соединения FTP с сервером.
Для обычного сеанса FTP отключите брандмауэр, антивирус или утилиту, чтобы настроить его так, чтобы CuteFTP обнаруживал очень хороший сеанс FTP на обоих портах 20 и 21 лет. См. Документацию или файл дампа для конкретного брандмауэра или антивируса. Софт по инструкции. Обычно производитель нашего устройства или программного обеспечения предоставляет инструкции на своем веб-сайте.
Если вы, с другой стороны, получаете единственную ошибку после открытия портов 50 и 21, обратитесь к администратору всего сайта, к которому вы пытаетесь подключиться.
-
Удаленный хост активно отклонил попытку подключения.
-
Убедитесь, что IP-адрес целевого форума указан правильно
-
Тщательно проверьте действительный номер порта (в разделе “Настройки сайта”> вкладка “Тип”).
-
Удаленный компьютер может быть в данный момент или постоянно недоступен (повторите попытку позже).
-
Убедитесь, что вы выбрали правильный процесс (SSH2, SSL, FTP и т. д.) и что вам нужно настроить все необходимые параметры для каждого проекта.
-
Убедитесь, что большинство IP-адреса назначения и номеров портов оптимальны.
-
Удаленный сервер вполне может отклонить множество подключений от соответствующего клиента. Попробуйте использовать конкретный одиночный провод при подключении к определенному компьютеру (Настройки сайта> Параметры).
-
Попробуйте проверить почтовый адрес.
-
Если вы на самом деле используете маршрутизатор, убедитесь, что коммутатор работает, пока (просто проверьте его, а затем откликнитесь эхом на исправление за пределами маршрутизатора).
-
Отслеживайте время своего маршрута до фактического пункта назначения, чтобы убедиться, что все модемы, подключенные к Интернету, также работают.
-
Убедитесь, что маска подсети настроена правильно.
-
Сервер в отпуске, возможно, постоянно недоступен. Пожалуйста, проверьте правильность имени хоста и / или IP-адреса назначения и попробуйте позже.
-
Сервер очень недоступен. Проверьте, является ли имя хоста назначения наиболее подходящим, возможно, IP-адресом, и повторите попытку.
г.
← →
FireMan_Alexey
(2003-06-26 16:30)
[0]
Суть дела такова. У меня есть адрес или хост к которому мне надо приконектиться, но я не знаю существует ли он вообще. Используя
TClientSocket, получаю ошибку
10065 —
«узел отсутствует»
, как я понимаю!
Но отловить ее ни в OnError ни в Try Except не могу.
Посоветуйте пожалуйста как быть.
Не хотелось бы переделывать работу заново.
Пробовал писать, как советует DigitMan, в OnError
Socket.Disconnect(Socket.SocketHandle);
Но это событие даже не возникает, а ошибку выдает сразу после
ClientSocket.Open;
← →
Карелин Артем
(2003-06-26 16:48)
[1]
Может Application.OnException спасет…
← →
Digitman
(2003-06-26 17:01)
[2]
код приведи свой
и — режим какой у тебя … блок или неблок
← →
Delphin
(2003-06-26 17:30)
[3]
ClientSocket1.Host:=Edit1.Text;
Try
ClientSocket1.Connect;
Except
….
DestroyWindow(WM_Close);
……
End;
← →
FireMan_Alexey
(2003-06-27 14:39)
[4]
>DigitMan
режим не блокирующий
текст
Procedure TMain.ProxyServClientRead(Sender: TObject;Socket: TCustomWinSocket);
Var
S,S1:String;
I1,I2,L:Integer;
Buf:Pointer;
Begin
//
IF TClientSocket(Socket.Data).Active then
Begin
I1:=Socket.ReceiveLength;
GetMem(Buf,I1);
Socket.ReceiveBuf(Buf^,I1);
TClientSocket(Socket.Data).Socket.SendBuf(Buf^,I1);// Отсылаю данные
FreeMem(Buf,I1);
End
Else
Begin
L:=Socket.ReceiveLength;
S:=Socket.ReceiveText;
I1:=Pos("Host",S)+6;
I2:=Pos("Proxy",S)-2;
S1:=Copy(S,I1,I2-I1);
If not GetAddr(S1,80) Then
Begin
Socket.SendText(ErrorProxy_HTTP(ProxyErrors[1]));
Socket.Disconnect(Socket.SocketHandle);
Exit;
End;
TClientSocket(Socket.Data).Port:=80;//Настраиваю порт
TClientSocket(Socket.Data).Host:=S1;//Хост
TClientSocket(Socket.Data).Open; //Пытаюсь коннектиться
(
Socket.Data)
>DigitMan
режим не блокирующий
текст
Procedure TMain.ProxyServClientRead(Sender: TObject;Socket: TCustomWinSocket);
Var
S,S1:String;
I1,I2,L:Integer;
Buf:Pointer;
Begin
//
IF TClientSocket(Socket.Data).Active then
Begin
I1:=Socket.ReceiveLength;
GetMem(Buf,I1);
Socket.ReceiveBuf(Buf^,I1);
TClientSocket(Socket.Data).Socket.SendBuf(Buf^,I1);// Отсылаю данные
FreeMem(Buf,I1);
End
Else
Begin
L:=Socket.ReceiveLength;
S:=Socket.ReceiveText;
I1:=Pos("Host",S)+6;
I2:=Pos("Proxy",S)-2;
S1:=Copy(S,I1,I2-I1);
If not GetAddr(S1,80) Then
Begin
Socket.SendText(ErrorProxy_HTTP(ProxyErrors[1]));
Socket.Disconnect(Socket.SocketHandle);
Exit;
End;
TClientSocket(Socket.Data).Port:=80;//Настраиваю порт
TClientSocket(Socket.Data).Host:=S1;//Хост
TClientSocket(Socket.Data).Open; //Пытаюсь коннектиться
TClientSocket(Socket.Data).Socket.SendText(S);// Отсылаю запрос
Label3.Caption:=S1;
End;
End;
← →
Digitman
(2003-06-27 14:57)
[5]
нет, подожди)
ты ведешь речь прежде всего о перехвате и обработке ошибок коннекта
где у тебя в коде обработка OnError() ? не вижу.
это — раз..
теперь — следующее.
ты утверждаешь, что режим для всех гнезд — неблокирующий.
тогда на основании чего ты сразу же за
TClientSocket(Socket.Data).Open; (
Socket.Data)
нет, подожди)
ты ведешь речь прежде всего о перехвате и обработке ошибок коннекта
где у тебя в коде обработка OnError() ? не вижу.
это — раз..
теперь — следующее.
ты утверждаешь, что режим для всех гнезд — неблокирующий.
тогда на основании чего ты сразу же за
TClientSocket(Socket.Data).Open; //Пытаюсь коннектиться
делаешь
TClientSocket(Socket.Data).Socket.SendText(S);// Отсылаю запрос
??? где и каким образом ты фиксируешь факт успешной попытки коннекта, прежде чем пытаться отослать запрос через устанавливаемое соединение ?
← →
FireMan_Alexey
(2003-07-01 15:02)
[6]
>DigitMan
procedure TMain.ProxyServClientError(Sender: TObject;
Socket: TCustomWinSocket; ErrorEvent: TErrorEvent;
var ErrorCode: Integer);
begin
//
Socket.Disconnect(Socket.SocketHandle);
ErrorCode:=0;
end;
Суть в том, что просто пробовал законектиться на существующий сайт указывая IP-адрес например 135.34.34.80 порт 80 и просто вызывал ClientSocket.Open, но если я в текущий момент не в интернете, то выдается ошибка 10065,
если же я указываю именно HOST, то OnError обрабатывает ошибку.
У меня своя подсеть. Маска подсети указана вручную 255.255.255.0
IP- ареса в диапазоне 192.168.0.*
возможно из-за данных настроек я не могу нормально законнектиться в инет?
А то, что я отсылаю сразу после OPEN, я исправил это и все раво не работает.
Извиняюсь что не прислал исходный код, я сейчас не на своей машине и исходника с собою нет.
← →
Digitman
(2003-07-02 08:36)
[7]
> то выдается ошибка 10065
> то OnError обрабатывает ошибку
не верю !!!!
при приведенном тобой теле OnError() ошибка будет «погашена» в любом случае, будь тобой указан или Host или Address — совершенно никакой разницы.
> то, что я отсылаю сразу после OPEN, я исправил это и все
> раво не работает
и каким же образом ты «исправил» ?
сдается мне, что по-прежнему (!) отказ с кодом 10065 ты имеешь при попытке выполнить именно метод send в момент после выполнения Open, но ДО момента реального коннекта либо возникновения события OnError()
← →
Digitman
(2003-07-02 08:45)
[8]
ты пойми главное — поскольку гнездо неблокирующее, то метод Open тут же возвратит тебе управление, еще ДО того, как будет фактически установлен коннект либо отказано в нем по каким-то причинам (связанным как правило с недоступностью/неактивностью целевого хоста/сервиса или с невозможностью с пом. DNS разрешить имя хоста в его IP-адрес).
о факте успешного коннекта говорит возникновение события OnConnect()
о факте НЕуспешного коннекта говорит возникновение события OnError() (причина отказа — в ErrorCode)
и вот ДО того, как возникнет событие OnConnect() выполнять какие-либо транспортные методы гнезда (send- либо receive-методы) совершенно бессмысленно — это 100%-но приведет к исключению ESocketError (а не к возбуждению события OnError !)
← →
FireMan_Alexey
(2003-07-02 16:50)
[9]
>Digitman
У меня еще вопрос, где можно достать описание функций
на русском
socket
bind
и т.д.
← →
Digitman
(2003-07-02 17:13)
[10]
http://book.itep.ru
← →
panov
(2003-07-02 17:15)
[11]
У меня еще вопрос, где можно достать описание функций на русском
только переводы кусками в сети.
← →
FireMan_Alexey
(2003-07-03 13:14)
[12]
>Digitman
Просто экспериментировал и получил вот что.
В этом простом примере у меня возникает ошибка 10065 и я не могу ее отловить.
Возможно я где-то ошибаюсь
1. CS.Active=False в начале
2. Режим неблок.
3. Интернета нет
unit Example;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ScktComp;
type
TForm1 = class(TForm)
CS: TClientSocket;
procedure FormCreate(Sender: TObject);
procedure CSError(Sender: TObject; Socket: TCustomWinSocket;
ErrorEvent: TErrorEvent; var ErrorCode: Integer);
private
{ Private declarations }
public
(
Sender: TObject)
>Digitman
Просто экспериментировал и получил вот что.
В этом простом примере у меня возникает ошибка 10065 и я не могу ее отловить.
Возможно я где-то ошибаюсь :)
1. CS.Active=False в начале
2. Режим неблок.
3. Интернета нет
unit Example;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ScktComp;
type
TForm1 = class(TForm)
CS: TClientSocket;
procedure FormCreate(Sender: TObject);
procedure CSError(Sender: TObject; Socket: TCustomWinSocket;
ErrorEvent: TErrorEvent; var ErrorCode: Integer);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.FormCreate(Sender: TObject);
begin
cs.Port:=80;
cs.Host:="154.34.34.80";
cs.Open;
end;
procedure TForm1.CSError(Sender: TObject; Socket: TCustomWinSocket;
ErrorEvent: TErrorEvent; var ErrorCode: Integer);
begin
ErrorCode:=0;
Socket.Disconnect(Socket.SocketHandle);
end;
← →
FireMan_Alexey
(2003-07-03 13:19)
[13]
>Panov
А где достать эти обрывки?
← →
Digitman
(2003-07-03 13:32)
[14]
procedure TForm1.FormCreate(Sender: TObject);
begin
cs.Port:=80;
cs.Address:=»154.34.34.80″;
try
cs.Open;
except
on e: ESocketError do
(
«Уррааа !!! Я поймал синхронную ошибку коннекта :»#10 + e.message)
procedure TForm1.FormCreate(Sender: TObject);
begin
cs.Port:=80;
cs.Address:=»154.34.34.80″;
try
cs.Open;
except
on e: ESocketError do
ShowMessage(«Уррааа !!! Я поймал синхронную ошибку коннекта :»#10 + e.message);
else
raise;
end;
end;
← →
Digitman
(2003-07-03 13:38)
[15]
> FireMan_Alexey
ты вообще-то в состоянии читать и анализировать исх.Паскаль-тексты стандартных компонентов от Борланда ? Ведь все что тебя заботило и будет заботить, элементарно выясняется анализом кода в модуле scktcomp.pas !
← →
Douglas Quaid
(2003-07-11 10:35)
[16]
Предусмотри в On Error следующее
ErrorCode := 0;
это «гасит» ошибку, в противном случае OnError выполняется, но ошибка соединения «всплывает»
This blog post was originally posted on JetBrains .NET blog.
Rider consists of several processes that send messages to each other via sockets. To ensure the reliability of the whole application, it’s important to properly handle all the socket errors. In our codebase, we had the following code which was adopted from Mono Debugger Libs and helps us communicate with debugger processes:
protected virtual bool ShouldRetryConnection (Exception ex, int attemptNumber)
{
var sx = ex as SocketException;
if (sx != null) {
if (sx.ErrorCode == 10061) //connection refused
return true;
}
return false;
}
In the case of a failed connection because of a “ConnectionRefused” error, we are retrying the connection attempt. It works fine with .NET Framework and Mono. However, once we migrated to .NET Core, this method no longer correctly detects the “connection refused” situation on Linux and macOS. If we open the SocketException
documentation, we will learn that this class has three different properties with error codes:
SocketError SocketErrorCode
: Gets the error code that is associated with this exception.int ErrorCode
: Gets the error code that is associated with this exception.int NativeErrorCode
: Gets the Win32 error code associated with this exception.
What’s the difference between these properties? Should we expect different values on different runtimes or different operating systems? Which one should we use in production? Why do we have problems with ShouldRetryConnection
on .NET Core? Let’s figure it all out!
Digging into the problem
Let’s start with the following program, which prints error code property values for SocketError.ConnectionRefused
:
var se = new SocketException((int) SocketError.ConnectionRefused);
Console.WriteLine((int)se.SocketErrorCode);
Console.WriteLine(se.ErrorCode);
Console.WriteLine(se.NativeErrorCode);
If we run it on Windows, we will get the same value on .NET Framework, Mono, and .NET Core:
SocketErrorCode | ErrorCode | NativeErrorCode | |
.NET Framework | 10061 | 10061 | 10061 |
Mono | 10061 | 10061 | 10061 |
.NET Core | 10061 | 10061 | 10061 |
10061 corresponds to the code of the connection refused socket error code in Windows (also known as WSAECONNREFUSED
).
Now let’s run the same program on Linux:
SocketErrorCode | ErrorCode | NativeErrorCode | |
Mono | 10061 | 10061 | 10061 |
.NET Core | 10061 | 111 | 111 |
As you can see, Mono returns Windows-compatible error codes. The situation with .NET Core is different: it returns a Windows-compatible value for SocketErrorCode (10061) and a Linux-like value for ErrorCode
and NativeErrorCode
(111).
Finally, let’s check macOS:
SocketErrorCode | ErrorCode | NativeErrorCode | |
Mono | 10061 | 10061 | 10061 |
.NET Core | 10061 | 61 | 61 |
Here, Mono is completely Windows-compatible again, but .NET Core returns 61 for ErrorCode
and NativeErrorCode
.
In the IBM Knowledge Center, we can find a few more values for the connection refused error code from the Unix world (also known as ECONNREFUSED
):
- AIX: 79
- HP-UX: 239
- Solaris: 146
For a better understanding of what’s going on, let’s check out the source code of all the properties.
SocketErrorCode
SocketException.SocketErrorCode
returns a value from the SocketError
enum. The numerical values of the enum elements are the same on all the runtimes (see its implementation in .NET Framework, .NET Core 3.1.3, and Mono 6.8.0.105):
public enum SocketError
{
SocketError = -1, // 0xFFFFFFFF
Success = 0,
OperationAborted = 995, // 0x000003E3
IOPending = 997, // 0x000003E5
Interrupted = 10004, // 0x00002714
AccessDenied = 10013, // 0x0000271D
Fault = 10014, // 0x0000271E
InvalidArgument = 10022, // 0x00002726
TooManyOpenSockets = 10024, // 0x00002728
WouldBlock = 10035, // 0x00002733
InProgress = 10036, // 0x00002734
AlreadyInProgress = 10037, // 0x00002735
NotSocket = 10038, // 0x00002736
DestinationAddressRequired = 10039, // 0x00002737
MessageSize = 10040, // 0x00002738
ProtocolType = 10041, // 0x00002739
ProtocolOption = 10042, // 0x0000273A
ProtocolNotSupported = 10043, // 0x0000273B
SocketNotSupported = 10044, // 0x0000273C
OperationNotSupported = 10045, // 0x0000273D
ProtocolFamilyNotSupported = 10046, // 0x0000273E
AddressFamilyNotSupported = 10047, // 0x0000273F
AddressAlreadyInUse = 10048, // 0x00002740
AddressNotAvailable = 10049, // 0x00002741
NetworkDown = 10050, // 0x00002742
NetworkUnreachable = 10051, // 0x00002743
NetworkReset = 10052, // 0x00002744
ConnectionAborted = 10053, // 0x00002745
ConnectionReset = 10054, // 0x00002746
NoBufferSpaceAvailable = 10055, // 0x00002747
IsConnected = 10056, // 0x00002748
NotConnected = 10057, // 0x00002749
Shutdown = 10058, // 0x0000274A
TimedOut = 10060, // 0x0000274C
ConnectionRefused = 10061, // 0x0000274D
HostDown = 10064, // 0x00002750
HostUnreachable = 10065, // 0x00002751
ProcessLimit = 10067, // 0x00002753
SystemNotReady = 10091, // 0x0000276B
VersionNotSupported = 10092, // 0x0000276C
NotInitialized = 10093, // 0x0000276D
Disconnecting = 10101, // 0x00002775
TypeNotFound = 10109, // 0x0000277D
HostNotFound = 11001, // 0x00002AF9
TryAgain = 11002, // 0x00002AFA
NoRecovery = 11003, // 0x00002AFB
NoData = 11004, // 0x00002AFC
}
These values correspond to the Windows Sockets Error Codes.
NativeErrorCode
In .NET Framework and Mono, SocketErrorCode
and NativeErrorCode
always have the same values:
public SocketError SocketErrorCode {
//
// the base class returns the HResult with this property
// we need the Win32 Error Code, hence the override.
//
get {
return (SocketError)NativeErrorCode;
}
}
In .NET Core, the native code is calculated in the constructor (see SocketException.cs#L20):
public SocketException(int errorCode) : this((SocketError)errorCode)
// ...
internal SocketException(SocketError socketError) : base(GetNativeErrorForSocketError(socketError))
The Windows implementation of GetNativeErrorForSocketError
is trivial (see SocketException.Windows.cs):
private static int GetNativeErrorForSocketError(SocketError error)
{
// SocketError values map directly to Win32 error codes
return (int)error;
}
The Unix implementation is more complicated (see SocketException.Unix.cs):
private static int GetNativeErrorForSocketError(SocketError error)
{
int nativeErr = (int)error;
if (error != SocketError.SocketError)
{
Interop.Error interopErr;
// If an interop error was not found, then don't invoke Info().RawErrno as that will fail with assert.
if (SocketErrorPal.TryGetNativeErrorForSocketError(error, out interopErr))
{
nativeErr = interopErr.Info().RawErrno;
}
}
return nativeErr;
}
TryGetNativeErrorForSocketError
should convert SocketError
to the native Unix error code.
Unfortunately, there exists no unequivocal mapping between Windows and Unix error codes. As such, the .NET team decided to create a Dictionary
that maps error codes in the best possible way (see SocketErrorPal.Unix.cs):
private const int NativeErrorToSocketErrorCount = 42;
private const int SocketErrorToNativeErrorCount = 40;
// No Interop.Errors are included for the following SocketErrors, as there's no good mapping:
// - SocketError.NoRecovery
// - SocketError.NotInitialized
// - SocketError.ProcessLimit
// - SocketError.SocketError
// - SocketError.SystemNotReady
// - SocketError.TypeNotFound
// - SocketError.VersionNotSupported
private static readonly Dictionary<Interop.Error, SocketError> s_nativeErrorToSocketError = new Dictionary<Interop.Error, SocketError>(NativeErrorToSocketErrorCount)
{
{ Interop.Error.EACCES, SocketError.AccessDenied },
{ Interop.Error.EADDRINUSE, SocketError.AddressAlreadyInUse },
{ Interop.Error.EADDRNOTAVAIL, SocketError.AddressNotAvailable },
{ Interop.Error.EAFNOSUPPORT, SocketError.AddressFamilyNotSupported },
{ Interop.Error.EAGAIN, SocketError.WouldBlock },
{ Interop.Error.EALREADY, SocketError.AlreadyInProgress },
{ Interop.Error.EBADF, SocketError.OperationAborted },
{ Interop.Error.ECANCELED, SocketError.OperationAborted },
{ Interop.Error.ECONNABORTED, SocketError.ConnectionAborted },
{ Interop.Error.ECONNREFUSED, SocketError.ConnectionRefused },
{ Interop.Error.ECONNRESET, SocketError.ConnectionReset },
{ Interop.Error.EDESTADDRREQ, SocketError.DestinationAddressRequired },
{ Interop.Error.EFAULT, SocketError.Fault },
{ Interop.Error.EHOSTDOWN, SocketError.HostDown },
{ Interop.Error.ENXIO, SocketError.HostNotFound }, // not perfect, but closest match available
{ Interop.Error.EHOSTUNREACH, SocketError.HostUnreachable },
{ Interop.Error.EINPROGRESS, SocketError.InProgress },
{ Interop.Error.EINTR, SocketError.Interrupted },
{ Interop.Error.EINVAL, SocketError.InvalidArgument },
{ Interop.Error.EISCONN, SocketError.IsConnected },
{ Interop.Error.EMFILE, SocketError.TooManyOpenSockets },
{ Interop.Error.EMSGSIZE, SocketError.MessageSize },
{ Interop.Error.ENETDOWN, SocketError.NetworkDown },
{ Interop.Error.ENETRESET, SocketError.NetworkReset },
{ Interop.Error.ENETUNREACH, SocketError.NetworkUnreachable },
{ Interop.Error.ENFILE, SocketError.TooManyOpenSockets },
{ Interop.Error.ENOBUFS, SocketError.NoBufferSpaceAvailable },
{ Interop.Error.ENODATA, SocketError.NoData },
{ Interop.Error.ENOENT, SocketError.AddressNotAvailable },
{ Interop.Error.ENOPROTOOPT, SocketError.ProtocolOption },
{ Interop.Error.ENOTCONN, SocketError.NotConnected },
{ Interop.Error.ENOTSOCK, SocketError.NotSocket },
{ Interop.Error.ENOTSUP, SocketError.OperationNotSupported },
{ Interop.Error.EPERM, SocketError.AccessDenied },
{ Interop.Error.EPIPE, SocketError.Shutdown },
{ Interop.Error.EPFNOSUPPORT, SocketError.ProtocolFamilyNotSupported },
{ Interop.Error.EPROTONOSUPPORT, SocketError.ProtocolNotSupported },
{ Interop.Error.EPROTOTYPE, SocketError.ProtocolType },
{ Interop.Error.ESOCKTNOSUPPORT, SocketError.SocketNotSupported },
{ Interop.Error.ESHUTDOWN, SocketError.Disconnecting },
{ Interop.Error.SUCCESS, SocketError.Success },
{ Interop.Error.ETIMEDOUT, SocketError.TimedOut },
};
private static readonly Dictionary<SocketError, Interop.Error> s_socketErrorToNativeError = new Dictionary<SocketError, Interop.Error>(SocketErrorToNativeErrorCount)
{
// This is *mostly* an inverse mapping of s_nativeErrorToSocketError. However, some options have multiple mappings and thus
// can't be inverted directly. Other options don't have a mapping from native to SocketError, but when presented with a SocketError,
// we want to provide the closest relevant Error possible, e.g. EINPROGRESS maps to SocketError.InProgress, and vice versa, but
// SocketError.IOPending also maps closest to EINPROGRESS. As such, roundtripping won't necessarily provide the original value 100% of the time,
// but it's the best we can do given the mismatch between Interop.Error and SocketError.
{ SocketError.AccessDenied, Interop.Error.EACCES}, // could also have been EPERM
{ SocketError.AddressAlreadyInUse, Interop.Error.EADDRINUSE },
{ SocketError.AddressNotAvailable, Interop.Error.EADDRNOTAVAIL },
{ SocketError.AddressFamilyNotSupported, Interop.Error.EAFNOSUPPORT },
{ SocketError.AlreadyInProgress, Interop.Error.EALREADY },
{ SocketError.ConnectionAborted, Interop.Error.ECONNABORTED },
{ SocketError.ConnectionRefused, Interop.Error.ECONNREFUSED },
{ SocketError.ConnectionReset, Interop.Error.ECONNRESET },
{ SocketError.DestinationAddressRequired, Interop.Error.EDESTADDRREQ },
{ SocketError.Disconnecting, Interop.Error.ESHUTDOWN },
{ SocketError.Fault, Interop.Error.EFAULT },
{ SocketError.HostDown, Interop.Error.EHOSTDOWN },
{ SocketError.HostNotFound, Interop.Error.EHOSTNOTFOUND },
{ SocketError.HostUnreachable, Interop.Error.EHOSTUNREACH },
{ SocketError.InProgress, Interop.Error.EINPROGRESS },
{ SocketError.Interrupted, Interop.Error.EINTR },
{ SocketError.InvalidArgument, Interop.Error.EINVAL },
{ SocketError.IOPending, Interop.Error.EINPROGRESS },
{ SocketError.IsConnected, Interop.Error.EISCONN },
{ SocketError.MessageSize, Interop.Error.EMSGSIZE },
{ SocketError.NetworkDown, Interop.Error.ENETDOWN },
{ SocketError.NetworkReset, Interop.Error.ENETRESET },
{ SocketError.NetworkUnreachable, Interop.Error.ENETUNREACH },
{ SocketError.NoBufferSpaceAvailable, Interop.Error.ENOBUFS },
{ SocketError.NoData, Interop.Error.ENODATA },
{ SocketError.NotConnected, Interop.Error.ENOTCONN },
{ SocketError.NotSocket, Interop.Error.ENOTSOCK },
{ SocketError.OperationAborted, Interop.Error.ECANCELED },
{ SocketError.OperationNotSupported, Interop.Error.ENOTSUP },
{ SocketError.ProtocolFamilyNotSupported, Interop.Error.EPFNOSUPPORT },
{ SocketError.ProtocolNotSupported, Interop.Error.EPROTONOSUPPORT },
{ SocketError.ProtocolOption, Interop.Error.ENOPROTOOPT },
{ SocketError.ProtocolType, Interop.Error.EPROTOTYPE },
{ SocketError.Shutdown, Interop.Error.EPIPE },
{ SocketError.SocketNotSupported, Interop.Error.ESOCKTNOSUPPORT },
{ SocketError.Success, Interop.Error.SUCCESS },
{ SocketError.TimedOut, Interop.Error.ETIMEDOUT },
{ SocketError.TooManyOpenSockets, Interop.Error.ENFILE }, // could also have been EMFILE
{ SocketError.TryAgain, Interop.Error.EAGAIN }, // not a perfect mapping, but better than nothing
{ SocketError.WouldBlock, Interop.Error.EAGAIN },
};
internal static bool TryGetNativeErrorForSocketError(SocketError error, out Interop.Error errno)
{
return s_socketErrorToNativeError.TryGetValue(error, out errno);
}
Once we have an instance of Interop.Error
, we call interopErr.Info().RawErrno
. The implementation of RawErrno can be found in Interop.Errors.cs:
internal int RawErrno
{
get { return _rawErrno == -1 ? (_rawErrno = Interop.Sys.ConvertErrorPalToPlatform(_error)) : _rawErrno; }
}
[DllImport(Libraries.SystemNative, EntryPoint = "SystemNative_ConvertErrorPalToPlatform")]
internal static extern int ConvertErrorPalToPlatform(Error error);
Here we are jumping to the native function SystemNative_ConvertErrorPalToPlatform that maps Error to the native integer code that is defined in errno.h. You can get all the values using the errno util. Here is a typical output on Linux:
$ errno -ls
EPERM 1 Operation not permitted
ENOENT 2 No such file or directory
ESRCH 3 No such process
EINTR 4 Interrupted system call
EIO 5 Input/output error
ENXIO 6 No such device or address
E2BIG 7 Argument list too long
ENOEXEC 8 Exec format error
EBADF 9 Bad file descriptor
ECHILD 10 No child processes
EAGAIN 11 Resource temporarily unavailable
ENOMEM 12 Cannot allocate memory
EACCES 13 Permission denied
EFAULT 14 Bad address
ENOTBLK 15 Block device required
EBUSY 16 Device or resource busy
EEXIST 17 File exists
EXDEV 18 Invalid cross-device link
ENODEV 19 No such device
ENOTDIR 20 Not a directory
EISDIR 21 Is a directory
EINVAL 22 Invalid argument
ENFILE 23 Too many open files in system
EMFILE 24 Too many open files
ENOTTY 25 Inappropriate ioctl for device
ETXTBSY 26 Text file busy
EFBIG 27 File too large
ENOSPC 28 No space left on device
ESPIPE 29 Illegal seek
EROFS 30 Read-only file system
EMLINK 31 Too many links
EPIPE 32 Broken pipe
EDOM 33 Numerical argument out of domain
ERANGE 34 Numerical result out of range
EDEADLK 35 Resource deadlock avoided
ENAMETOOLONG 36 File name too long
ENOLCK 37 No locks available
ENOSYS 38 Function not implemented
ENOTEMPTY 39 Directory not empty
ELOOP 40 Too many levels of symbolic links
EWOULDBLOCK 11 Resource temporarily unavailable
ENOMSG 42 No message of desired type
EIDRM 43 Identifier removed
ECHRNG 44 Channel number out of range
EL2NSYNC 45 Level 2 not synchronized
EL3HLT 46 Level 3 halted
EL3RST 47 Level 3 reset
ELNRNG 48 Link number out of range
EUNATCH 49 Protocol driver not attached
ENOCSI 50 No CSI structure available
EL2HLT 51 Level 2 halted
EBADE 52 Invalid exchange
EBADR 53 Invalid request descriptor
EXFULL 54 Exchange full
ENOANO 55 No anode
EBADRQC 56 Invalid request code
EBADSLT 57 Invalid slot
EDEADLOCK 35 Resource deadlock avoided
EBFONT 59 Bad font file format
ENOSTR 60 Device not a stream
ENODATA 61 No data available
ETIME 62 Timer expired
ENOSR 63 Out of streams resources
ENONET 64 Machine is not on the network
ENOPKG 65 Package not installed
EREMOTE 66 Object is remote
ENOLINK 67 Link has been severed
EADV 68 Advertise error
ESRMNT 69 Srmount error
ECOMM 70 Communication error on send
EPROTO 71 Protocol error
EMULTIHOP 72 Multihop attempted
EDOTDOT 73 RFS specific error
EBADMSG 74 Bad message
EOVERFLOW 75 Value too large for defined data type
ENOTUNIQ 76 Name not unique on network
EBADFD 77 File descriptor in bad state
EREMCHG 78 Remote address changed
ELIBACC 79 Can not access a needed shared library
ELIBBAD 80 Accessing a corrupted shared library
ELIBSCN 81 .lib section in a.out corrupted
ELIBMAX 82 Attempting to link in too many shared libraries
ELIBEXEC 83 Cannot exec a shared library directly
EILSEQ 84 Invalid or incomplete multibyte or wide character
ERESTART 85 Interrupted system call should be restarted
ESTRPIPE 86 Streams pipe error
EUSERS 87 Too many users
ENOTSOCK 88 Socket operation on non-socket
EDESTADDRREQ 89 Destination address required
EMSGSIZE 90 Message too long
EPROTOTYPE 91 Protocol wrong type for socket
ENOPROTOOPT 92 Protocol not available
EPROTONOSUPPORT 93 Protocol not supported
ESOCKTNOSUPPORT 94 Socket type not supported
EOPNOTSUPP 95 Operation not supported
EPFNOSUPPORT 96 Protocol family not supported
EAFNOSUPPORT 97 Address family not supported by protocol
EADDRINUSE 98 Address already in use
EADDRNOTAVAIL 99 Cannot assign requested address
ENETDOWN 100 Network is down
ENETUNREACH 101 Network is unreachable
ENETRESET 102 Network dropped connection on reset
ECONNABORTED 103 Software caused connection abort
ECONNRESET 104 Connection reset by peer
ENOBUFS 105 No buffer space available
EISCONN 106 Transport endpoint is already connected
ENOTCONN 107 Transport endpoint is not connected
ESHUTDOWN 108 Cannot send after transport endpoint shutdown
ETOOMANYREFS 109 Too many references: cannot splice
ETIMEDOUT 110 Connection timed out
ECONNREFUSED 111 Connection refused
EHOSTDOWN 112 Host is down
EHOSTUNREACH 113 No route to host
EALREADY 114 Operation already in progress
EINPROGRESS 115 Operation now in progress
ESTALE 116 Stale file handle
EUCLEAN 117 Structure needs cleaning
ENOTNAM 118 Not a XENIX named type file
ENAVAIL 119 No XENIX semaphores available
EISNAM 120 Is a named type file
EREMOTEIO 121 Remote I/O error
EDQUOT 122 Disk quota exceeded
ENOMEDIUM 123 No medium found
EMEDIUMTYPE 124 Wrong medium type
ECANCELED 125 Operation canceled
ENOKEY 126 Required key not available
EKEYEXPIRED 127 Key has expired
EKEYREVOKED 128 Key has been revoked
EKEYREJECTED 129 Key was rejected by service
EOWNERDEAD 130 Owner died
ENOTRECOVERABLE 131 State not recoverable
ERFKILL 132 Operation not possible due to RF-kill
EHWPOISON 133 Memory page has hardware error
ENOTSUP 95 Operation not supported
Note that errno
may be not available by default in your Linux distro. For example, on Debian, you should call sudo apt-get install moreutils
to get this utility.
Here is a typical output on macOS:
$ errno -ls
EPERM 1 Operation not permitted
ENOENT 2 No such file or directory
ESRCH 3 No such process
EINTR 4 Interrupted system call
EIO 5 Input/output error
ENXIO 6 Device not configured
E2BIG 7 Argument list too long
ENOEXEC 8 Exec format error
EBADF 9 Bad file descriptor
ECHILD 10 No child processes
EDEADLK 11 Resource deadlock avoided
ENOMEM 12 Cannot allocate memory
EACCES 13 Permission denied
EFAULT 14 Bad address
ENOTBLK 15 Block device required
EBUSY 16 Resource busy
EEXIST 17 File exists
EXDEV 18 Cross-device link
ENODEV 19 Operation not supported by device
ENOTDIR 20 Not a directory
EISDIR 21 Is a directory
EINVAL 22 Invalid argument
ENFILE 23 Too many open files in system
EMFILE 24 Too many open files
ENOTTY 25 Inappropriate ioctl for device
ETXTBSY 26 Text file busy
EFBIG 27 File too large
ENOSPC 28 No space left on device
ESPIPE 29 Illegal seek
EROFS 30 Read-only file system
EMLINK 31 Too many links
EPIPE 32 Broken pipe
EDOM 33 Numerical argument out of domain
ERANGE 34 Result too large
EAGAIN 35 Resource temporarily unavailable
EWOULDBLOCK 35 Resource temporarily unavailable
EINPROGRESS 36 Operation now in progress
EALREADY 37 Operation already in progress
ENOTSOCK 38 Socket operation on non-socket
EDESTADDRREQ 39 Destination address required
EMSGSIZE 40 Message too long
EPROTOTYPE 41 Protocol wrong type for socket
ENOPROTOOPT 42 Protocol not available
EPROTONOSUPPORT 43 Protocol not supported
ESOCKTNOSUPPORT 44 Socket type not supported
ENOTSUP 45 Operation not supported
EPFNOSUPPORT 46 Protocol family not supported
EAFNOSUPPORT 47 Address family not supported by protocol family
EADDRINUSE 48 Address already in use
EADDRNOTAVAIL 49 Can`t assign requested address
ENETDOWN 50 Network is down
ENETUNREACH 51 Network is unreachable
ENETRESET 52 Network dropped connection on reset
ECONNABORTED 53 Software caused connection abort
ECONNRESET 54 Connection reset by peer
ENOBUFS 55 No buffer space available
EISCONN 56 Socket is already connected
ENOTCONN 57 Socket is not connected
ESHUTDOWN 58 Can`t send after socket shutdown
ETOOMANYREFS 59 Too many references: can`t splice
ETIMEDOUT 60 Operation timed out
ECONNREFUSED 61 Connection refused
ELOOP 62 Too many levels of symbolic links
ENAMETOOLONG 63 File name too long
EHOSTDOWN 64 Host is down
EHOSTUNREACH 65 No route to host
ENOTEMPTY 66 Directory not empty
EPROCLIM 67 Too many processes
EUSERS 68 Too many users
EDQUOT 69 Disc quota exceeded
ESTALE 70 Stale NFS file handle
EREMOTE 71 Too many levels of remote in path
EBADRPC 72 RPC struct is bad
ERPCMISMATCH 73 RPC version wrong
EPROGUNAVAIL 74 RPC prog. not avail
EPROGMISMATCH 75 Program version wrong
EPROCUNAVAIL 76 Bad procedure for program
ENOLCK 77 No locks available
ENOSYS 78 Function not implemented
EFTYPE 79 Inappropriate file type or format
EAUTH 80 Authentication error
ENEEDAUTH 81 Need authenticator
EPWROFF 82 Device power is off
EDEVERR 83 Device error
EOVERFLOW 84 Value too large to be stored in data type
EBADEXEC 85 Bad executable (or shared library)
EBADARCH 86 Bad CPU type in executable
ESHLIBVERS 87 Shared library version mismatch
EBADMACHO 88 Malformed Mach-o file
ECANCELED 89 Operation canceled
EIDRM 90 Identifier removed
ENOMSG 91 No message of desired type
EILSEQ 92 Illegal byte sequence
ENOATTR 93 Attribute not found
EBADMSG 94 Bad message
EMULTIHOP 95 EMULTIHOP (Reserved)
ENODATA 96 No message available on STREAM
ENOLINK 97 ENOLINK (Reserved)
ENOSR 98 No STREAM resources
ENOSTR 99 Not a STREAM
EPROTO 100 Protocol error
ETIME 101 STREAM ioctl timeout
EOPNOTSUPP 102 Operation not supported on socket
ENOPOLICY 103 Policy not found
ENOTRECOVERABLE 104 State not recoverable
EOWNERDEAD 105 Previous owner died
EQFULL 106 Interface output queue is full
ELAST 106 Interface output queue is full
Hooray! We’ve finished our fascinating journey into the internals of socket error codes. Now you know where .NET is getting the native error code for each SocketException
from!
ErrorCode
The ErrorCode
property is the most boring one, as it always returns NativeErrorCode
.
.NET Framework, Mono 6.8.0.105:
public override int ErrorCode {
//
// the base class returns the HResult with this property
// we need the Win32 Error Code, hence the override.
//
get {
return NativeErrorCode;
}
}
In .NET Core 3.1.3:
public override int ErrorCode => base.NativeErrorCode;
Writing cross-platform socket error handling
Circling back to the original method we started this post with, we rewrote ShouldRetryConnection as follows:
protected virtual bool ShouldRetryConnection(Exception ex)
{
if (ex is SocketException sx)
return sx.SocketErrorCode == SocketError.ConnectionRefused;
return false;
}
There was a lot of work involved in tracking down the error code to check against, but in the end, our code is much more readable now. Adding to that, this method is now also completely cross-platform, and works correctly on any runtime.
Overview of the native error codes
In some situations, you may want to have a table with native error codes on different operating systems. We can get these values with the following code snippet:
var allErrors = Enum.GetValues(typeof(SocketError)).Cast<SocketError>().ToList();
var maxNameWidth = allErrors.Select(x => x.ToString().Length).Max();
foreach (var socketError in allErrors)
{
var name = socketError.ToString().PadRight(maxNameWidth);
var code = new SocketException((int) socketError).NativeErrorCode.ToString().PadLeft(7);
Console.WriteLine("| {name} | {code} |");
}
We executed this program on Windows, Linux, and macOS. Here are the aggregated results:
SocketError | Windows | Linux | macOS |
Success | 0 | 0 | 0 |
OperationAborted | 995 | 125 | 89 |
IOPending | 997 | 115 | 36 |
Interrupted | 10004 | 4 | 4 |
AccessDenied | 10013 | 13 | 13 |
Fault | 10014 | 14 | 14 |
InvalidArgument | 10022 | 22 | 22 |
TooManyOpenSockets | 10024 | 23 | 23 |
WouldBlock | 10035 | 11 | 35 |
InProgress | 10036 | 115 | 36 |
AlreadyInProgress | 10037 | 114 | 37 |
NotSocket | 10038 | 88 | 38 |
DestinationAddressRequired | 10039 | 89 | 39 |
MessageSize | 10040 | 90 | 40 |
ProtocolType | 10041 | 91 | 41 |
ProtocolOption | 10042 | 92 | 42 |
ProtocolNotSupported | 10043 | 93 | 43 |
SocketNotSupported | 10044 | 94 | 44 |
OperationNotSupported | 10045 | 95 | 45 |
ProtocolFamilyNotSupported | 10046 | 96 | 46 |
AddressFamilyNotSupported | 10047 | 97 | 47 |
AddressAlreadyInUse | 10048 | 98 | 48 |
AddressNotAvailable | 10049 | 99 | 49 |
NetworkDown | 10050 | 100 | 50 |
NetworkUnreachable | 10051 | 101 | 51 |
NetworkReset | 10052 | 102 | 52 |
ConnectionAborted | 10053 | 103 | 53 |
ConnectionReset | 10054 | 104 | 54 |
NoBufferSpaceAvailable | 10055 | 105 | 55 |
IsConnected | 10056 | 106 | 56 |
NotConnected | 10057 | 107 | 57 |
Shutdown | 10058 | 32 | 32 |
TimedOut | 10060 | 110 | 60 |
ConnectionRefused | 10061 | 111 | 61 |
HostDown | 10064 | 112 | 64 |
HostUnreachable | 10065 | 113 | 65 |
ProcessLimit | 10067 | 10067 | 10067 |
SystemNotReady | 10091 | 10091 | 10091 |
VersionNotSupported | 10092 | 10092 | 10092 |
NotInitialized | 10093 | 10093 | 10093 |
Disconnecting | 10101 | 108 | 58 |
TypeNotFound | 10109 | 10109 | 10109 |
HostNotFound | 11001 | -131073 | -131073 |
TryAgain | 11002 | 11 | 35 |
NoRecovery | 11003 | 11003 | 11003 |
NoData | 11004 | 61 | 96 |
SocketError | -1 | -1 | -1 |
This table may be useful if you work with native socket error codes.
Summary
From this investigation, we’ve learned the following:
SocketException.SocketErrorCode
returns a value from theSocketError
enum. The numerical values of the enum elements always correspond to the Windows socket error codes.SocketException.ErrorCode
always returnsSocketException.NativeErrorCode
.SocketException.NativeErrorCode
on .NET Framework and Mono always corresponds to the Windows error codes (even if you are using Mono on Unix). On .NET Core,SocketException.NativeErrorCode
equals the corresponding native error code from the current operating system.
A few practical recommendations:
- If you want to write portable code, always use
SocketException.SocketErrorCode
and compare it with the values ofSocketError
. Never use raw numerical error codes. - If you want to get the native error code on .NET Core (e.g., for passing to another native program), use
SocketException.NativeErrorCode
. Remember that different Unix-based operating systems (e.g., Linux, macOS, Solaris) have different native code sets. You can get the exact values of the native error codes by using the errno command.
References
- Microsoft Docs: Windows Sockets Error Codes
- IBM Knowledge Center: TCP/IP error codes
- MariaDB: Operating System Error Codes
- gnu.org: Error Codes
- Stackoverflow: Identical Error Codes
← →
FireMan_Alexey
(2003-06-26 16:30)
[0]
Суть дела такова. У меня есть адрес или хост к которому мне надо приконектиться, но я не знаю существует ли он вообще. Используя
TClientSocket, получаю ошибку
10065 —
«узел отсутствует»
, как я понимаю!
Но отловить ее ни в OnError ни в Try Except не могу.
Посоветуйте пожалуйста как быть.
Не хотелось бы переделывать работу заново.
Пробовал писать, как советует DigitMan, в OnError
Socket.Disconnect(Socket.SocketHandle);
Но это событие даже не возникает, а ошибку выдает сразу после
ClientSocket.Open;
← →
Карелин Артем
(2003-06-26 16:48)
[1]
Может Application.OnException спасет…
← →
Digitman
(2003-06-26 17:01)
[2]
код приведи свой
и — режим какой у тебя … блок или неблок
← →
Delphin
(2003-06-26 17:30)
[3]
ClientSocket1.Host:=Edit1.Text;
Try
ClientSocket1.Connect;
Except
….
DestroyWindow(WM_Close);
……
End;
← →
FireMan_Alexey
(2003-06-27 14:39)
[4]
>DigitMan
режим не блокирующий
текст
Procedure TMain.ProxyServClientRead(Sender: TObject;Socket: TCustomWinSocket);
Var
S,S1:String;
I1,I2,L:Integer;
Buf:Pointer;
Begin
//
IF TClientSocket(Socket.Data).Active then
Begin
I1:=Socket.ReceiveLength;
GetMem(Buf,I1);
Socket.ReceiveBuf(Buf^,I1);
TClientSocket(Socket.Data).Socket.SendBuf(Buf^,I1);// Отсылаю данные
FreeMem(Buf,I1);
End
Else
Begin
L:=Socket.ReceiveLength;
S:=Socket.ReceiveText;
I1:=Pos("Host",S)+6;
I2:=Pos("Proxy",S)-2;
S1:=Copy(S,I1,I2-I1);
If not GetAddr(S1,80) Then
Begin
Socket.SendText(ErrorProxy_HTTP(ProxyErrors[1]));
Socket.Disconnect(Socket.SocketHandle);
Exit;
End;
TClientSocket(Socket.Data).Port:=80;//Настраиваю порт
TClientSocket(Socket.Data).Host:=S1;//Хост
TClientSocket(Socket.Data).Open; //Пытаюсь коннектиться
(
Socket.Data)
>DigitMan
режим не блокирующий
текст
Procedure TMain.ProxyServClientRead(Sender: TObject;Socket: TCustomWinSocket);
Var
S,S1:String;
I1,I2,L:Integer;
Buf:Pointer;
Begin
//
IF TClientSocket(Socket.Data).Active then
Begin
I1:=Socket.ReceiveLength;
GetMem(Buf,I1);
Socket.ReceiveBuf(Buf^,I1);
TClientSocket(Socket.Data).Socket.SendBuf(Buf^,I1);// Отсылаю данные
FreeMem(Buf,I1);
End
Else
Begin
L:=Socket.ReceiveLength;
S:=Socket.ReceiveText;
I1:=Pos("Host",S)+6;
I2:=Pos("Proxy",S)-2;
S1:=Copy(S,I1,I2-I1);
If not GetAddr(S1,80) Then
Begin
Socket.SendText(ErrorProxy_HTTP(ProxyErrors[1]));
Socket.Disconnect(Socket.SocketHandle);
Exit;
End;
TClientSocket(Socket.Data).Port:=80;//Настраиваю порт
TClientSocket(Socket.Data).Host:=S1;//Хост
TClientSocket(Socket.Data).Open; //Пытаюсь коннектиться
TClientSocket(Socket.Data).Socket.SendText(S);// Отсылаю запрос
Label3.Caption:=S1;
End;
End;
← →
Digitman
(2003-06-27 14:57)
[5]
нет, подожди)
ты ведешь речь прежде всего о перехвате и обработке ошибок коннекта
где у тебя в коде обработка OnError() ? не вижу.
это — раз..
теперь — следующее.
ты утверждаешь, что режим для всех гнезд — неблокирующий.
тогда на основании чего ты сразу же за
TClientSocket(Socket.Data).Open; (
Socket.Data)
нет, подожди)
ты ведешь речь прежде всего о перехвате и обработке ошибок коннекта
где у тебя в коде обработка OnError() ? не вижу.
это — раз..
теперь — следующее.
ты утверждаешь, что режим для всех гнезд — неблокирующий.
тогда на основании чего ты сразу же за
TClientSocket(Socket.Data).Open; //Пытаюсь коннектиться
делаешь
TClientSocket(Socket.Data).Socket.SendText(S);// Отсылаю запрос
??? где и каким образом ты фиксируешь факт успешной попытки коннекта, прежде чем пытаться отослать запрос через устанавливаемое соединение ?
← →
FireMan_Alexey
(2003-07-01 15:02)
[6]
>DigitMan
procedure TMain.ProxyServClientError(Sender: TObject;
Socket: TCustomWinSocket; ErrorEvent: TErrorEvent;
var ErrorCode: Integer);
begin
//
Socket.Disconnect(Socket.SocketHandle);
ErrorCode:=0;
end;
Суть в том, что просто пробовал законектиться на существующий сайт указывая IP-адрес например 135.34.34.80 порт 80 и просто вызывал ClientSocket.Open, но если я в текущий момент не в интернете, то выдается ошибка 10065,
если же я указываю именно HOST, то OnError обрабатывает ошибку.
У меня своя подсеть. Маска подсети указана вручную 255.255.255.0
IP- ареса в диапазоне 192.168.0.*
возможно из-за данных настроек я не могу нормально законнектиться в инет?
А то, что я отсылаю сразу после OPEN, я исправил это и все раво не работает.
Извиняюсь что не прислал исходный код, я сейчас не на своей машине и исходника с собою нет.
← →
Digitman
(2003-07-02 08:36)
[7]
> то выдается ошибка 10065
> то OnError обрабатывает ошибку
не верю !!!!
при приведенном тобой теле OnError() ошибка будет «погашена» в любом случае, будь тобой указан или Host или Address — совершенно никакой разницы.
> то, что я отсылаю сразу после OPEN, я исправил это и все
> раво не работает
и каким же образом ты «исправил» ?
сдается мне, что по-прежнему (!) отказ с кодом 10065 ты имеешь при попытке выполнить именно метод send в момент после выполнения Open, но ДО момента реального коннекта либо возникновения события OnError()
← →
Digitman
(2003-07-02 08:45)
[8]
ты пойми главное — поскольку гнездо неблокирующее, то метод Open тут же возвратит тебе управление, еще ДО того, как будет фактически установлен коннект либо отказано в нем по каким-то причинам (связанным как правило с недоступностью/неактивностью целевого хоста/сервиса или с невозможностью с пом. DNS разрешить имя хоста в его IP-адрес).
о факте успешного коннекта говорит возникновение события OnConnect()
о факте НЕуспешного коннекта говорит возникновение события OnError() (причина отказа — в ErrorCode)
и вот ДО того, как возникнет событие OnConnect() выполнять какие-либо транспортные методы гнезда (send- либо receive-методы) совершенно бессмысленно — это 100%-но приведет к исключению ESocketError (а не к возбуждению события OnError !)
← →
FireMan_Alexey
(2003-07-02 16:50)
[9]
>Digitman
У меня еще вопрос, где можно достать описание функций
на русском
socket
bind
и т.д.
← →
Digitman
(2003-07-02 17:13)
[10]
http://book.itep.ru
← →
panov
(2003-07-02 17:15)
[11]
У меня еще вопрос, где можно достать описание функций на русском
только переводы кусками в сети.
← →
FireMan_Alexey
(2003-07-03 13:14)
[12]
>Digitman
Просто экспериментировал и получил вот что.
В этом простом примере у меня возникает ошибка 10065 и я не могу ее отловить.
Возможно я где-то ошибаюсь
1. CS.Active=False в начале
2. Режим неблок.
3. Интернета нет
unit Example;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ScktComp;
type
TForm1 = class(TForm)
CS: TClientSocket;
procedure FormCreate(Sender: TObject);
procedure CSError(Sender: TObject; Socket: TCustomWinSocket;
ErrorEvent: TErrorEvent; var ErrorCode: Integer);
private
{ Private declarations }
public
(
Sender: TObject)
>Digitman
Просто экспериментировал и получил вот что.
В этом простом примере у меня возникает ошибка 10065 и я не могу ее отловить.
Возможно я где-то ошибаюсь :)
1. CS.Active=False в начале
2. Режим неблок.
3. Интернета нет
unit Example;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ScktComp;
type
TForm1 = class(TForm)
CS: TClientSocket;
procedure FormCreate(Sender: TObject);
procedure CSError(Sender: TObject; Socket: TCustomWinSocket;
ErrorEvent: TErrorEvent; var ErrorCode: Integer);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.FormCreate(Sender: TObject);
begin
cs.Port:=80;
cs.Host:="154.34.34.80";
cs.Open;
end;
procedure TForm1.CSError(Sender: TObject; Socket: TCustomWinSocket;
ErrorEvent: TErrorEvent; var ErrorCode: Integer);
begin
ErrorCode:=0;
Socket.Disconnect(Socket.SocketHandle);
end;
← →
FireMan_Alexey
(2003-07-03 13:19)
[13]
>Panov
А где достать эти обрывки?
← →
Digitman
(2003-07-03 13:32)
[14]
procedure TForm1.FormCreate(Sender: TObject);
begin
cs.Port:=80;
cs.Address:=»154.34.34.80″;
try
cs.Open;
except
on e: ESocketError do
(
«Уррааа !!! Я поймал синхронную ошибку коннекта :»#10 + e.message)
procedure TForm1.FormCreate(Sender: TObject);
begin
cs.Port:=80;
cs.Address:=»154.34.34.80″;
try
cs.Open;
except
on e: ESocketError do
ShowMessage(«Уррааа !!! Я поймал синхронную ошибку коннекта :»#10 + e.message);
else
raise;
end;
end;
← →
Digitman
(2003-07-03 13:38)
[15]
> FireMan_Alexey
ты вообще-то в состоянии читать и анализировать исх.Паскаль-тексты стандартных компонентов от Борланда ? Ведь все что тебя заботило и будет заботить, элементарно выясняется анализом кода в модуле scktcomp.pas !
← →
Douglas Quaid
(2003-07-11 10:35)
[16]
Предусмотри в On Error следующее
ErrorCode := 0;
это «гасит» ошибку, в противном случае OnError выполняется, но ошибка соединения «всплывает»
|
|
To Fix (Solved: Socket Error: 10065, Error Number: 0x800CCC0E) error you need to |
|
Шаг 1: |
|
---|---|
Download (Solved: Socket Error: 10065, Error Number: 0x800CCC0E) Repair Tool |
|
Шаг 2: |
|
Нажмите «Scan» кнопка | |
Шаг 3: |
|
Нажмите ‘Исправь все‘ и вы сделали! | |
Совместимость: |
Решение: Ошибка сокета: 10065, Номер ошибки: 0x800CCC0E обычно вызвано неверно настроенными системными настройками или нерегулярными записями в реестре Windows. Эта ошибка может быть исправлена специальным программным обеспечением, которое восстанавливает реестр и настраивает системные настройки для восстановления стабильности
Если у вас есть Solved: Socket Error: 10065, номер ошибки: 0x800CCC0E, тогда мы настоятельно рекомендуем вам
Загрузить (исправлено: Ошибка сокета: 10065, номер ошибки: 0x800CCC0E) Инструмент восстановления.
This article contains information that shows you how to fix
Solved: Socket Error: 10065, Error Number: 0x800CCC0E
both
(manually) and (automatically) , In addition, this article will help you troubleshoot some common error messages related to Solved: Socket Error: 10065, Error Number: 0x800CCC0E that you may receive.
Примечание:
Эта статья была обновлено на 2023-09-16 и ранее опубликованный под WIKI_Q210794
Содержание
- 1. Meaning of Solved: Socket Error: 10065, Error Number: 0x800CCC0E?
- 2. Causes of Solved: Socket Error: 10065, Error Number: 0x800CCC0E?
- 3. More info on Solved: Socket Error: 10065, Error Number: 0x800CCC0E
Значение Solved: Ошибка сокета: 10065, Номер ошибки: 0x800CCC0E?
A mistake or inaccuracy, an error is caused about by committing miscalculations on the things that you do. It is a state of having a wrong judgement or conception in your conduct that allows catastrophic things to happen. In machines, error is a way to measure the difference between the observed value or the computed value of an event against its real value.
It is a deviation from correctness and accuracy. When errors occur, machines crash, computers freeze and softwares stop working. Errors are mostly unintentional events to happen. Most of the time, errors are a result of poor management and preparation.
Причины решения: Ошибка сокета: 10065, Номер ошибки: 0x800CCC0E?
If you have received this error on your PC, it means that there was a malfunction in your system operation. Common reasons include incorrect or failed installation or uninstallation of software that may have left invalid entries in your Windows registry, consequences of a virus or malware attack, improper system shutdown due to a power failure or another factor, someone with little technical knowledge accidentally deleting a necessary system file or registry entry, as well as a number of other causes. The immediate cause of the «Solved: Socket Error: 10065, Error Number: 0x800CCC0E» error is a failure to correctly run one of its normal operations by a system or application component.
More info on
Solved: Socket Error: 10065, Error Number: 0x800CCC0E
РЕКОМЕНДУЕМЫЕ: Нажмите здесь, чтобы исправить ошибки Windows и оптимизировать производительность системы.
Account: ‘Joint French’, Server: ‘pop.orange.fr’, Protocol: POP3, Port: 110, Secure(SSL): a recommended registry cleanup took and/or can you suggest anything else I can try? Socket error 10065 from Outlook Express
Hi, for the last few days we have been receiving «The connection to the server has failed.
Internet search implies it may be a broekn registry entry but is there this problem as the title was incorrect. Much appreciated
Just for completeness — I found the No, Socket Error: 10065, Error Number: 0x800CCC0E» from Outlook Express.
Sorry but I had to re-post cause of the error was nothing to do with ports.
Отправить проблему с Windows Mail. Ошибка сокета: 10060, номер ошибки: 0x800CCC0E
Привет, я просмотрел все темы обсуждения и попробовал Йорк, и теперь я использую другого провайдера для подключения к Интернету. Не только номера портов, но и все другие настройки.
Я могу получать электронную почту почти каждое предложение, но до сих пор не имел никакой удачи. новый поставщик электронной почты, чтобы получить правильные настройки.
Тема «Тест», Учетная запись: «O2 Email», Сервер: «smtp.o2.co.uk», Протокол: SMTP, Порт: 25, Secure (SSL): но не может отправлять. благодаря
You must go to the website of What triggered this error is that, I recently moved from London to New No, Socket Error: 10060, Error Number: 0x800CCC0E»
Любая помощь будет высоко ценится.
Ошибка сокета: 10060, номер ошибки: 0x800CCC0E
Поскольку мой puter находится на том же кабеле, что и мой телефон, мне нужен SERVER — ваш SMTP-сервер, который вы используете в Outlook Express для своей учетной записи MSN).
Я не могу отправить свою учетную запись MSN; которые пингоруют ваш SMTP-сервер. Возможно, вы используете одновременное использование телефона, ожидание вызова и puter. Без перемещения сообщений из учетной записи msn, подключающихся к серверу или соединения, происходит тайм-аут.
Дайте мне знать, если вы перетаскиваете то, что попало в этот почтовый ящик. Это был вопрос включения и выключения), может также мешать? Попробуйте превратить сервер, и вы не можете этого сделать?
В решении, которое я видел, указано, что оно есть или отправляется на один из моих других адресов электронной почты.
You can try to them off temporarily. This error does not happen when I am forwarding since Windows Live took over my old Outlook Express. Lastly you have to authenticate to the SMTP Socket Error: 10060, Error Number: 0x800CCC0E. Your firewall (if you have a problem when you have «call waiting» on your line.
I get the error: get a reply or not. Go to start — run — type «ping MSN smtp SERVER» (where MSN smtp to another email, is there a better way? Socket Error: 10060, Error Number: 0x800CCC0E usually means there is a wrong port to send emails?
ошибка выражения outlook 0x800ccc0e и ошибка сокета 10013
Now set up an email for the new user.Here are the instructions from Microsoft.http://windows.microsoft.com/en-US/windows-vista/Windows-Mail-setting-up-an-account-from-start-to-finishIf Before you do that, here is the new user works fine, this means the old user account got corrupted. Reboot and log something less destructive.Create a new user account.
в нового пользователя.
Номер ошибки 0x800CCC0E Ошибка Outlook Express
Every time I open Outlook Express I get «cleaners» but they do not work. Please advise this error message::::::
The connection to the server has failed. ASAP»
Спасибо
HOGFAN
Я пробовал все типы
Ошибка сокета электронной почты 10013 0x800CCC0E
Мы счастливо загрузили наши новые электронные письма за последние 12 месяцев и никогда не сталкивались с проблемой раньше.
У нас есть сеть компьютеров 12 и возникла проблема с загрузкой писем с почтового сервера, который размещен в другом месте.
Номер ошибки: 0x800CCC0E
Account: ‘Dad’, Server: ‘pop.ntlworld.com’, Protocol: POP3, Port: 995, Secure(SSL): Yes, Socket Error: 10060, Error Number: 0x800CCC0E
Спасибо, если вы можете помочь
Киран
Привет, я получаю это сообщение при попытке отправить / получить почту в Outlook Express
Не удалось подключиться к серверу.
Номер ошибки: 0x800CCC0E Vista SP1 OLE — 6.0.600.16386
У меня ошибка Google и ошибка SP1, поскольку я отправлял почту раньше. Скотт
Ошибка: 10061, номер ошибки: 0x800CCC0E
Поддерживает ли Хартия SSL-соединения SSL на порту 25? Subject ‘test’, Account: ‘******’, Server: ‘mail.charter.net’, Протокол: SMTP, Порт: 25, Secure (SSL): Нет, Socket SP1 и получение этой ошибки. Большинство серверов используют порт 465.
Попробуйте установить параметр Отключить порт на 465. Если это не сработает, попробуйте отключить брандмауэр и не получится. Все настройки в электронной почте, но если я попытаюсь отправить почту, я получу это.
Связь сделала все, о чем говорили. Я могу получить почту, и она будет отправлять и получать SSL без использования порта 25.
Использование Outlook Express 6.0.600.16386 Vista, как и должно быть. Похоже, что это сработало с момента установки сервера.
Ошибка Outlook Express: номер 10061 0x800ccc0e
Иногда может перезагружать компьютер с помощью сервера.
I recently get «Error — connection Norton. with no error and the other one will not. Windows XP.
Используйте и недавно удалили. Никакой шаблон, насколько он работает, а какой нет. Все настройки верны. В следующий раз без использования ярлыка.
Не стесняйтесь удачи. Поступили в Сеть. В некоторых случаях учетная запись одного человека будет появляться Нет для входа в систему.
Thanks. We have three identities will not. Have attempted to log and modem and will work. Was infected with to server has failed» numbers above.
XP OE 6.00.2900.2180 — Ошибка сокета: 10053, номер ошибки: 0x900CCC0F
Когда я нажимаю send и получаю все 3, я получаю следующую ошибку:
Твой конец.
Хорошо, я избегаю перестройки, если это вообще возможно.
Любой сервер неожиданно прекратил соединение.
еще? Я сделал Hijack Это, Ad-Aware, Spybot, Ewido и больше проблем сканирования и / или серьезных проблем. Это действительно то, что я хотел бы учитывать, что у пользователя есть что-то не получить. Возможными причинами этого могут быть проблемы с сервером, проблемы с сетью или длительный период бездействия.
W98SE-getting socket error 11001 & error number 0x800CCC0D
Решено: ошибка 0x800CCC0E
Сообщение об ошибке не предоставило таких же результатов, как указано там, то есть, пожалуйста, заполните то, что произошло с сервером
проверить это
http://answers.microsoft.com/en-us/…800ccc0e/04acbb3a-2d66-4a49-aca1-264fedae862f
За последние два дня эта ошибка все еще появляется. Предыдущий поток на ту же тему ошибки (ошибка 0x800CCC0E) подробности Мне не хватает.
Cheers.
подключение к коду возникло при активации отправки / получения.
Решено: ошибка SMTP Yahoo. 0x800ccc0e
I use MS Outlook 2000 settings and nothing has changed. I have triple checked all o’wise ones? Any ideas I am now unable to send my emails. Mega
и мой провайдер — Freeserve.
После многих лет никаких проблем с этим, 0x800ccc0e
I tried ‘detect and repair’ which was suggested someplace but it did not work. I get: unable to connect to server (acct: yahoo.co.uk) SMTP server: SMTP.mail.yahoo.co.uk ERROR
Решение: Ошибка Windows Live Mail 0x800CCC0E
Все они ранее имели место в течение более одного года использования.
У меня Windows Vista Home Premium, и я
Спасибо
предлагаемое исправление? Это новая проблема, которая никогда не использует Windows Live Mail с Comcast в качестве моего интернет-провайдера.
Кто-нибудь отправляется в Исходящие.
Решение: отчет об ошибке Outlook Express 0x800CCC0E
Оцените любые предложения относительно того, что может быть проблемой.
Когда я пытаюсь загрузить новые сообщения, я получаю сообщение об ошибке 0x800CCC0E.
I’m using outlook express 6 on XP.
Сообщение об ошибке 0x800ccc0E
Здравствуйте-
I’m at can receive) in Outlook Express 5. Post back with the smtp settings on fix solutions, but still the same problem. Can’t send E-Mail messages (but error number 0x800ccc0E. Computer, as far as the computer as they are now.
I’m receiving a different (new) identity, but still no luck. Thanks- Dog
Its usually as simple as I can see, is clean. I’ve run several virus scans, but nothing found. I’ve also uninstalled and reinstalled Outlook Express, tried a mis-spelt server name or wrong port.
Any wits end. I’ve visited several websites and followed their Ideas???
Ошибка Outlook 0x800ccc0e
Я получаю следующую ошибку Номер ошибки 0x800ccc0e)
кто знает, как остановить его?
Невозможно подключиться к серверу. (Учетная запись «что-то», сервер POP3 «yourdomain.com» при попытке получить электронную почту.
Ошибка Outlook Express 0x800CCC0E
Lots of times people attribute a non-responsive mail server with a checks out, we’ll try some other stuff.
на несколько дней.
Получили эти две вещи в первую очередь, и если все не имеет проблем с сервером электронной почты.
Now I am connection to the server has failed. Make sure that your ISP is problem on their machine and that is not always the case. Outlook express worked fine new computer. I get the following message «The unable to send/receive.
Ошибка получения почты Windows 0x800ccc0e
Всем привет,
I am having a weird issue Can someone please assist me, I am stumped, happen on a laptop i bought last week. and don’t know what else to try.
Ошибка почтовой системы Windows 0x800CCC0E
Код ошибки сокета при попытке проверить мой адрес электронной почты. Хорошо, что он отлично справился годами. Дайте это назад и, надеюсь, ошибка 10061 .. еще попробовать.
I use a personal domain and I can access the mail through but no difference. I’ve checked that my settings are correct and the only difference was the outgoing Luck
Maz1
Не уверен, что почтовый сервер был настроен на порт 25, и мой cpanel говорит, что он должен быть 26.
Four days ago I started getting the above my cpanel so it’s not server problems. Changed it it will work for you too. Not sure what that means anything.
Win Live Mail — ОШИБКА 0x800CCC0E
This could, for example, indicate a lack of memory on your system. Server: ‘imap.mail.com’
Идентификатор ошибки Windows Live Mail: или получать сообщения.
Не удалось отправить 0x800CCC0E
Протокол: IMAP
Порт: 995
Безопасный (SSL): Да
Соединение для отправки на сервер из-за несетевых ошибок.
Ответ сервера: ваша команда IMAP не может быть сервером.
-
usser
- Сообщения: 4
- Зарегистрирован: Вт май 24, 2011 7:06 am
Ошибка — sendto () failed: 10065
Здравствуйте
Обнаружил в логе приложений вот такую ошибку
Валится с периодичностью от нескольких секунд до нескольких минут, как определить причину?
Код: Выделить всё
Тип события: Ошибка
Источник события: WTware TFTP
Категория события: Отсутствует
Код события: 0
Дата: 24.05.2011
Время: 8:01:40
Пользователь: Н/Д
Компьютер: SERV
Описание:
sendto () failed: 10065
-
aka
- Разработчик
- Сообщения: 11676
- Зарегистрирован: Ср окт 01, 2003 12:06 am
- Откуда: Роcсия, Тольятти
- Контактная информация:
Re: Ошибка — sendto () failed: 10065
Сообщение
aka »
10065 — WSAEHOSTUNREACH
Хочу полностью лог TFTP. Пуск — wtware — конфигуратор — утилиты — Лог службы TFTP.
-
usser
- Сообщения: 4
- Зарегистрирован: Вт май 24, 2011 7:06 am
Re: Ошибка — sendto () failed: 10065
Сообщение
usser »
тоже самое(
на данный момент всего 2 терминала настроено и как я понял пользуются ими не слишком часто
и это весь лог… не понятно почему Журнал приложений забит ошибками, а в логе программы нет.. сервер не ребутился, сервисы не перезапускались
последние изменение в сети — переход на dhcp, не знаю была ли эта ошибка раньше, т.к. записей до введения dhcp просто нет, всё затёрто этой ошибкой
Код: Выделить всё
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
ERROR : sendto () failed: 10065
-
aka
- Разработчик
- Сообщения: 11676
- Зарегистрирован: Ср окт 01, 2003 12:06 am
- Откуда: Роcсия, Тольятти
- Контактная информация:
Re: Ошибка — sendto () failed: 10065
Сообщение
aka »
Хочу лог tftp с самого начала.
Запусти конфигуратор-администратор, открой страницу с логом службы TFTP и нажми кнопку «перезапустить», она сверху. Служба при запуске покажет немного диагностической информации в самом начале лога, вот ее я хочу увидеть.
-
usser
- Сообщения: 4
- Зарегистрирован: Вт май 24, 2011 7:06 am
Re: Ошибка — sendto () failed: 10065
Сообщение
usser »
извините, но такого конфигуратора не нашёл…может быть версия программы не та?
C:\Program Files\WTware\TFTPDROOT\lite\4.5.24\
в меню Пуск только это
Код: Выделить всё
WTware\Boot from CD\
WTware\Boot from IDE\
WTware\Boot from USB\
WTware\Documents\
WTware\Event viewer.lnk
WTware\First steps - boot ways.lnk
WTware\Setup password.lnk
-
aka
- Разработчик
- Сообщения: 11676
- Зарегистрирован: Ср окт 01, 2003 12:06 am
- Откуда: Роcсия, Тольятти
- Контактная информация:
Re: Ошибка — sendto () failed: 10065
Сообщение
aka »
Не, лайт двухлетней давности я починить уже не смогу. Берите свежую wtware 4.9, она лучше
-
usser
- Сообщения: 4
- Зарегистрирован: Вт май 24, 2011 7:06 am
Re: Ошибка — sendto () failed: 10065
Сообщение
usser »
дело оказалось в циске, деталей не знаю, то ли конфиг загрузить по tftp пыталась, то ли …
после отключения соответсвующей опции на циске, ошибки прекратились
Итак максимум что я накопал по коду 10065 VAG это ошибка по расходомеру на форуме по транспортеру)
После изучения Васи был найден режим чтения по протоколу obd2, данный режим позволяет читать машины любых марок и данные по протоколу obd2.
После того как данный режим показал код соответсвующий неисправности цепи расходомера я убедился в правильности моих поисков и вооружившись фонариком пошёл проверять проводку.
Ошибки стер Васей и все ок.