Python实现简单的文件传输与MySQL备份的脚本分享
admin
2023-07-31 02:32:59
0

用python实现简单Server/Client文件传输:

服务器端:

#!/usr/bin/python
import SocketServer, time
class MyServer(SocketServer.BaseRequestHandler):
userInfo = {
\'leonis\' : \'leonis\',
\'hudeyong\' : \'hudeyong\',
\'mudan\' : \'mudan\' }
def handle(self):
print \'Connected from\', self.client_address
while True:
receivedData = self.request.recv(8192)
if not receivedData:
continue
elif receivedData == \'Hi, server\':
self.request.sendall(\'hi, client\')
elif receivedData.startswith(\'name\'):
self.clientName = receivedData.split(\':\')[-1]
if MyServer.userInfo.has_key(self.clientName):
self.request.sendall(\'valid\')
else:
self.request.sendall(\'invalid\')
elif receivedData.startswith(\'pwd\'):
self.clientPwd = receivedData.split(\':\')[-1]
if self.clientPwd == MyServer.userInfo[self.clientName]:
self.request.sendall(\'valid\')
time.sleep(5)
sfile = open(\'down.sh\', \'rb\')
while True:
data = sfile.read(1024)
if not data:
break
while len(data) > 0:
intSent = self.request.send(data)
data = data[intSent:]
time.sleep(3)
self.request.sendall(\'EOF\')
else:
self.request.sendall(\'invalid\')
elif receivedData == \'bye\':
break
self.request.close()
print \'Disconnected from\', self.client_address
print
if __name__ == \'__main__\':
print \'Server is started\\nwaiting for connection…\\n\'
srv = SocketServer.ThreadingTCPServer((\'ip\', 50000), MyServer)
srv.serve_forever()

客户端:

import socket, time
class MyClient:
def __init__(self):
print \'Prepare for connecting…\'
def connect(self):
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect((\'ip\', 50000))
sock.sendall(\'Hi, server\')
self.response = sock.recv(8192)
print \'Server:\', self.response
self.s = raw_input(\"Server: Do you want get the \'thinking in python\' file?(y/n):\")
if self.s == \'y\':
while True:
self.name = raw_input(\'Server: input our name:\')
sock.sendall(\'name:\' + self.name.strip())
self.response = sock.recv(8192)
if self.response == \'valid\':
break
else:
print \'Server: Invalid username\'
while True:
self.pwd = raw_input(\'Server: input our password:\')
sock.sendall(\'pwd:\' + self.pwd.strip())
self.response = sock.recv(8192)
if self.response == \'valid\':
print \'please wait…\'
f = open(\'down.sh\', \'wb\')
while True:
data = sock.recv(1024)
if data == \'EOF\':
break
f.write(data)
f.flush()
f.close()
print \'download finished\'
break
else:
print \'Server: Invalid password\'
sock.sendall(\'bye\')
sock.close()
print \'Disconnected\'
if __name__ == \'__main__\':
client = MyClient()
client.connect()

由于担心服务器数据安全,所以写了这个脚本,结合上面分享的Server/Client 文件互传,可以备份网站数据到本地,安全又可靠

#!/usr/bin/python
# Filename: webbak.py
import os
import time
import tarfile
 
os.chdir(\'/home/web/\') #切换目录
source = \'leonis\'
bakdir = \'/home/web/leonis/\'
# mysql dump
dump = \'mysqldump\'
dbuser = \'XXXXXXX\'
dbpwd = \'XXXXXXXXXXX\'
dbname = \'XXXXXXXX\'
sqlfile = \'/home/web/leonis/leonis.sql\'
sql = \"%s -u%s -p%s %s > %s\" % (dump,dbuser,dbpwd,dbname,sqlfile)
if os.path.exists(sqlfile): 
  os.remove(sqlfile)
else:
  print \'then will dump sql file\'
result = os.popen(sql)
if result:       #
 print (\"SQL backup completed!\")
else:
 print (\"SQL backup failed!\")
# gzip 压缩 以当日日期命名
filename = bakdir + time.strftime(\'%Y%m%d\')+\'.tar.gz\'
tar = tarfile.open(filename,\"w:gz\")
tar.add(source)
tar.close()

相关内容

热门资讯

500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
Prometheus+Graf... 一,Prometheus概述 1,什么是Prometheus?Prometheus是最初在Sound...
python绘图库Matplo... 本文简单介绍了Python绘图库Matplotlib的安装,简介如下: matplotlib是pyt...