zoukankan      html  css  js  c++  java
  • 2015-12-16 第八天笔记整理-第二部分

    socket()

    本地的进程间通信(IPC)有很多种方式,但可以总结为下面4类:

    • 消息传递(管道、FIFO、消息队列)

    • 同步(互斥量、条件变量、读写锁、文件和写记录锁、信号量)

    • 共享内存(匿名的和具名的)

    • 远程过程调用(Solaris门和Sun RPC)

    不过这个不是重点!提问,在网络中进程之间如何通信?

        首要解决的问题是如何唯一标识一个进程,否则通信无从谈起!在本地可以通过进程PID来唯一标识一个进程,但是在网络中这是行不通的。其实TCP/IP协议族已经帮我们解决了这个问题,网络层的“ip地址”可以唯一标识网络中的主机,而传输层的“协议+端口”可以唯一标识主机中的应用程序(进程)。这样利用三元组(ip地址,协议,端口)就可以标识网络的进程了,网络中的进程通信就可以利用这个标志与其它进程进行交互。

        使用TCP/IP协议的应用程序通常采用应用编程接口:UNIX  BSD的套接字(socket)和UNIX System V的TLI(已经被淘汰),来实现网络进程之间的通信。就目前而言,几乎所有的应用程序都是采用socket,而现在又是网络时代,网络中进程通信是无处不在,这就是我为什么说“一切皆socket”。

        所以,在下面的理解中,我们可以把socket 简单的理解为“ip + 协议 + 端口

       其中ip就是ip地址,协议就是TCP+UDP,端口范围是1-65535


    需要说明的是socket和file有类似的地方,这是因为,在发展的初期他们都是按UNIX的思路创造出来的,“一切皆文件”,所以对于socket也有 读/写IO,打开,关闭这样的操作。

    socket和file的区别:

    • file模块是针对某个指定文件进行【打开】【读写】【关闭】
    • socket模块是针对 服务器端 和 客户端Socket 进行【打开】【读写】【关闭】

    实现socket通常分成两个部分

    client server
    socket() socket()
      bind()
      listen()
    connect() accept()
    write()  
      read()
      write()
    read()  
      close()
    close()  

    上图片:

     

    知道了沟通过程,剩下就是语法,然后就可以开始进行socket的编写了。

    sk = socket.socket(socket.AF_INET,socket.SOCK_STREAM,0)

    参数一:地址簇

      socket.AF_INET IPv4(默认)
      socket.AF_INET6 IPv6

      socket.AF_UNIX 只能够用于单一的Unix系统进程间通信

    参数二:类型

      socket.SOCK_STREAM  流式socket , for TCP (默认)
      socket.SOCK_DGRAM   数据报式socket , for UDP

          socket.SOCK_RAW 原始套接字,普通的套接字无法处理ICMP、IGMP等网络报文,而SOCK_RAW可以;其次,SOCK_RAW也可以处理特殊的IPv4报文;此外,利用原始套接字,可以通过IP_HDRINCL套接字选项由用户构造IP头。
      socket.SOCK_RDM 是一种可靠的UDP形式,即保证交付数据报但不保证顺序。SOCK_RAM用来提供对原始协议的低级访问,在需要执行某些特殊操作时使用,如发送ICMP报文。SOCK_RAM通常仅限于高级用户或管理员运行的程序使用。
      socket.SOCK_SEQPACKET 可靠的连续数据包服务

    参数三:协议

      0  (默认)与特定的地址家族相关的协议,如果是 0 ,则系统就会根据地址格式和套接类别,自动选择一个合适的协议

    #!/usr/bin/env python
    # -- coding: utf-8 --
    __author__ = 'EchoRep'
    ‘’‘
    创建服务端
    ’‘’
    import socket
    
    def main():
        # 创建socket对象
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        # 监听端口
        sock.bind(('127.0.0.1',8001))
        # 开始监听,
        sock.listen(5)
    
        while True:
            # 阻塞,deng 。。。。
            # 直到有请求连接
            print '....'
            connection, address = sock.accept()
            # connection,代表客户端socket对象,
            # address,客户端IP地址
            #handle_request(connection)
            buf = connection.recv(1024)
            print buf
            #通过链接接受数据
            connection.send("HTTP/1.1 200 OK
    
    ")
            connection.send("Hello, World")
            connection.close()
    
    if __name__ == '__main__':
      main()
    #!/usr/bin/env python
    # -- coding: utf-8 --
    __author__ = 'EchoRep'
    
    ‘’‘
    创建客户端
    ’‘’
    
    import socket
    while True:
        objClient = socket.socket()
        objClient.connect(("localhost",8001))
        objClient.send("hihihi")
        serverDate = objClient.recv(1024)
        print serverDate
        objClient.close()
  • 相关阅读:
    Spring源码学习之容器的基本实现(一)
    面向对象设计原则
    简单易懂带你了解红黑树
    简单易懂带你了解二叉树
    单例模式
    原形模式
    数组与链表
    记一次解决postgresql数据库内存泄露的问题
    记一次排查CPU高的问题
    react ts 设置paths 和 声明非@types的模块
  • 原文地址:https://www.cnblogs.com/echorep/p/5052750.html
Copyright © 2011-2022 走看看