Elasticsearch导入数据过程中,在 PowerShell 中使用 curl 命令的陷阱和解决方法
问题描述
在一次Elasticsearch的TD课过程中出现一个小问题。
环境Win11, nshou/elasticsearch-kibana,docker. 在下载kibana之后成功运行Elasticsearch,右键打开json文件文件夹中cmd,接着需要导入json数据:
curl --insecure -XPUT -u username:password https://localhost:9200/_bulk -H "Content-Type:application/json" --data-binary @file.json
然后就报错:
PS E:\ESILV\NoSQL\Elasticsearch> curl --insecure -XPUT -u elastic:UHpOXirbGCCAbQ_zyXJD https://localhost:9200/_bulk -H "Content-Type:application/json" --data-binary @stocks.json4
所在位置 行:1 字符: 134
+ ... _bulk -H "Content-Type:application/json" --data-binary @stocks.json4
+ ~~~~~~~
无法使用展开运算符“@”以在表达式中引用变量。只能将“@stocks”作为命令的参数。要在表达式中引用变量,请使用“$stocks”。
+ CategoryInfo : ParserError: (:) [], ParentContainsErrorRecordException
+ FullyQualifiedErrorId : SplattingNotPermitted
解决方案
在问教授后,发现她是通过先在该目录上下载了curl包。然后在导航栏中打开cmd。在运行就没错了。
附上curl介绍以及下载地址:
cURL is a small executable which sends/receives HTTP requests in command lines. You can specify headers by
adding parameters to your command (XPUT/XGET/XPOST, -H ”Content-Type…”, –databinary…).
You can download cURL (already installed under Linux and MacOSX) here (better to use the SSL embedded version):
https://curl.haxx.se/download.html. It is natively installed on Linux, MacOSX and eventually Windows. the parameters are different on PowerShell, use “Invite de commande”.
我一直没发现这两个方式打开的cmd原来不是一个东西(QwQ)…
同时,更深入了解了一下这个问题:
在其他环境中(如命令提示符或 Linux 终端),直接使用 curl 命令可能不会出现问题,因为这些环境中通常已经安装了 curl 工具,并且可以直接调用。
而在 PowerShell 中,虽然也可以使用 curl 命令,但在某些情况下会遇到问题,因为 PowerShell 具有自己的命令解释器,与传统的命令提示符或 Linux 终端有一些不同之处。在 PowerShell 中,curl 命令通常是 Invoke-WebRequest 或 Invoke-RestMethod 的别名,这意味着 PowerShell 会尝试将 curl 解释为这两个命令之一。如果你没有在 PowerShell 中定义 curl 别名,它将无法识别 curl 命令,因此会报错。
因此,为了在 PowerShell 中成功执行类似 curl 的操作,你应该使用 Invoke-WebRequest 或 Invoke-RestMethod 命令,而不是直接使用 curl。