执行完全相同的代码时,awk命令具有不同的行为。为什么?

时间:2017-10-04 12:50:35

标签: bash shell awk

我创建了一个小shellcript,它能够接收一个值列表,例如" MY_VAR_NAME = var_value MY_VAR_NAME2 = value2 ...",仅用空格分隔。还应该可以使用MY_VAR_NAME =''等值。或MY_VAR_NAME =(无)。

然后,这些值用于更改环境变量文件中的值,例如,MY_VAR_NAME = var_value会使脚本将.env文件中的MY_VAR_NAME值更改为var_value,而不会更改有关该文件的任何其他内容。

env文件具有以下配置:

NODE_ENV=development  
APP_PATH=/media  
BASE_URL=http://localhost:3000  
ASSETS_PATH=http://localhost:3000  
USE_CDN=false  
APP_PORT=3000  
WEBPACK_PORT=8080  
IS_CONNECTED_TO_BACKEND=false  
SHOULD_BUILD=false  
USE_REDUX_TOOL=false  
USE_LOG_OUTPUT_AS_JSON=false  
ACCESS_KEY_ID=  
SECRET_ACCESS_KEY=  
BUCKET_NAME=  
BASE_PATH=  
MIX_PANEL_KEY=  
RDSTATION_KEY=  
RESOURCE_KEY=  
SHOULD_ENABLE_INTERCOM=false  
SHOULD_ENABLE_GTM=false  
SHOULD_ENABLE_UTA=false  
SHOULD_ENABLE_WOOTRIC=false

我已经调试了我的脚本,并发现这有时会出现问题

cat .envtemp | awk -v var_value="$VAR_VALUE" \
                    -v var_name="$VAR_NAME" \
                    -F '=' '$0 !~ var_name {print $0} $0 ~ var_name {print $1"="var_value}' | tee .envtemp

这段代码有时会向.envtemp输出正确的结果,而有时它只输出任何内容,使.envtemp为空

我使用的完整代码如下:

function change_value(){
    VAR_NAME=$1
    VAR_VALUE=$2

    cat .envtemp | awk -v var_value="$VAR_VALUE" \
                    -v var_name="$VAR_NAME" \
                    -F '=' '$0 !~ var_name {print $0} $0 ~ var_name {print $1"="var_value}' | tee .envtemp 

    ls -l -a .env*
}

function manage_env(){
    for VAR in $@
    do
        var_name=`echo $VAR | awk -F '=' '{print $1}'`
        var_value=`echo $VAR | awk -F '=' '{print $2}'`
        change_value $var_name $var_value
    done
}

function main(){
    manage_env $@

    cat .envtemp > .env

    exit 0
}

main $@

以下是重新创建错误的示例脚本。它不会每次都发生,当它发生时,它并不总是具有相同的输入。

#!/bin/bash
ENV_MANAGER_INPUT="NODE_ENV=production BASE_URL=http://qa.arquivei.com.br ASSETS_PATH=https://d4m6agb781hapn.cloudfront.net USE_CDN=true WEBPACK_PORT= IS_CONNECTED_TO_BACKEND=true ACCESS_KEY_ID= SECRET_ACCESS_KEY= BUCKET_NAME=frontend-assets-dev BASE_PATH=qa"
cp .env.dist .env

#Removes comment lines. The script needs a .envtemp file.
cat .env.dist | grep -v '#' | grep -v '^$' > .envtemp

./jenkins_env_manager.sh ${ENV_MANAGER_INPUT}

1 个答案:

答案 0 :(得分:0)

您是否尝试过使用两个文件:

mv .envtemp .envtemp.tmp
cat .envtemp.tmp | awk ... | tee .envtemp