Python: Socket не хочет shutdown (), а setsockopt () игнорируется? (Проблема отладки) - PullRequest
0 голосов
/ 31 июля 2011

Отредактировано

Исходный вопрос был о проблеме с переподключением (close () и shutdown () путаница).Приведенный ниже код является рабочим кодом (исправлено). Для Googler этот скрипт является ботом IRC.Список функций:

  • Продолжайте повторное подключение до тех пор, пока подключение не станет доступным
  • Если назначенный ник уже занят, ставит строку за именем (повторяется до успеха)
  • Прослушивает PING и отвечаетс PONG
  • Может прослушивать команды и отвечать
  • Если соединение потеряно, бот попытается восстановить соединение (если не получена информация, нет PING, через 5 минут, он обрабатывает соединение какесли он был отключен)

Вот и все:)

Полный код:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys
import socket
import string
import os
import platform
import time

# Variables
HOST = "irc.server.net"
PORT = 6667
NICK = "Nickname"
IDENT = "Nickname"
REALNAME = os.getenv('USER')
CHAN = "##Channel"
readbuffer = ""

# The Connection itself
keep_connecting = True
while keep_connecting:
    irc = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    irc.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    irc.settimeout(300)
    try:
        irc.connect((HOST, PORT))
        pass
    except socket.gaierror:
        print "No connection, attempting to connect again"
        time.sleep(5)
        continue
    print "Sending info..."
    irc.send("NICK %s\r\n" % NICK)
    irc.send("USER %s %s bla :%s\r\n" % (IDENT, HOST, REALNAME))
    irc.send("JOIN :%s\r\n" % CHAN)
    # Initial msg to send when bot connects
    irc.send("PRIVMSG %s :%s\r\n" % (CHAN, "TehBot: "+ NICK + " Realname: " + REALNAME + " ."))
    while True:
        try:
            data = irc.recv(4096)
            print data
            # If disconneted from IRC
            if len(data) == 0:
                print "Length of data == 0 ?..."
                break
            # If Nick is in use
            if data.find (NICK + " :Nickname is already in use") != -1:
                NICK = NICK + str(time.time())[5:-3]
                break
            # Ping Pong so we don't get disconnected
            if data[0:4] == "PING":
                irc.send ("PONG " + data.split() [ 1 ] + "\r\n")
        except socket.timeout:
            print "Socket timeout!"
            irc.close()
            break

1 Ответ

1 голос
/ 31 июля 2011

Скорее всего, это потому, что вы отключили Wi-Fi, и интерфейс удален из системы, и вы получите что-то вроде Невозможно назначить запрошенный адрес . Вы получите такую ​​ошибку при попытке привязки к несуществующему локальному адресу.

Другое дело, что вы не сможете повторно подключиться к тому же сокету после вызова close, поскольку он освобождает все ресурсы, связанные с сокетом.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...