পাইপ stderr এবং বিভিন্ন কমান্ড stdout (শুধুমাত্র ফাইল না)


11

আমি ldap এর জন্য একটি ব্যাকআপ স্ক্রিপ্ট তৈরি করছি। আমি ত্রুটিগুলি / ভার / লগের কোনও ফাইলে যেতে এবং আউটপুটটিকে ব্যাকআপ ফোল্ডারে অন্য কোনও ফাইলে যেতে চাই। বর্তমানে আমি একটি টেম্প ফাইলটিতে পুনর্নির্দেশ করছি এবং তারপরে লগটিতে টেম্পল ফাইলটি প্রেরণ করছি। আমি বরং এটি 1 টি লাইনারের মতো করতাম ...

/usr/bin/ldapsearch -x -LLL -b "dc=contoso,dc=com" "(objectclass=*)" -h ldap.server -v 2>>/tmp/ldaptmp.err |
  gzip -c > /mnt/backups/ldap/`date +\%Y\%m\%d`.ldif.gz || 
  logger -t ldapbackup -p local6.err error exit $?

cat /tmp/ldaptmp.err | grep -v "ldap_initialize( ldap://ldap.server )" | 
  grep -v "filter: (objectclass=\*)" |
  grep -v "requesting: All userApplication attributes" >$ERR_LOG
rm -f /tmp/ldaptmp.err

এই কমান্ডটি 1 লাইনকে ঘনীভূত করার জন্য কীভাবে stderr এবং stdout কে বিভিন্ন পাইপগুলিতে পুনঃনির্দেশ করবেন? নাকি এর চেয়ে ভাল উপায় আছে?


1
: এই বিক্ষোভের কটাক্ষপাত stackoverflow.com/a/16283739/1765658 : অথবা অন্য অর্থ নমুনা unix.stackexchange.com/a/84012/27653
এফ Hauri

উত্তর:


10

ইউনিক্স এসই-এ এই উত্তর দ্বারা নির্দেশিত :

MyWeirdCommand.sh

#!/bin/bash
echo "1 2   3"
echo "4 5   6" >&2

testRedirection.sh:

#!/bin/bash
(./MyWeirdCommand.sh | cut -f1 >stdout.log) 3>&1 1>&2 2>&3 | cut -f3 >stderr.log

চলমান ফলন:

  • stderr.log 6

  • stdout.log 1


24

বাশে, আপনি অতিরিক্ত ফাইল বর্ণনাকারী পরিচালনা করতে প্রক্রিয়া বিকল্প ব্যবহার করতে পারেন। ফাইল বর্ণনাকারী অদলবদলের পদ্ধতির চেয়ে আপনি এটি দেখতে আরও সুন্দর দেখতে পারেন।

command > >(process_stdout) 2> >(process_stderr)

আপনার কমান্ডটি এর মতো দেখতে পারে:

/usr/bin/ldapsearch -x -LLL -b "dc=contoso,dc=com" "(objectclass=*)" -h ldap.server -v \
  > >( \
    gzip -c > /mnt/backups/ldap/$(date '+%Y%m%d').ldif.gz || 
    logger -t ldapbackup -p local6.err error exit $?
  ) \
  2> >( \
    grep -Ev "ldap_initialize( ldap://ldap.server )|filter: (objectclass=\*)|requesting: All userApplication attributes" > "$err_log" \
  )

1
এটা সঠিক উত্তর.
মাইকেল মার্টিনেজ

আপনি যদি কোনও ফাইলে পুনর্নির্দেশের পরিবর্তে চেইনটি রাখতে চান তবে আপনি আউটপুটটিকে স্ট্যাডারে ফিরে যেতে চাইবেন, এরকম কিছু: sh f>> (sed -e "s / ^ / stdout: /") 2>> ( sed -e "s / ^ / stderr: /"> & 2)
জেমস মুর

>(process)স্বরলিপিটির প্রযুক্তিগত নাম কী ?
jchook

1
@ জেচুক আমি এই শব্দটি প্রথম বাক্যে ব্যবহার করি: "প্রক্রিয়া প্রতিস্থাপন"।
পরবর্তী বিজ্ঞপ্তি না দেওয়া পর্যন্ত বিরতি দেওয়া হয়েছে।

1

টাইমস্ট্যাম্পগুলির সাথে ফাইলগুলি পৃথক করার জন্য আমি এইভাবে stdout এবং stderr মুদ্রণ করি (ডেবিয়ান মোরটিলস প্যাকেজ থেকে টিএস-তে পাইপিং করা):

(./my_little_script.pl | ts %F\ %T > out.log) 2>&1 | ts > err.log

পিএস যদি আপনার টিএস না থাকে তবে আপনার নিজস্ব এলিফ তৈরি করুন:

alias ts='while IFS= read -r line; do printf "%s %s\n" "$(date +%F\ %T)" "$line"; done'
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.