【问题标题】:Azure CLI - unable to create Azure Synapse linked service - quoting issue with JSON fileAzure CLI - 无法创建 Azure Synapse 链接服务 - 引用 JSON 文件的问题
【发布时间】:2022-01-14 16:13:28
【问题描述】:

我正在尝试使用 Azure CLI 在 Azure Synapse 上创建链接服务。我有一个带有链接服务代码的 json 文件:

{
    "name": "LS_dakeyvault",
    "properties": {
        "annotations": [],
        "type": "AzureKeyVault",
        "typeProperties": {
            "baseUrl": "https://edap-d-kv.vault.azure.net/"
        }
    }
}

我会在 Windows shell 中运行以下命令:

az synapse linked-service create --name LS_dakeyvault --file "C:\Project\SynGitTest0\linkedService\LS_dakeyvault.json" --workspace-name edap-d-syn

我会收到这个错误:

Failed to parse JSON: C:\Project\SynGitTest0\linkedService\LS_dakeyvault.json
Error detail: Expecting value: line 1 column 1 (char 0)
The JSON may have been parsed by the shell. See https://docs.microsoft.com/cli/azure/use-cli-effectively#quoting-issues

我对其他 shell(powershell、bash)也有同样的问题。

我尝试按照 MS 提供的链接中的说明进行操作。我不确定我是否理解我应该做什么。我尝试将文件名放在单引号中:

az synapse linked-service create --name LS_dakeyvault --file "'C:\Project\SynGitTest0\linkedService\LS_dakeyvault.json'" --workspace-name edap-d-syn

(我不确定这是引用问题的正确解决方案。) 在那种情况下,我会得到一个不同的错误:

string indices must be integers
Traceback (most recent call last):
  File "D:\a\1\s\build_scripts\windows\artifacts\cli\Lib\site-packages\knack/cli.py", line 231, in invoke
  File "D:\a\1\s\build_scripts\windows\artifacts\cli\Lib\site-packages\azure/cli/core/commands/__init__.py", line 658, in execute
  File "D:\a\1\s\build_scripts\windows\artifacts\cli\Lib\site-packages\azure/cli/core/commands/__init__.py", line 721, in _run_jobs_serially   
  File "D:\a\1\s\build_scripts\windows\artifacts\cli\Lib\site-packages\azure/cli/core/commands/__init__.py", line 692, in _run_job
  File "D:\a\1\s\build_scripts\windows\artifacts\cli\Lib\site-packages\azure/cli/core/commands/__init__.py", line 328, in __call__
  File "D:\a\1\s\build_scripts\windows\artifacts\cli\Lib\site-packages\azure/cli/core/commands/command_operation.py", line 121, in handler     
  File "D:\a\1\s\build_scripts\windows\artifacts\cli\Lib\site-packages\azure/cli/command_modules/synapse/manual/operations/artifacts.py", line 
36, in create_or_update_linked_service
TypeError: string indices must be integers

【问题讨论】:

    标签: json shell azure-cli azure-synapse linked-service


    【解决方案1】:

    如果您检查 Microsoft 文档的 Azure Key Vault linked service 部分,您会发现链接服务的 JSON 文件是正确的,没有问题,如下所示。

    {
        "name": "AzureKeyVaultLinkedService",
        "properties": {
            "type": "AzureKeyVault",
            "typeProperties": {
                "baseUrl": "https://<azureKeyVaultName>.vault.azure.net"
            }
        }
    }
    

    所以问题一定出在 您的 az 命令中的文件路径。您能否检查文件路径在您的命令中是否正确。如果您检查az synapse linked-service create CLI 命令的Required Parameters,您会发现 -

    - -file 属性可以从 JSON 文件使用@{path} 语法 或 json 字符串提供。

    如果输入正确的路径并在路径开头添加@,则链接服务创建cmdlet 可以正常工作。如果您仍然遇到问题,请尝试移动到存储文件的目录并运行命令。

    我建议阅读az synapse linked-serviceStore credential in Azure Key Vault 文档以获取更多信息。

    【讨论】:

      猜你喜欢
      • 2021-06-04
      • 2018-05-22
      • 2022-01-19
      • 2022-11-14
      • 2021-01-18
      • 1970-01-01
      • 2021-03-01
      • 2020-05-14
      • 2021-04-13
      相关资源
      最近更新 更多