gpt4 book ai didi

node.js - 通过代理访问 azure redis 缓存

转载 作者:可可西里 更新时间:2023-11-01 11:14:48 25 4
gpt4 key购买 nike

从开发环境来看,开发者需要访问Redis缓存。与 Azure Redis 缓存的连接是通过端口 6380 上的ocks协议(protocol)完成的。

问题是对互联网的外部访问是通过我们公司的代理完成的。

如果是 HTTP(S) 访问,例如在 Node.js 中,我们使用 npm 包“dotenv”,在其中指定“HTTP(S)”代理设置(例如包 ms-rest azure)。

但是在这里我们没有找到任何使用代理进行socks访问的解决方案。

在这种情况下,我们使用 npm 包“redis”。

有人有代理使用的解决方案吗?

最佳答案

似乎不可能从代理后面的客户端直接连接到 Azure Redis 缓存。原因如下:

  1. Redis 仅支持通过 telnet 等协议(protocol)进行 tcp 连接,如果您的代理不支持 socks,则不可行。
  2. 我搜索了两个推荐的 NodeJS redis 客户端 ioredisnode_redis,两者都不支持通过代理建立连接。

因此,这里有两种可能的解决方案适合您当前的情况。

  1. 如果您的代理支持socks,您可以尝试在现有redis客户端的基础上更改一些代码来创建一个新的redis客户端来支持socks代理。
  2. 针对当前案例推荐。我建议您可以在Azure上创建一个HTTP服务来处理代理后面的客户端请求,该服务可以将HTTP请求的参数传递到Azure Redis缓存并将结果包装到HTTP响应中。它是基于 HTTP 的 Redis,如 solutious/bone .

希望有帮助。

关于node.js - 通过代理访问 azure redis 缓存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53847786/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com