Portál AbcLinuxu, 6. května 2024 07:18


Dotaz: Escape znaku v prikazu

20.1.2016 14:49 lmlmlm
Escape znaku v prikazu
Přečteno: 249×
Odpovědět | Admin
Ahoj, poprosil bych o radu pri vyescapovani zavorek ( a ), nemuzu prijit na to, co delam spatne. Diky

Takto bohuzel nefunguje
#!/bin/sh
...
 eval \("$_RUNJAVA\"" "\"$LOGGING_CONFIG\"" $LOGGING_MANAGER $JAVA_OPTS $CATALINA_OPTS \
      -Djava.endorsed.dirs="\"$JAVA_ENDORSED_DIRS\"" -classpath "\"$CLASSPATH\"" \
      -Dcatalina.base="\"$CATALINA_BASE\"" \
      -Dcatalina.home="\"$CATALINA_HOME\"" \
      -Djava.io.tmpdir="\"$CATALINA_TMPDIR\"" \
      org.apache.catalina.startup.Bootstrap "$@" start 2>&1 & [ ! -z "$CATALINA_PID" ] && echo $! > "$CATALINA_PID"\) | tee -a $CATALINA_OUT 2>&1 | $RSYSLOG  2>&1 &
Takto je to v originalu
 eval "\"$_RUNJAVA\"" "\"$LOGGING_CONFIG\"" $LOGGING_MANAGER $JAVA_OPTS $CATALINA_OPTS \
      -Djava.endorsed.dirs="\"$JAVA_ENDORSED_DIRS\"" -classpath "\"$CLASSPATH\"" \
      -Dcatalina.base="\"$CATALINA_BASE\"" \
      -Dcatalina.home="\"$CATALINA_HOME\"" \
      -Djava.io.tmpdir="\"$CATALINA_TMPDIR\"" \
      org.apache.catalina.startup.Bootstrap "$@" start \
      >> "$CATALINA_OUT" 2>&1 "&"

Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

20.1.2016 15:08 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: Escape znaku v prikazu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Před znak "[" zřejmě místo "&" patří "&&"
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
20.1.2016 15:33 lmlmlm
Rozbalit Rozbalit vše Re: Escape znaku v prikazu
ne, to tam ma byt, to jen poslu do pozadi, pak si vyctu pid, tahle konstrukce je kvuli tomu, ze bych pak dale bych dostaval pid posledniho prikazu na pipe.
20.1.2016 15:46 NN
Rozbalit Rozbalit vše Re: Escape znaku v prikazu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Bez toho eval by to neslo?
20.1.2016 21:42 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Escape znaku v prikazu
Odpovědět | | Sbalit | Link | Blokovat | Admin

Ty nepárové uvozovky jsou nějaký záměr?

"$_RUNJAVA\""

V originále jsou párové:

"\"$_RUNJAVA\""

Taky asi místo…

... "$CATALINA_PID"\) ...

…by tam mělo být…

... "$CATALINA_PID"\;\) ...

…protože subshell musí končit středníkem nebo ampersandem.

Navíc mi není jasné, proč je tam tak špatně čitelný eval jenom kvůli dvojí expanzi "$@" a pár dalších proměnných. Chci-li dvojitě expandovat některé proměnné, mohlo by to jít třeba takto:

( "$_RUNJAVA" "$LOGGING_CONFIG" \
  $(echo "$LOGGING_MANAGER" "$JAVA_OPTS" "$CATALINA_OPTS") \
  -Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" \
  -classpath "$CLASSPATH" \
  -Dcatalina.base="$CATALINA_BASE" \
  -Dcatalina.home="$CATALINA_HOME" \
  -Djava.io.tmpdir="$CATALINA_TMPDIR" \
  org.apache.catalina.startup.Bootstrap $(echo "$@") start 2>&1 & \
  [ -n "$CATALINA_PID" ] && echo $! > "$CATALINA_PID" ; ) \
| tee -a "$CATALINA_OUT" | "$RSYSLOG" &

Určitě tam mám pár (desítek) překlepů, když to střílím takhle od boku, ale v principu by to fungovat mohlo. Možná tam taky budou nějaké drobné nuance, ale ty už je potřeba vyhodnotit až s konkrétními parametry ("$@") a proměnnými. Například odstraněním uvozovek kolem "$JAVA_OPTS" se dá zajistit ještě další krok expanze, je-li třeba.

Soudě podle názvů proměnných, není náhodou cílem, aby soubor $CATALINA_OUT obsahoval jenom stdout, zatímco $RSYSLOG má dostávat na vstup oba výstupy smíchané? To by pak bylo nějak takhle:

mkfifo catalina_stderr
( "$_RUNJAVA" ... start 2>catalina_stderr & \
  [ -n "$CATALINA_PID" ] && echo $! > "$CATALINA_PID" ; ) \
| ( tee -a "$CATALINA_OUT" & cat catalina_stderr & ) \
| "$RSYSLOG" &

Chyby, které vzniknou

20.1.2016 21:48 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Escape znaku v prikazu

…Chyby, které vzniknou při neúspěšném pokusu zapsat do "$CATALINA_PID", by se mohly taky nějak zvlášť ošetřit, mají-li se logovat a nemají-li se míchat do streamů od toho Tomcatu nebo co to je. Tedy buď poslat do /dev/null nebo do nějakého extra logu atd. atp. Nebo předpokládat, že se zápis vždycky podaří. ;-) Záleží na tom, jak moc univerzální a neprůstřelné to má být.

20.1.2016 23:59 lmlmlm
Rozbalit Rozbalit vše Re: Escape znaku v prikazu
Díky za rady, popravdě řečeno, do catalina.out chci všechny proudy, to samé platí pro $RSYSLOG, který by měl být odrazem. Celé se to ještě zítra zamotá, až do toho přimíchám rotatelogs, kvůli rotaci, která prostě v základu není, ale to asi předbíhám, musím to vyzkoušet.

Snad takto
rm -rf "$CATALINA_OUT"
mkfifo "$CATALINA_OUT"
nohup /usr/sbin/rotatelogs -f "$CATALINA_BASE"/logs/console.%Y.%m.%d.log 86400 > /dev/null 2>&1  < "$CATALINA_OUT" &

( "$_RUNJAVA" "$LOGGING_CONFIG" \
  $(echo "$LOGGING_MANAGER" "$JAVA_OPTS" "$CATALINA_OPTS") \
  -Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" \
  -classpath "$CLASSPATH" \
  -Dcatalina.base="$CATALINA_BASE" \
  -Dcatalina.home="$CATALINA_HOME" \
  -Djava.io.tmpdir="$CATALINA_TMPDIR" \
  org.apache.catalina.startup.Bootstrap $(echo "$@") start 2>&1 & \
  [ -n "$CATALINA_PID" ] && echo $! > "$CATALINA_PID" ; ) \
| tee -a "$CATALINA_OUT" | "$RSYSLOG" &

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.