[질문] 쉘스크립트로 파싱중에 에러가 납니다.
쉘스크립트로 텍스트 파일을 파싱하고자 하는데, 한 변수만 출력하면 잘 출력되나, 동시에 print를 이용해
여러변수 출력시 모든 변수가 출력이 안됩니다.
즉 bash -x를 이용해 사용하면 보통 + 기호가 앞에 붙어야 하나, 안되는 부분에서 '표시가 뜨고 출력될 문자앞에 $가 붙고 뒤에 \r이 붙습니다.
이거때매 안되는거 같은데 왜 그런지 알려주세요
구문과 "bash -x 파일이름 " 한것을 아래와 같이 붙입니다.
lines=$(echo $(cat NewAzone_L4.txt | wc -l))
vrrp_id=$(echo $(cat NewAzone_L4.txt | awk '{print $3}' | cut -c 1- | head -1));
#vrrp_ip=$(echo $(cat NewAzone_L4.txt | awk '{print $7}' | head -1 | tail -1 | sed s/\r$//g))
vrrp_ip=`cat NewAzone_L4.txt | head -1 | tail -1 | awk -F: '{print $4}'`;
service_port=$(echo $(cat NewAzone_L4.txt | awk -FVirtual '{print $1}' | sed "/^$/d" | head -1 | tail -1 | awk '{print $1 "" $5}'))
real_id=$(echo $(cat NewAzone_L4.txt | awk -FVirtual '{print $1}' | sed /^$/d | head -1 | awk '{print $3}' | cut -c -4))
realserver_ip=$(echo $(cat NewAzone_L4.txt | awk -FVirtual '{print $1}' | sed /^$/d | head -1 | awk '{print $4}' | sed s/,//g))
status=$(echo $(cat NewAzone_L4.txt | awk -FVirtual '{print $1}' | sed "/^$/d" | head -1 | tail -1 | awk '{print $6}'))
######## print ##########
echo $vrrp_id $vrrp_ip $service_port $real_id $realserver_ip $status
printf "%s %s %s %s %s %s\n" $vrrp_id $vrrp_ip $service_port $real_id $realserver_ip $status
printf "%s %s\n" $vrrp_ip $service_port
printf "%s\n" $vrrp_id; printf "%s\n" $vrrp_ip
printf "%s\n" $service_port
printf "%s\n" $real_id
printf "%s\n" $realserver_ip
printf "%s\n" $status
=----------------- bash -x 파일이름 실행시 ----------------------
+++ cat NewAzone_L4.txt
+++ wc -l
++ echo 78
+ lines=78
+++ cat NewAzone_L4.txt
+++ awk '{print $3}'
+++ cut -c 1-
+++ head -1
++ echo v78
+ vrrp_id=v78
++ cat NewAzone_L4.txt
++ head -1
++ tail -1
++ awk -F: '{print $4}'
' vrrp_ip=' 203.254.227.78
+++ cat NewAzone_L4.txt
+++ awk -FVirtual '{print $1}'
+++ sed '/^$/d'
+++ head -1
+++ awk '{print $1 "" $5}'
+++ tail -1
++ echo http8080
+ service_port=http8080
+++ cat NewAzone_L4.txt
+++ awk -FVirtual '{print $1}'
+++ sed '/^$/d'
+++ head -1
+++ awk '{print $3}'
+++ cut -c -4
++ echo r101
+ real_id=r101
+++ cat NewAzone_L4.txt
+++ awk -FVirtual '{print $1}'
+++ sed '/^$/d'
+++ head -1
+++ awk '{print $4}'
+++ sed s/,//g
++ echo 203.254.227.101
+ realserver_ip=203.254.227.101
+++ cat NewAzone_L4.txt
+++ awk -FVirtual '{print $1}'
+++ sed '/^$/d'
+++ head -1
+++ tail -1
+++ awk '{print $6}'
'+ echo '(Failed)
' status='(Failed)
' echo v78 $'203.254.227.78\r' http8080 r101 203.254.227.101 '(Failed)
http8080 r101 203.254.227.101 (Failed)
' printf '%s %s %s %s %s %s\n' v78 $'203.254.227.78\r' http8080 r101 203.254.227.101 '(Failed)
http8080 r101 203.254.227.101 (Failed)
+ printf '%s %s\n' $'203.254.227.78\r' http8080
http808027.78
+ printf '%s\n' v78
v78
+ printf '%s\n' $'203.254.227.78\r'
203.254.227.78
+ printf '%s\n' http8080
http8080
+ printf '%s\n' r101
r101
+ printf '%s\n' 203.254.227.101
203.254.227.101
' printf '%s\n' '(Failed)
(Failed)
보통 +로 나타나야 하는데 '로 표시된 녀석이 문제를 일으키는거 같습니다. '를 일으키는 녀석은 보통 문장의 끝부분을
파싱할시에 나타나는데 왜그런건지 알려주세요.
[bushi@rose net]$[bushi@rose
처럼 head | tail 을 걷어내고 디버깅해보세요.
루프도는게 번거로우면 중간에 exit ;
OTL
댓글 달기