{"id":48887,"date":"2023-09-01T15:03:46","date_gmt":"2023-11-16T06:43:00","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/"},"modified":"2024-04-30T21:05:56","modified_gmt":"2024-04-30T13:05:56","slug":"%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/","title":{"rendered":"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011"},"content":{"rendered":"<h3>\u7b80\u800c\u8a00\u4e4b<\/h3>\n<p>\u7528&#8221;\u57fa\u7840\u8bbe\u65bd\u5373\u4ee3\u7801&#8221;\u7684\u6982\u5ff5\uff0c\u6211\u4eec\u5c06\u4f7f\u7528Terraform\u5728Azure\u73af\u5883\u4e0a\u6784\u5efaAzure Databricks\u3002<\/p>\n<h3>\u672c\u5730\u73af\u5883<\/h3>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">macOS Monterey 12.1<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Azure CLI 2.28.0<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">terraform v1.0.11<\/ul>\n<h3>\u524d\u63d0\u6761\u4ef6<\/h3>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u5df2\u7ecf\u51c6\u5907\u597dAzure\u73af\u5883\uff08\u79df\u6237\/\u8ba2\u9605\uff09<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u5df2\u7ecf\u5728\u672c\u5730\u73af\u5883\u5b89\u88c5\u4e86&#8221;azure cli&#8221;<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u5df2\u7ecf\u5728\u672c\u5730\u73af\u5883\u914d\u7f6e\u4e86&#8221;terraform&#8221;\u73af\u5883<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\u5df2\u7ecf\u521b\u5efa\u4e86\u7528\u4e8e\u5728Azure\u4e0a\u4f7f\u7528Terraform\u6784\u5efa\u73af\u5883\u7684\u670d\u52a1\u4e3b\u4f53\uff0c\u5e76\u5b9a\u4e49\u4e86\u7528\u4e8eTerraform\u7684\u672c\u5730\u73af\u5883\u53d8\u91cf\u3002<\/ol>\n<hr \/>\n<h2>\u5c1d\u8bd5\u4f7f\u7528Terraform\u5728Azure\u4e0a\u521b\u5efaDatabricks\u3002<\/h2>\n<h3>\u7f16\u5199 Terraform \u5b9a\u4e49\u6587\u4ef6\u3002<\/h3>\n<p>\u4e3b\u8981\u5b9a\u4e49\u6587\u4ef6<\/p>\n<pre class=\"post-pre\"><code><span class=\"nx\">terraform<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">required_providers<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">azurerm<\/span> <span class=\"p\">=<\/span>  <span class=\"s2\">\"~&gt; 2.33\"<\/span>\r\n    <span class=\"nx\">random<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"~&gt; 2.2\"<\/span>\r\n\r\n    <span class=\"nx\">databricks<\/span> <span class=\"p\">=<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nx\">source<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"databrickslabs\/databricks\"<\/span>\r\n      <span class=\"nx\">version<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"0.4.4\"<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nx\">provider<\/span> <span class=\"s2\">\"azurerm\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">features<\/span> <span class=\"p\">{}<\/span>\r\n  <span class=\"nx\">tenant_id<\/span>     <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">ARM_TENANT_ID<\/span>\r\n  <span class=\"nx\">client_id<\/span>     <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">ARM_CLIENT_ID<\/span>\r\n  <span class=\"nx\">client_secret<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">ARM_CLIENT_SECRET<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u53c2\u6570\u5b9a\u4e49\u6587\u4ef6<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\"># \u74b0\u5883\u5909\u6570\uff08Azure\u30b5\u30fc\u30d3\u30b9\u30d7\u30ea\u30f3\u30b7\u30d1\u30eb\uff09<\/span>\r\n<span class=\"nx\">variable<\/span> <span class=\"nx\">ARM_TENANT_ID<\/span> <span class=\"p\">{}<\/span>\r\n<span class=\"nx\">variable<\/span> <span class=\"nx\">ARM_CLIENT_ID<\/span> <span class=\"p\">{}<\/span>\r\n<span class=\"nx\">variable<\/span> <span class=\"nx\">ARM_CLIENT_SECRET<\/span> <span class=\"p\">{}<\/span>\r\n\r\n<span class=\"c1\"># \u30bf\u30b0\u60c5\u5831<\/span>\r\n<span class=\"nx\">variable<\/span> <span class=\"nx\">tags_def<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">default<\/span> <span class=\"p\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">owner<\/span>      <span class=\"p\">=<\/span> <span class=\"s2\">\"ituru\"<\/span>\r\n    <span class=\"nx\">period<\/span>     <span class=\"p\">=<\/span> <span class=\"s2\">\"2022-03-31\"<\/span>\r\n    <span class=\"nx\">CostCenter<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"psg2\"<\/span>\r\n    <span class=\"nx\">Environment<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"Demo\"<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u5404\u7a2e\u30d1\u30e9\u30e1\u30fc\u30bf <\/span>\r\n<span class=\"nx\">variable<\/span> <span class=\"nx\">resource_group_name<\/span> <span class=\"p\">{}<\/span>\r\n<span class=\"nx\">variable<\/span> <span class=\"nx\">region<\/span> <span class=\"p\">{}<\/span>\r\n<span class=\"nx\">variable<\/span> <span class=\"nx\">email_notifier<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">description<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"The email address to send job status to\"<\/span>\r\n  <span class=\"nx\">type<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">list<\/span><span class=\"err\">(<\/span><span class=\"nx\">string<\/span><span class=\"err\">)<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u53c2\u6570\u503c\u5b9a\u4e49\u6587\u4ef6<\/p>\n<pre class=\"post-pre\"><code># \u74b0\u5883\u5909\u6570\u306e\u5b9a\u7fa9\uff08Azure\u30b5\u30fc\u30d3\u30b9\u30d7\u30ea\u30f3\u30b7\u30d1\u30eb\uff09\r\nARM_TENANT_ID       = \"zzzzzzzz-cccc-4645-5757-zzzzzzzzzzzz\"\r\nARM_CLIENT_ID       = \"xxxxxxxx-xxxx-4444-9922-xxxxxxxxxxxx\"\r\nARM_CLIENT_SECRET   = \"hogehogehogehogehogehogehogehogege\"\r\n\r\n# \u30d1\u30e9\u30e1\u30fc\u30bf\u5024\u306e\u5b9a\u7fa9\r\nresource_group_name = \"rg_ituru_bricks01\"     \/\/ \u30ea\u30bd\u30fc\u30b9\u30b0\u30eb\u30fc\u30d7\u540d\r\nregion              = \"japaneast\"             \/\/ \u5229\u7528\u30ea\u30fc\u30b8\u30e7\u30f3\r\nemail_notifier      = [\"hogehoge@gegege.com\"] \/\/ \u9001\u4fe1\u5148\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\uff08List\u578b\uff09\r\n<\/code><\/pre>\n<p>\u8cc7\u6599\u642c\u904b\u516c\u53f8Databricks\u6240\u63d0\u4f9b\u7684\u5b9a\u7fa9\u6a94\u6848<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\"># Databricks\u30d7\u30ed\u30d0\u30a4\u30c0\u30fc<\/span>\r\n<span class=\"c1\"># provider \"databricks\" {}<\/span>\r\n<span class=\"nx\">provider<\/span> <span class=\"s2\">\"databricks\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">host<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">azurerm_databricks_workspace<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"err\">.<\/span><span class=\"nx\">workspace_url<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># Get information about the Databricks user that is calling<\/span>\r\n<span class=\"c1\"># the Databricks API (the one associated with \"databricks_connection_profile\").<\/span>\r\n<span class=\"c1\"># \u30e6\u30fc\u30b6\u306e\u5b9a\u7fa9<\/span>\r\n<span class=\"nx\">data<\/span> <span class=\"s2\">\"databricks_current_user\"<\/span> <span class=\"s2\">\"me\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">depends_on<\/span> <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"nx\">azurerm_databricks_workspace<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># Get the latest Spark version to use for the cluster.<\/span>\r\n<span class=\"c1\"># Spark\u30d0\u30fc\u30b8\u30e7\u30f3\u306e\u5b9a\u7fa9<\/span>\r\n<span class=\"nx\">data<\/span> <span class=\"s2\">\"databricks_spark_version\"<\/span> <span class=\"s2\">\"latest\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">long_term_support<\/span> <span class=\"p\">=<\/span> <span class=\"kc\">true<\/span>\r\n  <span class=\"nx\">depends_on<\/span> <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"nx\">azurerm_databricks_workspace<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># Get the smallest available node type to use for the cluster. Choose<\/span>\r\n<span class=\"c1\"># only from among available node types with local storage.<\/span>\r\n<span class=\"c1\"># \u30ce\u30fc\u30c9\u30bf\u30a4\u30d7\u306e\u5b9a\u7fa9<\/span>\r\n<span class=\"nx\">data<\/span> <span class=\"s2\">\"databricks_node_type\"<\/span> <span class=\"s2\">\"smallest\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">local_disk<\/span> <span class=\"p\">=<\/span> <span class=\"kc\">true<\/span>\r\n  <span class=\"nx\">depends_on<\/span> <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"nx\">azurerm_databricks_workspace<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30e9\u30f3\u30c0\u30e0\u6587\u5b57\u5217\u751f\u6210<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"random_string\"<\/span> <span class=\"s2\">\"naming\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">special<\/span> <span class=\"p\">=<\/span> <span class=\"kc\">false<\/span>\r\n  <span class=\"nx\">upper<\/span>   <span class=\"p\">=<\/span> <span class=\"kc\">false<\/span>\r\n  <span class=\"nx\">length<\/span>  <span class=\"p\">=<\/span> <span class=\"mi\">6<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># # The prefix to use when naming the databricks workspace<\/span>\r\n<span class=\"c1\"># \u30ed\u30fc\u30ab\u30eb\u5909\u6570\u5b9a\u7fa9<\/span>\r\n<span class=\"nx\">locals<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">prefix<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"databricksdemo-${random_string.naming.result}\"<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30ea\u30bd\u30fc\u30b9\u30b0\u30eb\u30fc\u30d7<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"azurerm_resource_group\"<\/span> <span class=\"s2\">\"this\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">name<\/span>     <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">resource_group_name<\/span>\r\n  <span class=\"nx\">location<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">region<\/span>\r\n  <span class=\"nx\">tags<\/span>     <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">tags_def<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># Databricks \u30ef\u30fc\u30af\u30b9\u30da\u30fc\u30b9<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"azurerm_databricks_workspace\"<\/span> <span class=\"s2\">\"this\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">name<\/span>                        <span class=\"p\">=<\/span> <span class=\"s2\">\"ituru-${local.prefix}-workspace\"<\/span>\r\n  <span class=\"nx\">resource_group_name<\/span>         <span class=\"p\">=<\/span> <span class=\"nx\">azurerm_resource_group<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"err\">.<\/span><span class=\"nx\">name<\/span>\r\n  <span class=\"nx\">location<\/span>                    <span class=\"p\">=<\/span> <span class=\"nx\">azurerm_resource_group<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"err\">.<\/span><span class=\"nx\">location<\/span>\r\n  <span class=\"nx\">sku<\/span>                         <span class=\"p\">=<\/span> <span class=\"s2\">\"trial\"<\/span>\r\n  <span class=\"nx\">managed_resource_group_name<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"ituru-${local.prefix}-workspace-rg\"<\/span>\r\n  <span class=\"nx\">tags<\/span>                        <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">tags_def<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u30b9\u30b3\u30fc\u30d7\u751f\u6210<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_secret_scope\"<\/span> <span class=\"s2\">\"this\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">name<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"demo-${data.databricks_current_user.me.alphanumeric}\"<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u30c8\u30fc\u30af\u30f3\u751f\u6210<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_token\"<\/span> <span class=\"s2\">\"pat\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">comment<\/span>          <span class=\"p\">=<\/span> <span class=\"s2\">\"Created from ${abspath(path.module)}\"<\/span>\r\n  <span class=\"nx\">lifetime_seconds<\/span> <span class=\"p\">=<\/span> <span class=\"mi\">3600<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u767a\u884c<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_secret\"<\/span> <span class=\"s2\">\"token\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">string_value<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">databricks_token<\/span><span class=\"err\">.<\/span><span class=\"nx\">pat<\/span><span class=\"err\">.<\/span><span class=\"nx\">token_value<\/span>\r\n  <span class=\"nx\">scope<\/span>        <span class=\"p\">=<\/span> <span class=\"nx\">databricks_secret_scope<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"err\">.<\/span><span class=\"nx\">name<\/span>\r\n  <span class=\"nx\">key<\/span>          <span class=\"p\">=<\/span> <span class=\"s2\">\"token\"<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n\r\n<span class=\"c1\"># Create a simple, sample notebook. Store it in a subfolder within<\/span>\r\n<span class=\"c1\"># the Databricks current user's folder. The notebook contains the<\/span>\r\n<span class=\"c1\"># following basic Spark code in Python.<\/span>\r\n<span class=\"c1\"># \u30ce\u30fc\u30c8\u30d6\u30c3\u30af<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_notebook\"<\/span> <span class=\"s2\">\"this\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">path<\/span>     <span class=\"p\">=<\/span> <span class=\"s2\">\"${data.databricks_current_user.me.home}\/Terraform\"<\/span>\r\n  <span class=\"nx\">language<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"PYTHON\"<\/span>\r\n  <span class=\"nx\">content_base64<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">base64encode<\/span><span class=\"err\">(<\/span><span class=\"o\">&lt;&lt;-<\/span><span class=\"no\">EOT<\/span><span class=\"sh\">\r\n    token = dbutils.secrets.get('${databricks_secret_scope.this.name}', '${databricks_secret.token.key}')\r\n    print(f'This should be redacted: {token}')\r\n<\/span><span class=\"no\">    EOT\r\n<\/span>  <span class=\"err\">)<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># Create a job to run the sample notebook. The job will create<\/span>\r\n<span class=\"c1\"># a cluster to run on. The cluster will use the smallest available<\/span>\r\n<span class=\"c1\"># node type and run the latest version of Spark.<\/span>\r\n<span class=\"c1\"># \u30b8\u30e7\u30d6<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_job\"<\/span> <span class=\"s2\">\"this\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">name<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"Terraform Demo (${data.databricks_current_user.me.alphanumeric})\"<\/span>\r\n  <span class=\"nx\">new_cluster<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">num_workers<\/span>   <span class=\"p\">=<\/span> <span class=\"mi\">1<\/span>\r\n    <span class=\"nx\">spark_version<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">data<\/span><span class=\"err\">.<\/span><span class=\"nx\">databricks_spark_version<\/span><span class=\"err\">.<\/span><span class=\"nx\">latest<\/span><span class=\"err\">.<\/span><span class=\"nx\">id<\/span>\r\n    <span class=\"nx\">node_type_id<\/span>  <span class=\"p\">=<\/span> <span class=\"nx\">data<\/span><span class=\"err\">.<\/span><span class=\"nx\">databricks_node_type<\/span><span class=\"err\">.<\/span><span class=\"nx\">smallest<\/span><span class=\"err\">.<\/span><span class=\"nx\">id<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">notebook_task<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">notebook_path<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">databricks_notebook<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"err\">.<\/span><span class=\"nx\">path<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">email_notifications<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">on_success<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">email_notifier<\/span>\r\n    <span class=\"nx\">on_failure<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">var<\/span><span class=\"err\">.<\/span><span class=\"nx\">email_notifier<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">depends_on<\/span> <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"nx\">azurerm_databricks_workspace<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"p\">,<\/span> <span class=\"nx\">databricks_notebook<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30af\u30e9\u30b9\u30bf\u30fc<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_cluster\"<\/span> <span class=\"s2\">\"this\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">cluster_name<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"Exploration (${data.databricks_current_user.me.alphanumeric})\"<\/span>\r\n  <span class=\"nx\">spark_version<\/span>           <span class=\"p\">=<\/span> <span class=\"nx\">data<\/span><span class=\"err\">.<\/span><span class=\"nx\">databricks_spark_version<\/span><span class=\"err\">.<\/span><span class=\"nx\">latest<\/span><span class=\"err\">.<\/span><span class=\"nx\">id<\/span>\r\n  <span class=\"nx\">instance_pool_id<\/span>        <span class=\"p\">=<\/span> <span class=\"nx\">databricks_instance_pool<\/span><span class=\"err\">.<\/span><span class=\"nx\">smallest_nodes<\/span><span class=\"err\">.<\/span><span class=\"nx\">id<\/span>\r\n  <span class=\"nx\">autotermination_minutes<\/span> <span class=\"p\">=<\/span> <span class=\"mi\">20<\/span>\r\n  <span class=\"nx\">autoscale<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">min_workers<\/span> <span class=\"p\">=<\/span> <span class=\"mi\">1<\/span>\r\n    <span class=\"nx\">max_workers<\/span> <span class=\"p\">=<\/span> <span class=\"mi\">10<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30af\u30e9\u30b9\u30bf\u30fc\u30dd\u30ea\u30b7\u30fc<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_cluster_policy\"<\/span> <span class=\"s2\">\"this\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">name<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"Minimal (${data.databricks_current_user.me.alphanumeric})\"<\/span>\r\n  <span class=\"nx\">definition<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">jsonencode<\/span><span class=\"err\">(<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"s2\">\"dbus_per_hour\"<\/span> <span class=\"err\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"s2\">\"type\"<\/span> <span class=\"err\">:<\/span> <span class=\"s2\">\"range\"<\/span><span class=\"err\">,<\/span>\r\n      <span class=\"s2\">\"maxValue\"<\/span> <span class=\"err\">:<\/span> <span class=\"mi\">10<\/span>\r\n    <span class=\"p\">}<\/span><span class=\"err\">,<\/span>\r\n    <span class=\"s2\">\"autotermination_minutes\"<\/span> <span class=\"err\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"s2\">\"type\"<\/span> <span class=\"err\">:<\/span> <span class=\"s2\">\"fixed\"<\/span><span class=\"err\">,<\/span>\r\n      <span class=\"s2\">\"value\"<\/span> <span class=\"err\">:<\/span> <span class=\"mi\">20<\/span><span class=\"err\">,<\/span>\r\n      <span class=\"s2\">\"hidden\"<\/span> <span class=\"err\">:<\/span> <span class=\"kc\">true<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">}<\/span><span class=\"err\">)<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># \u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u30d7\u30fc\u30eb<\/span>\r\n<span class=\"nx\">resource<\/span> <span class=\"s2\">\"databricks_instance_pool\"<\/span> <span class=\"s2\">\"smallest_nodes\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">instance_pool_name<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"Smallest Nodes (${data.databricks_current_user.me.alphanumeric})\"<\/span>\r\n  <span class=\"nx\">min_idle_instances<\/span> <span class=\"p\">=<\/span> <span class=\"mi\">0<\/span>\r\n  <span class=\"nx\">max_capacity<\/span>       <span class=\"p\">=<\/span> <span class=\"mi\">30<\/span>\r\n  <span class=\"nx\">node_type_id<\/span>       <span class=\"p\">=<\/span> <span class=\"nx\">data<\/span><span class=\"err\">.<\/span><span class=\"nx\">databricks_node_type<\/span><span class=\"err\">.<\/span><span class=\"nx\">smallest<\/span><span class=\"err\">.<\/span><span class=\"nx\">id<\/span>\r\n  <span class=\"nx\">preloaded_spark_versions<\/span> <span class=\"p\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"nx\">data<\/span><span class=\"err\">.<\/span><span class=\"nx\">databricks_spark_version<\/span><span class=\"err\">.<\/span><span class=\"nx\">latest<\/span><span class=\"err\">.<\/span><span class=\"nx\">id<\/span>\r\n  <span class=\"p\">]<\/span>\r\n\r\n  <span class=\"nx\">idle_instance_autotermination_minutes<\/span> <span class=\"p\">=<\/span> <span class=\"mi\">20<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u8f93\u51fa\u4fe1\u606f\u6587\u4ef6<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\"># Print the URL to the databrickes workspace.<\/span>\r\n<span class=\"nx\">output<\/span> <span class=\"s2\">\"databricks_url\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">value<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"https:\/\/${azurerm_databricks_workspace.this.workspace_url}\/\"<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># Print the URL to the notebook.<\/span>\r\n<span class=\"nx\">output<\/span> <span class=\"s2\">\"notebook_url\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">value<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">databricks_notebook<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"err\">.<\/span><span class=\"nx\">url<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\"># Print the URL to the job.<\/span>\r\n<span class=\"nx\">output<\/span> <span class=\"s2\">\"job_url\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">value<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">databricks_job<\/span><span class=\"err\">.<\/span><span class=\"nx\">this<\/span><span class=\"err\">.<\/span><span class=\"nx\">url<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h3>\u6267\u884cTerraform<\/h3>\n<pre class=\"post-pre\"><code>## init\r\n$ terraform init\r\n\r\n## plan\r\n$ terraform plan\r\n\r\n## apply\r\n$ terraform apply\r\n<\/code><\/pre>\n<h3>\u8fdb\u884c Terraform \u6267\u884c\u540e\u7684\u786e\u8ba4<\/h3>\n<pre class=\"post-pre\"><code>## \u4f5c\u6210\u3055\u308c\u305f\u30ea\u30bd\u30fc\u30b9\u30b0\u30eb\u30fc\u30d7\u306e\u78ba\u8a8d\r\n$ az group show --name rg_ituru_bricks01\r\n{\r\n  \"id\": \"\/subscriptions\/nnnnnnnn-1717-4334-9779-mmmmmmmmmmmm\/resourceGroups\/rg_ituru_bricks01\",\r\n  \"location\": \"japaneast\",\r\n  \"managedBy\": null,\r\n  \"name\": \"rg_ituru_bricks01\",\r\n  \"properties\": {\r\n    \"provisioningState\": \"Succeeded\"\r\n  },\r\n  \"tags\": {\r\n    \"CostCenter\": \"psg2\",\r\n    \"Environment\": \"Demo\",\r\n    \"owner\": \"ituru\",\r\n    \"period\": \"2022-03-31\"\r\n  },\r\n  \"type\": \"Microsoft.Resources\/resourceGroups\"\r\n}\r\n\r\n## \u4f5c\u6210\u3057\u305f Azure Databricks Workspace \u306e\u78ba\u8a8d\r\n$ az databricks workspace list --resource-group rg_ituru_bricks01 -o table\r\nCreatedDateTime                   Location    ManagedResourceGroupId                                                                                       Name                                   ProvisioningState    ResourceGroup      WorkspaceId       WorkspaceUrl\r\n--------------------------------  ----------  -----------------------------------------------------------------------------------------------------------  -------------------------------------  -------------------  -----------------  ----------------  ------------------------------------------\r\n2022-01-13T00:11:27.479190+00:00  japaneast   \/subscriptions\/nnnnnnnn-1717-4334-9779-mmmmmmmmmmmm\/resourceGroups\/ituru-databricksdemo-7ke24v-workspace-rg  ituru-databricksdemo-7ke24v-workspace  Succeeded            rg_ituru_bricks01  1975197519751975  adb-1975197519751975.6.azuredatabricks.net\r\n\r\n<\/code><\/pre>\n<p>\u672c\u5730\u5de5\u4f5c\u76ee\u5f55\u7684\u72b6\u6001<\/p>\n<pre class=\"post-pre\"><code>$ tree -a         \r\n.\r\n\u251c\u2500\u2500 .terraform\r\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 providers\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u2514\u2500\u2500 registry.terraform.io\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u251c\u2500\u2500 databrickslabs\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0 \u2514\u2500\u2500 databricks\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 0.3.9\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0 \u2514\u2500\u2500 darwin_amd64\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 CHANGELOG.md\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 LICENSE\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 NOTICE\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2514\u2500\u2500 terraform-provider-databricks_v0.3.9\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 0.4.0\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0 \u2514\u2500\u2500 darwin_amd64\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 CHANGELOG.md\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 LICENSE\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u251c\u2500\u2500 NOTICE\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2514\u2500\u2500 terraform-provider-databricks_v0.4.0\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0     \u2514\u2500\u2500 0.4.4\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0         \u2514\u2500\u2500 darwin_amd64\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0             \u251c\u2500\u2500 CHANGELOG.md\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0             \u251c\u2500\u2500 LICENSE\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0             \u251c\u2500\u2500 NOTICE\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2502\u00a0\u00a0             \u2514\u2500\u2500 terraform-provider-databricks_v0.4.4\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2514\u2500\u2500 hashicorp\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u251c\u2500\u2500 azurerm\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0 \u251c\u2500\u2500 2.88.1\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u2514\u2500\u2500 darwin_amd64\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0 \u2502\u00a0\u00a0     \u2514\u2500\u2500 terraform-provider-azurerm_v2.88.1_x5\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0 \u2514\u2500\u2500 2.91.0\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0     \u2514\u2500\u2500 darwin_amd64\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0         \u2514\u2500\u2500 terraform-provider-azurerm_v2.91.0_x5\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u251c\u2500\u2500 external\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0 \u2514\u2500\u2500 2.1.0\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0     \u2514\u2500\u2500 darwin_amd64\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2502\u00a0\u00a0         \u2514\u2500\u2500 terraform-provider-external_v2.1.0_x5\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0         \u2514\u2500\u2500 random\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0             \u2514\u2500\u2500 2.3.1\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0                 \u2514\u2500\u2500 darwin_amd64\r\n\u2502\u00a0\u00a0 \u2502\u00a0\u00a0                     \u2514\u2500\u2500 terraform-provider-random_v2.3.1_x4\r\n\u2502\u00a0\u00a0 \u2514\u2500\u2500 terraform.tfstate\r\n\u251c\u2500\u2500 .terraform.lock.hcl\r\n\u251c\u2500\u2500 databricks.tf\r\n\u251c\u2500\u2500 main.tf\r\n\u251c\u2500\u2500 outputs.tf\r\n\u251c\u2500\u2500 terraform.tfstate\r\n\u251c\u2500\u2500 terraform.tfstate.backup\r\n\u251c\u2500\u2500 terraform.tfvars\r\n\u2514\u2500\u2500 variables.tf\r\n<\/code><\/pre>\n<h3>\u4f7f\u7528Terraform\u5220\u9664\u5df2\u521b\u5efa\u7684\u8d44\u6e90<\/h3>\n<pre class=\"post-pre\"><code>$ terraform destroy\r\n<\/code><\/pre>\n<hr \/>\n<h3>\u603b\u7ed3<\/h3>\n<p>\u4f7f\u7528Terraform\u5de5\u5177\uff0c\u5feb\u901f\u5728Azure\u73af\u5883\u4e0a\u90e8\u7f72Azure Databricks\u6210\u529f\u4e86\u3002<\/p>\n<h3>\u8bf7\u53c2\u8003\u8fd9\u7bc7\u6587\u7ae0\u3002<\/h3>\n<p>\u6211\u53c2\u8003\u4e86\u4e0b\u9762\u8fd9\u7bc7\u6587\u7ae0\uff0c\u5e76\u8868\u793a\u611f\u8c22\uff1a<br \/>\n&#8211; \u4f7f\u7528Terraform\u5728Azure\u4e0a\u90e8\u7f72Databricks\u5de5\u4f5c\u533a<br \/>\n&#8211; Databricks Terraform\u63d0\u4f9b\u7a0b\u5e8f<br \/>\n&#8211; DatabricksTerraform\u63d0\u4f9b\u7a0b\u5e8f<br \/>\n&#8211; \u4f7f\u7528Terraform\u5728\u7aef\u5230\u7aef\u7ba1\u7406\u5de5\u4f5c\u533a<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u7b80\u800c\u8a00\u4e4b \u7528&#8221;\u57fa\u7840\u8bbe\u65bd\u5373\u4ee3\u7801&#8221;\u7684\u6982\u5ff5\uff0c\u6211\u4eec\u5c06\u4f7f\u7528Terraform\u5728Azure\u73af\u5883\u4e0a\u6784 [&hellip;]<\/p>\n","protected":false},"author":11,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-48887","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5df2\u7ecf\u521b\u5efa\u4e86azure-databricks\u3010azure\u7684\u57fa\u7840\u67b6\u6784\u3011\u3002\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011\" \/>\n<meta property=\"og:description\" content=\"\u7b80\u800c\u8a00\u4e4b \u7528&#8221;\u57fa\u7840\u8bbe\u65bd\u5373\u4ee3\u7801&#8221;\u7684\u6982\u5ff5\uff0c\u6211\u4eec\u5c06\u4f7f\u7528Terraform\u5728Azure\u73af\u5883\u4e0a\u6784 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5df2\u7ecf\u521b\u5efa\u4e86azure-databricks\u3010azure\u7684\u57fa\u7840\u67b6\u6784\u3011\u3002\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-11-16T06:43:00+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-30T13:05:56+00:00\" \/>\n<meta name=\"author\" content=\"\u65b0, \u97f5\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u65b0, \u97f5\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/\",\"name\":\"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-11-16T06:43:00+00:00\",\"dateModified\":\"2024-04-30T13:05:56+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9\",\"name\":\"\u65b0, \u97f5\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"caption\":\"\u65b0, \u97f5\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5df2\u7ecf\u521b\u5efa\u4e86azure-databricks\u3010azure\u7684\u57fa\u7840\u67b6\u6784\u3011\u3002\/","og_locale":"zh_CN","og_type":"article","og_title":"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011","og_description":"\u7b80\u800c\u8a00\u4e4b \u7528&#8221;\u57fa\u7840\u8bbe\u65bd\u5373\u4ee3\u7801&#8221;\u7684\u6982\u5ff5\uff0c\u6211\u4eec\u5c06\u4f7f\u7528Terraform\u5728Azure\u73af\u5883\u4e0a\u6784 [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5df2\u7ecf\u521b\u5efa\u4e86azure-databricks\u3010azure\u7684\u57fa\u7840\u67b6\u6784\u3011\u3002\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-11-16T06:43:00+00:00","article_modified_time":"2024-04-30T13:05:56+00:00","author":"\u65b0, \u97f5","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u65b0, \u97f5","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"4 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/","name":"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-11-16T06:43:00+00:00","dateModified":"2024-04-30T13:05:56+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u6211\u5df2\u7ecf\u521b\u5efa\u4e86Azure Databricks\u3010Azure\u7684\u57fa\u7840\u67b6\u6784\u3011"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9","name":"\u65b0, \u97f5","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","caption":"\u65b0, \u97f5"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%b7%b2%e7%bb%8f%e5%88%9b%e5%bb%ba%e4%ba%86azure-databricks%e3%80%90azure%e7%9a%84%e5%9f%ba%e7%a1%80%e6%9e%b6%e6%9e%84%e3%80%91%e3%80%82\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/48887","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/11"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=48887"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/48887\/revisions"}],"predecessor-version":[{"id":94296,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/48887\/revisions\/94296"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=48887"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=48887"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=48887"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}