एससीपी तब काम नहीं करता है जब ईको।


81

फेडोरा में मेरे दो उपयोगकर्ता हैं:

  1. वाणी
  2. जड़ (काफी स्पष्ट!)

उपयोगकर्ता Wani की .bashrc की मेरी सामग्री हैं:

# .bashrc
echo "Hello"
# Source global definitions
if [ -f /etc/bashrc ]; then
    . /etc/bashrc
fi

# User specific aliases and functions

अब रूट में लॉग इन करने के बाद, मैं निम्नलिखित कमांड टाइप करता हूं:

[root@Dell Wani]# touch try.txt
[root@Dell Wani]# service sshd start
[root@Dell Wani]# scp try.txt Wani@localhost:~/
Wani@localhost's password: 
Hello
[root@Dell Wani]# 

अब मैं वानी में प्रवेश करता हूं, और टाइप करता हूं:

[Wani@Dell ~]$ cat try.txt
cat: try.txt: No such file or directory
[Wani@Dell ~]$ 

अब मैं फिर से रूट में लॉग इन करता हूं और उसी कमांड को टाइप करता हूं -v:

[root@Dell Wani]# scp -v morph.log Wani@localhost:
Executing: program /usr/bin/ssh host localhost, user Wani, command scp -v -t -- .
OpenSSH_5.6p1, OpenSSL 1.0.0j-fips 10 May 2012
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: Applying options for *
debug1: Connecting to localhost [127.0.0.1] port 22.
debug1: Connection established.
debug1: permanently_set_uid: 0/0
debug1: identity file /root/.ssh/id_rsa type -1
debug1: identity file /root/.ssh/id_rsa-cert type -1
debug1: identity file /root/.ssh/id_dsa type -1
debug1: identity file /root/.ssh/id_dsa-cert type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.6
debug1: match: OpenSSH_5.6 pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.6
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug1: Host 'localhost' is known and matches the RSA host key.
debug1: Found key in /root/.ssh/known_hosts:2
debug1: ssh_rsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: Roaming not allowed by server
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey,gssapi-keyex,gssapi-     with-mic,password
debug1: Next authentication method: gssapi-keyex
debug1: No valid Key exchange context
debug1: Next authentication method: gssapi-with-mic
debug1: Unspecified GSS failure.  Minor code may provide more information
Credentials cache file '/tmp/krb5cc_0' not found

debug1: Unspecified GSS failure.  Minor code may provide more information
Credentials cache file '/tmp/krb5cc_0' not found

debug1: Unspecified GSS failure.  Minor code may provide more information


debug1: Unspecified GSS failure.  Minor code may provide more information


debug1: Next authentication method: publickey
debug1: Trying private key: /root/.ssh/id_rsa
debug1: Trying private key: /root/.ssh/id_dsa
debug1: Next authentication method: password
Wani@localhost's password: 
debug1: Authentication succeeded (password).
Authenticated to localhost ([127.0.0.1]:22).
debug1: channel 0: new [client-session]
debug1: Requesting no-more-sessions@openssh.com
debug1: Entering interactive session.
debug1: Sending environment.
debug1: Sending env XMODIFIERS = @im=none
debug1: Sending env LANG = en_US.UTF-8
debug1: Sending command: scp -v -t -- .
Hello
[root@Dell Wani]# debug1: client_input_channel_req: channel 0 rtype exit-status      reply      0
debug1: channel 0: free: client-session, nchannels 1
debug1: fd 0 clearing O_NONBLOCK
debug1: fd 1 clearing O_NONBLOCK
Transferred: sent 1664, received 1976 bytes, in 0.1 seconds
Bytes per second: sent 22961.5, received 27266.8
debug1: Exit status 0

(और एंटर करने के बाद)

[root@Dell Wani]# 

किसी को भी कृपया कुछ प्रकाश डाला जा सकता है कि वास्तव में यहाँ क्या हुआ? फाइल को रूट से वानी में कॉपी क्यों नहीं किया गया?


