前言:

你会发现会网络是多么幸福的事情

主要内容:

socket 概念:

socket本质上就是2台网络互通的电脑之间,架设一个通道,两台电脑通过这个通道来实现数据的互相传递。我们知道网络通信都是基于IP地址加短裤的方法来定位到目标的具体机器上的具体服务。操作系统有0-65535个端口,每个端口都可以独立对外提供服务,如果把一个公司比做一台电脑,那公司的总机号码就相当于IP地址,每个员工的分机号就相当于短裤,你想找公司某个人,必须先打电话到总机,然后再转分机。

这里提到了OSI七层模型的概念:

第一层:物理层

第二层:数据链路层

第三层: 网络层

第四层:传输层

第五层:会话层

第六层:表示层

第七层:应用层

建立一个socket必须至少有2端,1个是服务端,1个是客户端,服务端被动等待并接受请求,客户端主动发起请求,连接建立之后,双方可以互发数据。

建立一个链接,需要IPV4和IPV6
Socket Types
socket.SOCK_STREAM     #for tcp
socket.SOCK_DGRAM     #for  udp
socket.SOCK_RAW      #原始套接字
建立链接之后,就需要IP和端口了
排队数量,一般是5
sk.listen(backlog)
关闭套接字
sk.close()
接受套接字的数据
sk.recv(bufsize[,flag])
 
具体步骤
1、生成一个socket实例
 
server = socket.socket(AF_INET,SOCK_STREAM)
2、绑定地址
server.bind('0.0.0.0',8000)
3、监听端口排队5个
server.listen(5)
 
4、接受
talk_list = []
server.accept()   会返回2个值 conn 建立链接的线   client_addr 链接对象
talk_list.append(conn)
conn.send('sdfds') 
另外一个介入进来
conn.recv('sdfsf')
5、发送
server.send()
6、关机
server.close()
 
上面是服务端
 
客户端通信
client = socket.socket(AF_INET,SOCK_STREAM)
client.connect('')
client.send
client.recv
 
接下来,就通过代码来实现这个服务端和客户端
server端
#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket server = socket.socket(socket.AF_INET,socket.SOCK_STREAM) server.bind(("0.0.0.0",)) server.listen() conn,client_addr = server.accept() print(conn,client_addr) while True:
data = conn.recv() #1024字节
print("recv from cli:",data)
conn.send(b"got it")

client端

#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket client = socket.socket() client.connect(("localhost",))
while True:
msg = input(">>:").strip()
if len(msg) == :continue
client.send(msg.encode())
print("send ",msg)
data = client.recv()
print("receive from server:",data)
再开一个client的时候,会出现堵死的情况,断开一个,另外一个可以使用了。
所以上面的可以改良
 
server端
#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket server = socket.socket(socket.AF_INET,socket.SOCK_STREAM) server.bind(("0.0.0.0",)) server.listen() while True:
conn,client_addr = server.accept()
print(conn,client_addr) while True:
try:
data = conn.recv() #1024字节
print("recv from cli:",data)
conn.send(b"got it")
except ConnectionResetError as e:
print(e)
break

客户端

#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket client = socket.socket() client.connect(("localhost",))
while True:
msg = input(">>:").strip()
if len(msg) == :continue
client.send(msg.encode())
print("send ",msg)
data = client.recv()
print("receive from server:",data)

接着写一个SSH连过去,执行命令的服务端和客户端

server端

#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket
import subprocess server = socket.socket(socket.AF_INET,socket.SOCK_STREAM) server.bind(("0.0.0.0",)) server.listen()
print("=============start to listen============")
while True:
conn,client_addr = server.accept()
print(conn,client_addr) while True: data = conn.recv() #1024字节
print("recv from cli:",data)
res_obj = subprocess.Popen(data,shell=True ,stdout=subprocess.PIPE,stderr=subprocess.PIPE)
res = res_obj.stdout.read()
conn.send(str(len(res)).encode())
print("==res len:",len(res))
conn.send(res)

客户端

#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket client = socket.socket() client.connect(("localhost",))
while True:
msg = input(">>:").strip()
if len(msg) == :continue
client.send(msg.encode())
print("send ",msg) data = client.recv()
print("res:",data.decode())
res_len = int(data.decode()) recevied_size =
res = b''
while recevied_size < total_size:
d = client.recv()
res += d recevied_size += len(d)
print(res.decode())

最后做一个持续接受的server端和client端

服务端

[root@docker20- ~]# cat server.py
#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket
import subprocess
server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
server.bind(("0.0.0.0",))
server.listen()
print("--------------start to listen------------------") while True:
conn,client_addr = server.accept()
print(conn,client_addr) while True:
data = conn.recv()
print("recv from cli:",data)
res_obj = subprocess.Popen(data,shell=True, stdout=subprocess.PIPE,stderr=subprocess.PIPE)
res = res_obj.stdout.read()
conn.send(str(len(res)).encode())
print("--res len:",len(res))
conn.send(res)

客户端

#!/usr/bin/env python
# -*- coding: utf- -*-
#Author: Leon xie import socket client = socket.socket() client.connect(("10.10.20.127",)) while True: msg = input(">>:").strip()
if len(msg) == :continue client.send(msg.encode())
print("send",msg)
data = client.recv()
print("res:",data.decode())
total_size = int(data.decode())
#总长度跟已经收到的相等即可 received_size =
res=b''
while received_size <total_size:
d = client.recv()
res += d received_size += len(d) print("---------------rece done------------")
print(res.decode())

