设为首页 收藏本站
查看: 713|回复: 0

[经验分享] 一个简单的python socket编程

[复制链接]

尚未签到

发表于 2017-5-2 10:54:27 | 显示全部楼层 |阅读模式
python 编写server的步骤:

  •   第一步是创建socket对象。调用socket构造函数。如:

    socket = socket.socket( family, type )

    family参数代表地址家族,可为AF_INET或AF_UNIX。AF_INET家族包括Internet地址,AF_UNIX家族用于同一台机器上的进程间通信。
    type参数代表套接字类型,可为SOCK_STREAM(流套接字)和SOCK_DGRAM(数据报套接字)。
  •   第二步是将socket绑定到指定地址。这是通过socket对象的bind方法来实现的:

    socket.bind( address )



    由AF_INET所创建的套接字,address地址必须是一个双元素元组,格式是(host,port)。host代表主机,port代表端口号。如果端口号正在使用、主机名不正确或端口已被保留,bind方法将引发socket.error异常。
  •   第三步是使用socket套接字的listen方法接收连接请求。
      socket.listen( backlog )
      backlog指定最多允许多少个客户连接到服务器。它的值至少为1。收到连接请求后,这些请求需要排队,如果队列满,就拒绝请求。
  •   第四步是服务器套接字通过socket的accept方法等待客户请求一个连接。

    connection, address = socket.accept()

    调 用accept方法时,socket会时入“waiting”状态。客户请求连接时,方法建立连接并返回服务器。accept方法返回一个含有两个元素的 元组(connection,address)。第一个元素connection是新的socket对象,服务器必须通过它与客户通信;第二个元素 address是客户的Internet地址。
  • 第五步是处理阶段,服务器和客户端通过send和recv方法通信(传输 数据)。服务器调用send,并采用字符串形式向客户发送信息。send方法返回已发送的字符个数。服务器使用recv方法从客户接收信息。调用recv 时,服务器必须指定一个整数,它对应于可通过本次方法调用来接收的最大数据量。recv方法在接收数据时会进入“blocked”状态,最后返回一个字符 串,用它表示收到的数据。如果发送的数据量超过了recv所允许的,数据会被截短。多余的数据将缓冲于接收端。以后调用recv时,多余的数据会从缓冲区 删除(以及自上次调用recv以来,客户可能发送的其它任何数据)。
  • 传输结束,服务器调用socket的close方法关闭连接。
python编写client的步骤:

  • 创建一个socket以连接服务器:socket = socket.socket( family, type )
  •   使用socket的connect方法连接服务器。对于AF_INET家族,连接格式如下:
      socket.connect( (host,port) )
      host代表服务器主机名或IP,port代表服务器进程所绑定的端口号。如连接成功,客户就可通过套接字与服务器通信,如果连接失败,会引发socket.error异常。
  • 处理阶段,客户和服务器将通过send方法和recv方法通信。
  • 传输结束,客户通过调用socket的close方法关闭连接。
下面给个简单的例子:

server.py
python 代码
 

  • if __name__ == '__main__':  
  •     import socket  
  •     sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
  •     sock.bind(('localhost', 8001))  
  •     sock.listen(5)  
  •     while True:  
  •         connection,address = sock.accept()  
  •         try:  
  •             connection.settimeout(5)  
  •             buf = connection.recv(1024)  
  •             if buf == '1':  
  •                 connection.send('welcome to server!')  
  •             else:  
  •                 connection.send('please go out!')  
  •         except socket.timeout:  
  •             print 'time out'  
  •         connection.close()  


client.py
python 代码
 

  • if __name__ == '__main__':  
  •     import socket  
  •     sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
  •     sock.connect(('localhost', 8001))  
  •     import time  
  •     time.sleep(2)  
  •     sock.send('1')  
  •     print sock.recv(1024)  
  •     sock.close()  


在终端运行server.py,然后运行clien.py,会在终端打印“welcome  to server!"。如果更改client.py的sock.send('1')为其它值在终端会打印”please go out!“,更改time.sleep(2)为大于5的数值, 服务器将会超时。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-372040-1-1.html 上篇帖子: 使用 python 模拟 ruby 的 open class 下篇帖子: Amazing Python 2: "exec/eval/repr"
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表