किस बारे में cp? cp try.txt ~Wani/काम करता है ?
nnonneo

यह वास्तव में संभव है कि आपके से इंटरेक्टिव कमांड या स्प्रूसियस आउटपुट .bashrcकुछ गैर-सक्रिय परिदृश्यों को बर्बाद कर सकते हैं। कोड को case $- in *i*ऐसे या कुछ पर सशर्त बनाने का प्रयास करें ।
ट्रिपल

@nneonneo: यह काम करता है। वास्तव में, भले ही मेरे पास अलग-अलग कंप्यूटरों पर दो उपयोगकर्ता हैं, फ़ाइल की नकल नहीं होती है!
नेहल जे वानी

1
सभी पोस्ट मैंने देखा है कि यह समस्या विभिन्न bashrc फ़ाइलों आदि में मौजूद क्यों है, हालांकि, जब SCP / STFP एक मशीन में आप नहीं करते हैं और स्टार्टअप स्क्रिप्ट को बदल नहीं सकते हैं, तो समाधान क्या है ???
23

मैंने स्टेकर के लिए सभी इको को रीडायरेक्ट किया। काम करता है, लेकिन ...
एंड्रियास

जवाबों:


78

echoएक .bashrcविल ब्रेक का उपयोग करना scp, जैसा scpकि स्टड / स्टडआउट चैनलों पर इसके प्रोटोकॉल डेटा को देखने की उम्मीद है। Https://bugzilla.redhat.com/show_bug.cgi?id=20527 देखेंइस मुद्दे पर अधिक चर्चा के लिए ।

कुछ वर्कअराउंड उपलब्ध हैं:

  • 'इंटरएक्टिव' ध्वज पर स्थिति (उदाहरण के लिए case $- in *i*ट्रिपल द्वारा सुझाई गई)
  • ttyएक इंटरैक्टिव शेल (जैसे if tty > /dev/nullया if [ -t 0 ]) का पता लगाने के लिए उपयोगिता का उपयोग करें
  • के मूल्य की जाँच करें $SSH_TTY

मुझे लगता है कि आपको आपके लिए जो भी काम करना चाहिए, वह करना चाहिए। मुझे नहीं पता कि सबसे अच्छा (सबसे पोर्टेबल / सबसे विश्वसनीय) विकल्प क्या है, दुर्भाग्य से।


6
"केस" कमांड को स्पष्ट करने के लिए बस यही होगा:case $- in *i*) echo This is safe since the shell is interactive; esac
mlathe

shoptयह भी एक विकल्प है
vesperto

1
चूँकि मेरा होस्ट हमेशा SSH से अधिक होता है, SSH_TTY हमेशा सेट रहता है। -t 0शर्त का उपयोग करना मेरे लिए अच्छी तरह से काम किया। मैं अब अपने bashrc पर निम्नलिखित फ़ंक्शन का उपयोग करता हूं। safe_echo() { if [[ -t 0 ]];then echo -e "$*" fi }
संदीप भट्टाचार्य

