Programação funcional: python3 usa módulo de soquete para simular a conexão TCP-processo multi-cliente multi-cliente

Para simular o processo de comunicação TCP, este exemplo se conecta várias vezes, usando um método de múltiplos processos. A função realizada é que o multi-cliente se conecta à porta 21567 do servidor, o método de conexão é TCP, envia dados ao servidor, o servidor imprime os dados e, em seguida, envia feedback ([hora atual] envia dados) para cada cliente

importar soquete
importar sistema operacional a
partir do momento

host = ''
porta = 21567
addr = (host, porta)
s = socket.socket ()
s.setsockopt (socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
s.bind (addr)
s.listen (2)

while True: ## O servidor de controle de loop externo aguarda para receber a conexão do cliente
    cli_sock, cli_addr = s.accept ()
    pid = os.fork () ## Use a função fork do módulo os para copiar o processo.
    if pid: ## Julgamento, se pid não for 0, é igual ao processo principal
        cli_sock.close () ## O processo principal é responsável apenas pela conexão do servidor, feche a conexão do cliente
        enquanto True: ## Adicione um loop para controlar o processo principal O
            resultado da operação do processo zombie result = os.waitpid (-1, 1) [0] ## Aqui, -1 representa o formato da linguagem C, 1 significa que o processo não trava, porque o resultado retornado pelo os.waitpid é um yuan Grupo, o primeiro item da tupla é o pid do processo. Então, pegue a seguinte tabela 0
            if result == 0: ## Julgamento, se o processo filho pid for 0, significa que é um processo zumbi (saída), not 0 é uma
                interrupção normal do processo filho em execução
    : else # # Se pid não for 0, será igual a um filho Processo
        s.close () ## O processo filho é responsável por todas as operações do cliente. Mas não é responsável pela operação do servidor, então feche o servidor.
        while True: ## O loop interno é responsável por controlar a recepção e a transmissão de
            dados do servidor rdata = cli_sock.recv (1024)
            rdata = rdata.decode ('utf8')
            se rdata.strip () == 'quit':
                break
            print ( rdata.strip ())
            sdata = '[% s]% s'% (strftime ('% H:% S:% M'), rdata)
            cli_sock.send (sdata.encode ('utf8'))
        cli_sock.close ()
        exit () # Aqui é muito importante. Aqui está o trabalho que pertence ao processo filho. Caso contrário, escreva exit. Depois que o processo filho concluir seu trabalho, ele entrará novamente no loop e o processo filho também gerará um processo filho, resultando em uma bomba de forquilha.
s.close ()


Este exemplo é várias conexões, a programação funcional e a execução do programa são executadas de cima para baixo. Relativamente fácil de entender. Em geral, o servidor espera para receber dados, mas quando o cliente se conecta, cria um processo filho. Julgamento, se for o processo principal, feche o serviço de conexão do cliente. Se é um processo filho. Feche o serviço de conexão do servidor. Aguarde o cliente se conectar ao processo principal. Manipule outras tarefas especificamente para o processo filho. Como vários processos podem gerar processos zumbis, o trabalho de lidar com processos zumbis é entregue ao processo principal. Por fim, observe que o processo filho está dentro do loop externo. Se o processo filho não for encerrado após a conclusão do trabalho. Então, quando o ciclo recomeçar, uma bomba de garfo será gerada. Gerando processos filhos continuamente.

Publicado 73 artigos originais · elogiados 4 · 20.000+ visualizações

Acho que você gosta

Origin blog.csdn.net/qq_27592485/article/details/100767398
Recomendado
Clasificación