Python 网络编程 大数据

数据库

数据库能做什么?

存储大量数据,方便检索和访问。

保持数据包数据信息的一致,完整。

共享和安全。

通过组合分析,产生新的所有信息。

应用程序

作用:相应操作并显示结果,想数据库请求数据

要求:美观、操作简单方便

数据库

作用存储数据,检索数据、生成新的数据

要求:统一、安全、性能。

Oracle

Oracle公司的产品

产品免费、服务费收费

Sql server

针对不同用户群体的多个版本

易用性好

Mysql

开放源代码

网站应用广泛。

数据库就是数据的仓库

数据库中包含表关系以及操作对象

数据存放在表中。

数据库仅有唯一的编号,不能重复。

网络编程

Python提供了两个级别访问的网络服务

低级别的网络服务支持基本的Socket,他提供了标准的BSD Sockets AOI可以访问底层操作系统SOCKET接口的全部方法。

高级别的网络服务模块SocketServer,他提供了服务器中心类,可以简化网络服务器的开发 。

什么是Socket

Socket又称套接字,应用程序通常通过套接字向网络发出请求或者应答网络请求,使主机间或者一台计算机上的进程间可以通讯。

Socket 对象(内建)方法

s.bind()  绑定地址(host,port)到套接字, 在AF_INET下,以元组(host,port)的形式表示地址。

s.listen() 开始TCP监听。backlog指定在拒绝连接之前,操作系统可以挂起的最大连接数量。该值至少为1,大部分应用程序设为5就可以了。

s.accept() 被动接受TCP客户端连接,(阻塞式)等待连接的到来

客户端套接字

s.connect()   主动初始化TCP服务器连接,。一般address的格式为元组(hostname,port),如果连接出错,返回socket.error错误。

s.connect_ex() connect()函数的扩展版本,出错时返回出错码,而不是抛出异常

公共用途的套接字函数

s.recv()  接收TCP数据,数据以字符串形式返回,bufsize指定要接收的最大数据量。flag提供有关消息的其他信息,通常可以忽略。

s.send()  发送TCP数据,将string中的数据发送到连接的套接字。返回值是要发送的字节数量,该数量可能小于string的字节大小。

s.sendall()   完整发送TCP数据,完整发送TCP数据。将string中的数据发送到连接的套接字,但在返回之前会尝试发送所有数据。成功返回None,失败则抛出异常。

s.recvfrom()  接收UDP数据,与recv()类似,但返回值是(data,address)。其中data是包含接收数据的字符串,address是发送数据的套接字地址。

s.sendto() 发送UDP数据,将数据发送到套接字,address是形式为(ipaddr,port)的元组,指定远程地址。返回值是发送的字节数。

s.close() 关闭套接字

s.getpeername()   返回连接套接字的远程地址。返回值通常是元组(ipaddr,port)。

s.getsockname()   返回套接字自己的地址。通常是一个元组(ipaddr,port)

s.setsockopt(level,optname,value) 设置给定套接字选项的值。

s.getsockopt(level,optname[.buflen])  返回套接字选项的值。

s.settimeout(timeout) 设置套接字操作的超时期,timeout是一个浮点数,单位是秒。值为None表示没有超时期。一般,超时期应该在刚创建套接字时设置,因为它们可能用于连接的操作(如connect())

s.gettimeout() 返回当前超时期的值,单位是秒,如果没有设置超时期,则返回None。

s.fileno() 返回套接字的文件描述符。

s.setblocking(flag)   如果flag为0,则将套接字设为非阻塞模式,否则将套接字设为阻塞模式(默认值)。非阻塞模式下,如果调用recv()没有发现任何数据,或send()调用无法立即发送数据,那么将引起socket.error异常。

s.makefile()  创建一个与该套接字相关连的文件

服务端

我们使用 socket 模块的 socket 函数来创建一个 socket 对象。socket 对象可以通过调用其他函数来设置一个 socket 服务。

现在我们可以通过调用 bind(hostname, port) 函数来指定服务的 port(端口)。

接着,我们调用 socket 对象的 accept 方法。该方法等待客户端的连接,并返回 connection 对象,表示已连接到客户端。

客户端

接下来我们写一个简单的客户端实例连接到以上创建的服务。端口号为 9999。

socket.connect(hosname, port ) 方法打开一个 TCP 连接到主机为 hostname 端口为 port 的服务商。连接后我们就可以从服务端后期数据,记住,操作完成后需要关闭连接。

 

Python Internet 模块

协议       功能用途                         端口 模块

HTTP      网页访问                          80 httplib, urllib, xmlrpclib

NNTP      阅读和张贴新闻文章,俗称为"帖子"   119 nntplib

FTP       文件传输                          20 ftplib, urllib

SMTP      发送邮件                          25 smtplib

POP3      接收邮件                          110    poplib

IMAP4     获取邮件                          143    imaplib

Telnet 命令行                           23 telnetlib

Gopher 信息查找                          70 gopherlib, urllib

服务器

import socket
import threading
serversocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
serversocket.bind(("127.0.0.117", 9999))  # 绑定服务地址和端口号
print("服务器已等待")
serversocket.listen(5)  # 最多同时接收5个
msg = None  # 定义一个全局的变量,用来存储聊天信息,临时存储当前抢到线程的数据
lock = threading.Lock()
mythread = threading.Condition(lock)
def server_recv(c, a):
    global msg
    while True:
        mystr = c.recv(1024)
        mythread.acquire()  # 线程同步
        msg = str(a) + mystr.decode()
        print(msg)
        mythread.notify_all()
        mythread.release()
def server_send(c, a):
    global msg
    while True:
        mythread.acquire()
        mythread.wait()
        mythread.release()
        c.send(msg.encode())
        print(msg)
while True:
    c, a = serversocket.accept()
    threading._start_new_thread(server_recv, (c, a))
    threading._start_new_thread(server_send, (c, a))
客户端
import socket
import threading
client=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
client.connect(('127.0.0.117',9999))#绑定服务器地址和端口号
print('客户端已连接')
def myrerv(c):
    while   True:
        msg=c.recv(1024)#接受消息
        print(msg.decode())
threading._start_new_thread(myrerv,(client,))
def myinpuut():
    while   True:
        msg=input()
        client.send(msg.encode())
threading._start_new_thread(myinpuut())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值