1

我是厨师新手,对 Ruby 知之甚少。

我在“storage_conn_str”中低于价值

SAS 令牌:#Chef::DelayedEvaluator:0x0000000006e28c80@c:/chef/cache/cookbooks/*****/recipes/*****.rb:20

在我的食谱中,我将“&”替换为“&”。我用lazy来延迟ruby块和资源中变量的执行。

下面是我的食谱

key_vault_name node['key_vault_names']['Test']
end

ruby_block 'modify_token' do
  block do
    sastoken = lazy { node.run_state['SAS_Token'] }
    Chef::Log.info("SAS Token: #{sastoken}")
    modified_token = lazy { sastoken.gsub(/[&]/, '&') }
    Chef::Log.info("SAS Token after replacement: #{modified_token}")
    storage_conn_str = lazy { File.join(storage_conn_str , modified_token)}
    Chef::Log.info("storage connection string: #{storage_conn_str}")
  end
  action :run
end

webapp 'TableStorageAPI' do
source URI.join(node['binary_storage_uri'], app_node['source']).to_s
version app_version
appPoolName 'TableStorageAPI'
path '/V1/TableStorageAPI'
siteName 'SSL'
enable32Bit false
pipeline_mode :Integrated
use_servicebroker false
transform_variables(
storage_conn: lazy {storage_conn_str},
mail_to: app_node['mail_to'],
mail_from: app_node['mail_from'],
smtp_host: node['tps']['smtp']['server'],
log_location: app_node['log_location'],
env_name: app_node['env_name']
)
end```
----------------------------------------------
I am not sure why webapp resource is executing before the computation of 'storage_conn_str'.
4

1 回答 1

0

“我不确定为什么在计算 'storage_conn_str' 之前执行 webapp 资源。”

这是因为 storage_conn_str 是在ruby​​_block 'modify_token'中定义的。它对 webapp 资源不可见。

您可以做的是,改为创建一个属性。

例如:节点["mycb"]["storage_conn_str"] = ""

在 ruby​​_block

ruby_block 'modify_token' do
  block do
    ...
    storage_conn_str = lazy { File.join(storage_conn_str , modified_token)}
    Chef::Log.info("storage connection string: #{storage_conn_str}")
    node.default["mycb"]["storage_conn_str"] = storage_conn_str 
  end
  action :run
end

在 webapp 资源中

webapp 'TableStorageAPI' do
...
   storage_conn: node["mycb"]["storage_conn_str"]
...
end

这应该可以解决您遇到的问题

于 2020-04-27T03:27:58.407 回答