通过Python脚本理解系统进程间通信
2012-12-13 10:17
316 查看
标签:包 通信 localhost 缓冲区 import
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://president.blog.51cto.com/4990508/1079464
from socket import * #导入socket包中的所有内容
from time import ctime #导入time包,同时在本地可使用ctime进行调用
import os,sys #导入os,sys包
HOST='localhost' #定义主机
PORT=21567 #定义端口
BUFSIZ=1024 #定义缓冲区
ADDR=(HOST,PORT) #定义元组
tcpSerSock=socket(AF_INET,SOCK_STREAM) #生成socket
tcpSerSock.bind(ADDR) #将地址及端口元组与socket绑定
tcpSerSock.listen(5) #监听用户请求
r,w=os.pipe() #定义管道,进程间通信就靠他了!
while True: #定义无限循环
print "waiting ...." #打印等待用户输入时的waiting
try: #检测可能的异常
tcpCliSock,addr=tcpSerSock.accept() #处理用户请求
os.write(w,"f") #在管道一侧写入字符“f”
except: #处理异常
sys.exit(0) #如果发生异常将直接退出
if os.fork(): #在父进程中的处理
pass #跳过处理
else: #在子进程中的处理
print 'con from :',addr #打印客户端信息
while True: #定义无限循环
data=tcpCliSock.recv(BUFSIZ) #从客户端接收1024大小的数据
os.write(w,data) #将数据写入到道道中
if not data: #如果客户端没有任何输入,即直接回车或Ctrl+D
tcpSerSock.close() #关闭客户端链接
break #跳出无限循环
tcpCliSock.send('[%s] %s' %(ctime(),os.read(r,1024)))#否则回显用户信息并附加当前时间!
tcpSerSock.close() #这句话依然不会被执行。
通过这两个脚本大家能否对Apache的profork模式有一个更清晰的认识?
本文出自 “林肯” 博客,请务必保留此出处http://president.blog.51cto.com/4990508/1079464
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://president.blog.51cto.com/4990508/1079464
from socket import * #导入socket包中的所有内容
from time import ctime #导入time包,同时在本地可使用ctime进行调用
import os,sys #导入os,sys包
HOST='localhost' #定义主机
PORT=21567 #定义端口
BUFSIZ=1024 #定义缓冲区
ADDR=(HOST,PORT) #定义元组
tcpSerSock=socket(AF_INET,SOCK_STREAM) #生成socket
tcpSerSock.bind(ADDR) #将地址及端口元组与socket绑定
tcpSerSock.listen(5) #监听用户请求
r,w=os.pipe() #定义管道,进程间通信就靠他了!
while True: #定义无限循环
print "waiting ...." #打印等待用户输入时的waiting
try: #检测可能的异常
tcpCliSock,addr=tcpSerSock.accept() #处理用户请求
os.write(w,"f") #在管道一侧写入字符“f”
except: #处理异常
sys.exit(0) #如果发生异常将直接退出
if os.fork(): #在父进程中的处理
pass #跳过处理
else: #在子进程中的处理
print 'con from :',addr #打印客户端信息
while True: #定义无限循环
data=tcpCliSock.recv(BUFSIZ) #从客户端接收1024大小的数据
os.write(w,data) #将数据写入到道道中
if not data: #如果客户端没有任何输入,即直接回车或Ctrl+D
tcpSerSock.close() #关闭客户端链接
break #跳出无限循环
tcpCliSock.send('[%s] %s' %(ctime(),os.read(r,1024)))#否则回显用户信息并附加当前时间!
tcpSerSock.close() #这句话依然不会被执行。
通过这两个脚本大家能否对Apache的profork模式有一个更清晰的认识?
本文出自 “林肯” 博客,请务必保留此出处http://president.blog.51cto.com/4990508/1079464
相关文章推荐
- 通过Python脚本理解系统进程
- 通过Python脚本理解系统进程 推荐
- 通过Python脚本理解系统线程
- 通过Python脚本理解系统进程间通信
- 通过Python脚本理解系统进程间通信 推荐
- 通过Python脚本理解系统线程 推荐
- 通过Python脚本理解系统线程
- 通过Python脚本理解系统线程
- Python 之小白的系统进程的理解之进程间通信
- PHP通过系统命令执行Python脚本
- mac 系统下定时执行python脚本
- 为Docker容器设置固定IP实现网络联通(2)——通过Python脚本实现并解决pipework缺陷
- python脚本设置超时机制系统时间的方法
- python 脚本 通过解析 DDL 更新PDM
- Python 之小白的系统进程的理解之进程池Pool
- python windows下通过SSH获取linux系统cpu、内存、网络使用情况
- 让系统及时的通过域用户脚本自动的打补丁
- 通过重建Hosting系统理解HTTP请求在ASP.NET Core管道中的处理流程[上]:采用管道处理请求
- 使用一个简单的python脚本将一个本地文件以码流的形式,通过UDP协议发送到对端:
- zabbix通过python脚本发告警邮件