完结。

一个初学者的辛酸路程-socket编程-8的更多相关文章

  1. 一个初学者的辛酸路程-python操作SQLAlchemy-13

    前言 其实一开始写blog,我是拒绝的,但是,没办法,没有任何理由抗拒.今天呢,要说的就是如何使用Python来操作数据库. SQLAlchemy SQLAlchemy是Python编程语言下的一款O ...

  2. 一个初学者的辛酸路程-FTP-9

    前言 今天,我要描述一个FTP的故事 主要内容 嗯,今天主要以阶梯性的形式来做一个FTP项目. 第一步: 我要实现这么一个功能,一个FTP客户端,1个FTP服务端,2端建立连接以后可以进行通讯. 服务 ...

  3. 一个初学者的辛酸路程-初识Python-1

    前言 很喜欢的一句话,与诸位共勉. 人的一切痛苦,本质上都是对自己无能的愤怒----王小波. 初识Python 一.它的爸爸是谁 首先,我们需要认识下面这位人物. 他是Python的创始人,吉多范罗苏 ...

  4. 一个初学者的辛酸路程-初识Django

    前言: 主要是关于JavaScript的高级部分以及Django 主要内容: 一.jQuery 事件绑定: DOM事件绑定: -直接在标签上绑定 第一种: $('.title').click(func ...

  5. 一个初学者的辛酸路程-Python基础-3

    前言 不要整天沉迷于学习-. 字典 一.我想跟你聊聊字典 1.为何要有字典? 大家有没有想过为什么要有字典?有列表不就可以了吗? 也许大家会这么认为,我给大家举个例子,大家就明白了. 比如说,我通讯录 ...

  6. 一个初学者的辛酸路程-了解Python-2

    前言 blog花了一上午写的,结果笔记本关机了,没有保存,找不到了,找不到了啊,所以说,你看的每一篇blog可能都是我写了2次以上的--.哎!! 代码改变世界,继续......... Python基础 ...

  7. 一个初学者的辛酸路程-依旧Django

    回顾: 1.Django的请求声明周期?   请求过来,先到URL,URL这里写了一大堆路由关系映射,如果匹配成功,执行对应的函数,或者执行类里面对应的方法,FBV和CBV,本质上返回的内容都是字符串 ...

  8. 一个初学者的辛酸路程-继续Django

    问题1:HTTP请求过来会先到Django的那个地方? 先到urls.py  ,里面写的是对应关系,1个URL对应1个函数名. 如果发URL请求过来,到达这里,然后帮你去执行指定的函数,函数要做哪些事 ...

  9. 一个初学者的辛酸路程-jQuery

    前言: 主要概要: 1.HTML+CSS补充 2.DOM事件 3.jQuery示例 内容概要: 1.布局 代码如下 <!DOCTYPE html> <html lang=" ...

随机推荐

  1. 一步步学习Python-django开发-Mac下搭建Python-Django环境

    首先确定学习那一个版本,以之前对Python的接触,Python2.x 的版本仍然占据很大的市场.但作为初学者我还是决定学习新的版本,相信未来会逐渐转向3.x版本的. 其实搭建Python不是一件很难 ...

  2. 一步一步深入spring(2)-三种方式来实例化bean

    在一步一步深入spring(1)--搭建和测试spring的开发环境中提到了一种实例化bean的方式,也是最基本的使用构造器实例化bean 1.使用构造器实例化bean:这是最简单的方式,Spring ...

  3. 10169 - Urn-ball Probabilities !

    描述:有两个罐子,一个罐子里有一个红球,另一个罐子里有一个红球和一个白球,每次从两个罐子里各取一个球,然后在向每个罐子里各加一个白球,一次取到两个红球时就结束取球,求n次取球中至少一次为取球为红球的概 ...

  4. easyui 个人使用心得之下拉列表

    下拉框: 第一种:从数据库获取<input id="FlowType" name="FlowType" style="width: 245px; ...

  5. 理解git对象

    1. 首次提交,提交一个简单的文件 a.txt ,commit 之后的图如下:   如图所示,生成了 3 个对象,一个 commit 对象,一个 tree 对象,一个 blob 对象.图上蓝底是 co ...

  6. Node.js 使用gm处理图像

    现要对之前的文件服务器进行扩展,听网上说gm处理图像来一套一套的.so决定使用该工具去实现文件服务器的图片处理这块.目标有下现在通过参数去获得缩略图http://xxx.xxx.com/image/2 ...

  7. Netty 5.0源码分析之综述

    1. 前言 本系列主要是用于梳理Netty的架构流程,深入设计细节,重点关注Netty是如何实现它所声称的特性. (ps:本人水平有限,如有错误,请不吝指教 : )) 2. 什么是Netty Nett ...

  8. Python中的各种装饰器详解

    Python装饰器,分两部分,一是装饰器本身的定义,一是被装饰器对象的定义. 一.函数式装饰器:装饰器本身是一个函数. 1.装饰函数:被装饰对象是一个函数 [1]装饰器无参数: a.被装饰对象无参数: ...

  9. Meterpreter

    监听 AutoRunScrip:自动执行脚本 如:自动执行post/windows/manage/migrate set AutoRunScript post/windows/manage/migra ...

  10. @Transactional问题记录下

    系统中多数据源  在control 层 分别使用不同数据源的service ,有个service 调用相应的dao直接出现表或视图不存在,发现这个service类上加了@Transactional 注 ...