if [[ "$SSH_TTY" == */dev/pts/* ]] ; thenअंदर अगर अपनी सामग्री डालें जो प्रिंटआउट को प्रिंट करती है, तो एसपीपी ठीक काम करेगा।
बीटिंगबाइट्स

@BeatingBytes & @Sandip भट्टाचार्य, [[पोर्टेबल नहीं है और मुझे भी नहीं लगता कि यह सकारात्मक है। dashशेल में यह प्रयास करें if [[ 0 = 0 ]]; then echo x; else echo y; fi:। तुम्हें पता है, मिलता है dash: 3: [[: not found
अण्डाकार दृश्य 16

19

Nneonneo के विकल्पों में जोड़ने के लिए, आप इंटरेक्टिव झंडे के साथ भी शर्त लगा सकते हैं

if [[ $- =~ "i" ]]

जो मुझे लगता है कि संभवतः बैश में सबसे स्पष्ट तरीका है।


[[पोर्टेबल नहीं है और मुझे भी नहीं लगता कि यह सकारात्मक है। dashशेल में यह प्रयास करें if [[ 0 = 0 ]]; then echo x; else echo y; fi:। तुम्हें पता है, मिलता है dash: 3: [[: not found
अण्डाकार दृश्य 10


11

डिफ़ॉल्ट उबंटू .bashrcनिम्नलिखित स्निपेट जो पहले से ही समस्या का ख्याल रखता है शामिल हैं:

# If not running interactively, don't do anything
case $- in
    *i*) ;;
    *) return;;
esac

4
छोटा:[[ $- != *i* ]] && return
phil294

2
आपके उत्तर में प्रदान किया गया प्रपत्र POSIX संगत है। [[सुविधा के उपयोग के कारण आप अपनी टिप्पणी में जो पेशकश करते हैं वह POSIX नहीं है । एक bashrc फ़ाइल के लिए इतना समस्याग्रस्त नहीं;) लेकिन आप इसे किसी अन्य संदर्भ / शेल में उपयोग करने में सक्षम होना चाहते हैं।
टॉरट

4

इसके .bashrcबजाय, आउटपुट के रूप में STDERR का उपयोग करें:

echo "# Important Notice" >&2

अद्यतन: इसका उपयोग न करें! हमारे पास हाल ही में एक मुद्दा था कि एक (बंद स्रोत) उपकरण echoएसटीडीआरआर के कारण विफल हो गया .bashrc। टूल (उपयोग rcp) से न तो किसी आउटपुट की उम्मीद थी, न ही STDOUT पर और न ही STDERR पर। और यह गूंजते ही अटक गया। सबक सीखा: मनुष्यों के लिए और मशीनों (लिपियों) के लिए अलग-अलग खाते बनाएं, या बस के माध्यम से झुनझुना बंद करो .bashrc


"मनुष्यों के लिए और मशीनों के लिए अलग-अलग खाते बनाएं" अंडररेटेड है।
एंड्रियास

1

एक इंटरैक्टिव शेल के लिए परीक्षण का सबसे पोर्टेबल तरीका प्रतीत होता है:

test -t 0
if [ $? -eq 0 ]
then
    # interactive
    ;
else
    # non-interactive
    ;
fi

0

nneonneo के समाधान ने मेरे लिए भी काम किया। लेकिन चूंकि मेरा डिफ़ॉल्ट शेल TCSH है, इसलिए मुझे इस प्रकार (.tcshrc) के रूप में फिक्स को थोड़ा संपादित करना पड़ा।

if ( $?SSH_TTY ) then
    exec /bin/bash
endif

बस सोचा था कि मैं सभी के लाभ के लिए साझा करूंगा।


0

यदि आप Red Hat Enterprise Linux (आरएचईएल) या संस्करण पर हैं, तो एक स्क्रिप्ट को ड्रॉप करें echo, या जो कुछ भी आप चाहते हैं, उसे /etc/profile.d/ में दें


0

यदि आप इको स्टेटमेंट्स के साथ-साथ @ ब्लाउहिरन के उत्तर भी चाहते हैं, तो आप केस की स्थिति के बाद अपना इको स्टेटमेंट रख सकते हैं।

case $- in
    *i*) ;;
    *) return;;
esac

echo "Your Greeting/Warning Message/s here!"

-1
if [ 0 -eq $(shopt -q login_shell; echo $?) ]; then
  echo "do something?"
fi

स्रोत


ओपी के लिए कुछ संदर्भ प्रदान करना अच्छा होगा।
२१

संदर्भ और प्रासंगिक जानकारी पहले से ही अन्य उत्तरों और प्रश्न से ही निकाली जा सकती है। यह कम सिग्नल-टू-शोर अनुपात के साथ, जो पहले से समझा जा रहा है, करने का एक और तरीका है।
vesperto
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.