1、首先需要搞一个云服务器
有钱的可以买,没钱的可以找些免费试用的玩玩,学习,现在一般用自己的电脑不够用,有的时候跑确实慢,一种是计算量大,另一种就是要不断请求别的web端,所以个人电脑,比如是笔记本就更难受了,再来做AI用服务器再正常不过了,但是怎么非常简单的移植到服务器并完全托管使用是个操作,用到了服务器跑,在这里稍微做个小笔记把,方便大家也用。
2、设置好账号和密码
一般云服务器用linux系统比较多,通过SSH连接云服务器,输入密码即可
此处输入账号
输入密码即可登录,之后就可以将写好的python服务器网站搭建到云服务器上跑了
# coding:utf-8
'''gbk utf-8'''
import socket
# import sys
# print(sys.getdefaultencoding())
# sys.setdefaultencoding('utf-8')
from multiprocessing import Process
def handle_client(client_socket):
"""
处理客户端请求
"""
while 1:
request_data = client_socket.recv(1024)
print(client_socket)
print("request data:", request_data)
if request_data.decode() == '':
# client_socket.close()
return
try:
request_line, body = request_data.decode().split('\r\n', 1)
header_list = request_line.split(' ')
method = header_list[0].upper()
url = header_list[1]
print('request_line:', request_line)
print('body', body)
print('header_list', header_list)
print('url', url)
# 获得请求参数
if method == 'POST':
request_data = {}
request_body = body.split('\r\n\r\n', 1)[1]
parameters = request_body.split('\n') # 每一行是一个字段
parameters = request_body.split('&') # 每一行是一个字段
for i in parameters:
key, val = i.split('=', 1)
request_data[key] = val
print("post request data body:", request_data)
if method == 'GET':
# 获取get参数
if url.find('?') != -1:
request_data = {}
req = url.split('?', 1)[1]
file_name = url.split('?', 1)[0]
parameters = req.split('&')
for i in parameters:
key, val = i.split('=', 1)
request_data[key] = val
print("get request data url:", request_data)
# 构造响应数据
filepath = './myhtml_test.html'
f = open(filepath, 'rb') # 打开二进制文件
htmlfile = f.read()
f.close()
response_start_line = "HTTP/1.1 200 OK\r\n"
response_headers = "Server: My server\r\n"
response_body = htmlfile
response = response_start_line + response_headers + "\r\n"
# 向客户端返回响应数据
client_socket.send(bytes(response, "utf-8"))
client_socket.send(bytes(response_body))
finally:
pass
# 关闭客户端连接
client_socket.close()
return
if __name__ == "__main__":
server_ip = "127.0.0.1"
server_port = 80
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_socket.bind(('', server_port)) #此处ip地址必须为空才能是本机服务器ip地址
server_socket.listen(128)
print(server_ip,server_port)
while True:
client_socket, client_address = server_socket.accept()
print("[%s, %s]用户连接上了" % (client_socket, client_address))
handle_client_process = Process(target=handle_client, args=(client_socket,))
handle_client_process.start()
print("[%s, %s]用户连接上了2" % (client_socket, client_address))
client_socket.close()
print("[%s, %s]用户连接上了3" % (client_socket, client_address))
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>网页标题</title>
</head>
<body>
<a href="http://www.baidu.com">这是一个链接</a>
<h1>这是一个标题</h1>
<hr /> <!-- 标签在 HTML 页面中创建水平线。 -->
<p>段落</p>
<p>This is<br />a para<br />graph with line breaks</p>
<p style="font-family:arial;color:red;font-size:20px;">A paragraph.</p>
<p>WWF 的目标是:<q>构建人与自然和谐共存的世界。</q></p>
<blockquote >
五十年来,WWF 一直致力于保护自然界的未来。
世界领先的环保组织,WWF 工作于 100 个国家,
并得到美国一百二十万会员及全球近五百万会员的支持。
</blockquote>
<p><abbr title="World Health Organization">WHO</abbr> 成立于 1948 年。</p>
<a href="WebConfig.html">这是一个链接
<button type="button" >点我</button>
</a>
</body>
</html>
服务器上运行之后,通过浏览器就可以访问自己搭建的网站了
linux常用命令:
1、ps
可以查看当进程
2、kill -9 PID
可以强制杀死进程,例如:kill -9 23238
3、python3 http_test3_html.py &
可以运行代码的同时可以继续输入其他命令,在最后加一个&