- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我们在 React 应用程序的 package.json
中定义了代理(创建为 create-react-app。我们在开发过程中在前端(webpack)和后端(express)之间使用代理 described here 。这是我们定义后端服务器代理的部分(package.json
:
"scripts": {
...
},
"proxy": "http://localhost:3001"
}
在后端(服务器在端口 3001
上运行),我们调用另一个 API(但我认为这并不重要,只是一个注释)。我注意到从 webpack (create-react-app) 到 express (backed) 的代理调用非常慢。 (Windows 操作系统)
GET http://localhost:3000/endpoint/ -> ~600ms - 900ms
GET http://localhost:3001/endpoint/ -> ~150ms - 250ms
正如您所看到的,代理调用(端口 3000)和直接调用(端口 (3001))之间的时间差异确实很大。我预计会有延迟,但这看起来很奇怪。
此外,有时来自代理的大型 JSON 响应 (~38KB
) 会被破坏(无效 - 例如,在 30%+
情况下缺少响应的某些部分或交换字符)。我一直在后端遇到同样的问题,我想我已经通过设置 keep-alive
连接的 proxy-agent 解决了这个问题。
您知道为什么或如何改进代理时间和行为吗?
我还尝试在package.json
中设置代理,但没有成功。 create react app documentation说:
You may also specify any configuration value http-proxy-middleware or http-proxy supports.
agent: object to be passed to http(s).request (see Node's https agent and http agent objects)
是否可以在package.json
中定义代理?
我尝试过,但出现以下错误
TypeError: Agent option must be an Agent-like object, undefined, or false. at new ClientRequest (_http_client.js:106:11)
"proxy": {
"/": {
"target": "http://localhost:3001",
"agent": { "keepAlive": true }
}
}
非常感谢任何建议或想法。
最佳答案
添加我的问题的答案,以防有人遇到与我们相同的问题。
我们被迫使用react-app-rewired对于定制代理。遗憾的是,我们无法为 devServer
代理设置自定义代理。
如果您需要更改 devServer 的代理,documentation 中的解释非常好。 .
// config-overrides.js
module.exports = {
devServer: function(configFunction) {
return function(proxy, allowedHost) {
const config = configFunction(proxy, allowedHost);
config.proxy.forEach(p => {
p.agent = agent;
});
return config;
};
}
}
我猜这是一种解决方法,在 create-react-app
的 future 版本中可能不支持但响应时间约为 150 毫秒 - 230 毫秒(并且!没有无效的 JSON),这才是现在最重要的。 。
来自 react-app-rewired
的令人不安的注释我想指出:
By doing this you're breaking the "guarantees" that CRA provides. That is to say you now "own" the configs. No support will be provided. Proceed with caution.
关于javascript - React 在 package.json 中创建应用程序代理在 Windows 上速度很慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48954803/
我正在尝试使用 JAXB 从 XSD 生成 java 类。 XSD 是我公司的官方 xsd,因此我无法仅为我的项目修改它们。在该网站上进行了数百次尝试和搜索后,我决定直接提出问题。 我的 XSD 中有
我已经了解了以下链接中的详细信息,但仍然存在何时使用哪个文件的问题?https://docs.npmjs.com/files/package-lock.json 最佳答案 包.json 包含项目的相关
当我在 centos 上运行命令 rpmbuild -bb mypackage.spec 时,出现错误 error: Package already exists: %package debuginf
my.packages 是 src 目录中的自定义原型(prototype)包。 Plone 实例中的数千个项目与其类型一起添加。我想将包重命名为 my.package。通过简单地卸载 my.pack
根据 javadoc 规范,我在相关包的根目录中放置了一个名为 package-info.html 的文档文件。但是,当我在该文件夹上运行 Doxygen 时,不会拾取该文件中的文档。我如何告诉 Do
我已经定义了如下的包: (defpackage :thehilariouspackageofamirteymuri (:nicknames ampack amir teymuri) (:use
我正在思考这个问题: > .packages() > (.packages()) [1] "stats" "graphics" "grDevices" "utils" "datase
我在内存中有一个 System.IO.Packaging.Package(它是一个 WordprocessingDocument)并且想将它流式传输到浏览器以保存它。 Word 文档已被基于 MVC
即使这是我不常发现的东西,在成员之前注释/* package*/的原因是什么? /* package */ final void attach(Context context) { atta
我正在开发我的应用程序,但在添加包以便导入它时,我总是收到此错误。 error: type 'Package.Dependency' has no member 'Package' 这是我的 Pack
install.packages("data.table") trying URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.
放置手动创建的插件的最佳位置是什么: a) C:\Users\{UserName}\AppData\Roaming\Sublime Text 3\Packages 或 b) C:\Users\{Use
这是一个有趣的 Perl 行为。 (至少对我来说 :) ) 我有两个包 PACKAGE1 和 PACKAGE2,它们导出具有相同名称的函数 Method1()。 由于将有如此多的包将导出相同的功能,使
package-archives (("marmalade" . "http://marmalade-repo.org/packages/") ("gnu" . "http://elpa.gnu.or
任何人都可以让我知道 package-lock.json 文件的确切用途吗? 尽管许多人提到它用于查看版本化依赖树。 寻找简单易行的解释。 提前致谢。 最佳答案 npm install使用此文件来确保
Python documentation说 Consider this code: import sound.effects.echo import sound.effects.surround fr
我在 ubuntu 上运行 VPS: Distributor ID: Ubuntu Description: Ubuntu 14.04.5 LTS Release: 14.04 C
我有这样一个结构 $ tree -h . ├── [1.0K] myproj │ ├── [ 0] index.py │ ├── [ 0] __init__.py │ └──
我正在尝试解压 System.IO.Packaging.Package我从网络服务器收到的。也就是说,我正在使用 System.IO.Packaging.Package.Open(Stream)方法并
关于 package.json 文件中的@types 依赖项,我有一个愚蠢的问题: 在下面的 URL 中解释了应该安装的类型作为运行时依赖 npm install --save @types/loda
我是一名优秀的程序员,十分优秀!