http 转发

本文介绍了一种在Python中实现网络端口转发和重定向的方法。通过创建PipeThread类来建立两个socket之间的数据传输通道,并利用Pinhole类监听指定端口并将连接转发到目标地址。适用于Python 2和Python 3。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#encoding=utf8
#author: walker摘自《Python Cookbook(2rd)》
#date: 2015-06-11
#function: 网络端口的转发和重定向(适用于python2/python3)
import sys, socket, time, threading
LOGGING = True
loglock = threading.Lock()
#打印日志到标准输出
def log(s, *a):
  if LOGGING:
    loglock.acquire()
    try:
      print('%s:%s' % (time.ctime(), (s % a)))
      sys.stdout.flush()
    finally:
      loglock.release()
class PipeThread(threading.Thread):
  pipes = []   #静态成员变量,存储通讯的线程编号
  pipeslock = threading.Lock()
  def __init__(self, source, sink):
    #Thread.__init__(self) #python2.2之前版本适用
    super(PipeThread, self).__init__()
    self.source = source
    self.sink = sink
    log('Creating new pipe thread %s (%s -> %s)',
        self, source.getpeername(), sink.getpeername())
    self.pipeslock.acquire()
    try:
      self.pipes.append(self)
    finally:
      self.pipeslock.release()
    self.pipeslock.acquire()
    try:
      pipes_now = len(self.pipes)
    finally:
      self.pipeslock.release()
    log('%s pipes now active', pipes_now)
  def run(self):
    while True:
      try:
        data = self.source.recv(1024)
        if not data:
          break
        self.sink.send(data)
      except:
        break
    log('%s terminating', self)
    self.pipeslock.acquire()
    try:
      self.pipes.remove(self)
    finally:
      self.pipeslock.release()
    self.pipeslock.acquire()
    try:
      pipes_left = len(self.pipes)
    finally:
      self.pipeslock.release()
    log('%s pipes still active', pipes_left)
class Pinhole(threading.Thread):
  def __init__(self, port, newhost, newport):
    #Thread.__init__(self) #python2.2之前版本适用
    super(Pinhole, self).__init__()
    log('Redirecting: localhost: %s->%s:%s', port, newhost, newport)
    self.newhost = newhost
    self.newport = newport
    self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    self.sock.bind(('', port))
    self.sock.listen(5) #参数为timeout,单位为秒
  def run(self):
    while True:
      newsock, address = self.sock.accept()
      log('Creating new session for %s:%s', *address)
      fwd = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
      fwd.connect((self.newhost, self.newport))
      PipeThread(newsock, fwd).start() #正向传送
      PipeThread(fwd, newsock).start() #逆向传送
if __name__ == '__main__':
  print('Starting Pinhole port fowarder/redirector')
  try:
    port = 8631
    newhost = "192.168.40.24"
    try:
      newport = 8630
    except IndexError:
      newport = port
  except (ValueError, IndexError):
    print('Usage: %s port newhost [newport]' % sys.argv[0])
    sys.exit(1)
  #sys.stdout = open('pinhole.log', 'w') #将日志写入文件
  print(f" local port :{port} recity to {newhost}:{newport}  ")
  Pinhole(port, newhost, newport).start()

 可以将本地的某个端口映射到某台服务器的端口  可以做代理转发使用

### 如何配置 Nginx 进行 HTTP 请求转发 #### 1. 基本概念 Nginx 是一种高效的 Web 服务器和反向代理服务器,能够处理大量的并发连接并提供快速的内容分发。通过配置 Nginx 的 `location` 和 `proxy_pass` 指令可以实现 HTTP 请求的转发。 #### 2. 配置文件结构 通常情况下,Nginx 的主要配置文件位于 `/etc/nginx/nginx.conf` 或者 `/etc/nginx/conf.d/default.conf` 中。为了简化管理,建议创建独立的配置文件来定义特定站点的行为。 #### 3. 实现请求转发的具体方法 要使 Nginx 将接收到的客户端请求转发给另一个服务端口或地址,可以在虚拟主机(server block)内设置如下所示的位置匹配规则: ```nginx http { server { listen 80; server_name localhost; location /api/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; # 转发至目标服务器 proxy_pass http://backend_server_address/; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } } ``` 上述代码片段展示了如何将路径以 `/api/` 开头的所有请求都发送到名为 `backend_server_address` 的后端应用上[^1]。 #### 4. 测试与验证 完成以上配置更改之后,记得保存修改过的配置文件,并重启 Nginx 来加载新的设定。可以通过命令行工具如 curl 发送测试请求确认是否成功实现了预期的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值