• python高级(03)--socket编程


    python高级(03)--socket编程

    概念理解

    五层网络模型:

    五层网络模型

    左侧为server端,右侧为client端:

    socket编程

    socket和server实现通信

    socket_server.py

    import socket
    
    server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server.bind(('0.0.0.0', 8000))
    server.listen(10)
    sock, addr = server.accept()
    
    # 获取从客户端发送的数据
    # 一次获取1k的数据
    data = sock.recv(1024)
    print(data.decode('utf-8'))
    sock.send("Hello {}".format(data.decode('utf-8')).encode('utf-8'))
    
    
    sock.close()
    server.close()
    
    

    socket_client.py

    import socket
    
    client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    client.connect(('127.0.0.1', 8000))
    
    client.send('snoopy'.encode('utf-8'))
    data = client.recv(1024)
    print(data.decode('utf-8'))
    
    client.close()
    

    socket实现聊天和多用户连接

    socket_server.py

    import socket
    import threading
    
    
    server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server.bind(('0.0.0.0', 8000))
    server.listen(10)
    
    
    def handle_sock(sock: socket.socket, addr):
        while True:
            print('new sock', sock, addr)
            recv_data = sock.recv(1024).decode('utf-8')
            print(recv_data)
            if recv_data == 'Q':
                break
            re_data = input()
            sock.send(re_data.encode('utf-8'))
        sock.close()
    
    
    # 获取从客户端发送的数据
    # 一次获取1k的数据
    while True:
        sock, addr = server.accept()  # 阻塞
    
        client_thread = threading.Thread(target=handle_sock, args=(sock, addr))
        client_thread.start()
    
    # sock.close()
    # server.close()
    

    socket_client.py

    import socket
    
    client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    client.connect(('127.0.0.1', 8000))
    
    while True:
        re_data = input()
        client.send(re_data.encode('utf-8'))
        if re_data == 'Q':
            break
        data = client.recv(1024)
        print(data.decode('utf-8'))
    
    client.close()
    

    socket模拟http请求

    # requests -> urlib -> socket
    import socket
    from urllib.parse import urlparse
    
    
    def get_url(url):
        # 通过socket请求html
        url = urlparse(url)
        host = url.netloc
        path = url.path
        if path == '':
            path = '/'
    
        # 建立socket连接
        client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        # client.setblocking(False)
        client.connect((host, 80))  # 阻塞不会消耗CPU
    
        # 不停的询问连接是否建立好, 需要while循环不停的去检查状态
        # 做计算任务或者再次发起其他的连接请求
        
        client.send("GET {} HTTP/1.1
    Host:{}
    Connection:close
    
    ".format(path, host).encode("utf8"))
        data = b""
        while True:
            d = client.recv(1024)
            if d:
                data += d
            else:
                break
        data = data.decode('utf8')
        html_data = data.split("
    
    ")[0]
        print(html_data)
        client.close()
    
    
    if __name__ == "__main__":
        import time
        start_time = time.time()
    
        for url in range(20):
            url = "http://shop.projectsedu.com/goods/{}/".format(url)
            get_url(url)
        print(time.time() - start_time)
    
  • 相关阅读:
    Windows环境下安装Hadoop+Hive的使用案例
    基于hadoop的离线分析大数据工具Hive的架构图
    springboot集成elasticsearch
    亿级流量场景下,大型架构设计实现【全文检索高级搜索---ElasticSearch篇】-- 中
    海量数据,大数据处理技术--分布式数据库【Hbase】
    亿级流量场景下,大型架构设计实现【全文检索高级搜索---ElasticSearch篇】-- 上
    zookeeper安装以及遇到的一些坑
    亿级流量场景下,大型架构设计实现【2】---storm篇
    用到UdpClient的一点经验
    随笔
  • 原文地址:https://www.cnblogs.com/pankypan/p/13664751.html
Copyright © 2020-2023  润新知