Ssh लॉगिन करने के बाद एक फाइल को प्रॉम्प्ट के लिए ड्रॉप करें
एक-लाइनर प्रश्न: मैं एसएसएच के माध्यम से एक गढ़ होस्ट के माध्यम से लॉग इन करने के बाद दूरस्थ होस्ट पर दूरस्थ फ़ाइल को स्वचालित रूप से कैसे दर्ज करूं?
मुझे एक फाइल रखने की आवश्यकता है जिसमें उपनाम + शेल उपयोगकर्ता परिभाषित कार्यों की सूची हो, जो ssh-ing के बाद एक दूरस्थ होस्ट पर कार्य करता है।
फ़ाइल दूरस्थ मेकिंग में / tmp फ़ोल्डर जैसे / tmp / my-rc पर मौजूद है
अन्य पोस्ट और इंटरनेट की खोज मैंने पाया है
ssh -t [email protected] 'source /tmp/my-rc; bash -l'
समस्या यह है कि मुझे एक टर्मिनल मिलता है, लेकिन कोई भी अलाइंस सेट नहीं है क्योंकि यह एक नया बैश शेल है '
यह सोचकर कि शेल संलग्न होने के बाद स्रोत किया जाना चाहिए, नीचे की कोशिश की गई लेकिन यह भी काम नहीं करता है। कोई त्रुटि नहीं है, मुझे टर्मिनल मिला है, लेकिन यह मत सोचो कि फाइल खट्टी हो गई है (/ tmp / my-rc फाइल से डमी संदेश गूंज कर सत्यापित)
ssh -t [email protected] 'bash -l; source /tmp/my-rc'
यहां तक कि 'के साथ' की कोशिश की। स्रोत के बजाय, कोई भाग्य नहीं।
कोई मदद।
Note1: बैश या ZSH किसी भी शेल समाधान करना होगा।
नोट 2: एक्टुएल एसएचएस एक प्रॉक्सी कमांड के माध्यम से है, जो कि गढ़ होस्ट पर एक हॉप है (बस इसका उल्लेख है कि यह उस पर निर्भर है)
Note3: मेरे पास एक प्रोफ़ाइल rc या bashrc या दूरस्थ होस्ट पर एक होम डायरेक्टरी का भी निजीकरण नहीं है।
नोट 4: जिस सटीक कमांड को मैंने सुरक्षित होस्ट में लॉगिन करने के लिए इस्तेमाल किया था, वह नीचे दिए गए गढ़ के माध्यम से है
ssh -o ProxyCommand='ssh -W %h:%p ec2-3-218-12-120.compute-1.amazonaws.com' 10.0.31.122
जवाब
के साथ bash
, आप कर सकते हैं:
ssh -t user@host '
PROMPT_COMMAND="source /tmp/my-rc
unset PROMPT_COMMAND
" exec bash --norc'
जिसके कारण /tmp/my-rc
संकेत से पहले ही खटास पैदा हो जाएगी, और केवल उस संकेत के बाद से हम परेशान हैं PROMPT_COMMAND
।
आप इसे वास्तव में परिभाषित करते हुए समाप्त करना चाहते हैं unset PROMPT_COMMAND
तो निकालना चाहते हैं /tmp/my-rc
।
उपर्युक्त दूरस्थ उपयोगकर्ता के लॉगिन शेल का बॉर्न जैसा है, लेकिन आपको इसे अन्य प्रकार के गोले (csh / rc / fish) के अनुकूल बनाना चाहिए।
यह देखते हुए कि आप दूरस्थ होस्ट के लिए लिख /tmp
सकते हैं, आप /tmp/myhome
उस पर एक निर्देशिका बना सकते हैं , अपने गोले की प्रोफाइल और आरंभिक फ़ाइलों को वहां रख सकते हैं और फिर ZDOTIDR
सेट के साथ Zash /tmp/myhome
और HOME
सेट के साथ बैश शुरू कर सकते हैं /tmp/myhome
।
डिफ़ॉल्ट रूप से, Zsh सेट नहीं है $ZDOTDIR
, $HOME
तो डिफ़ॉल्ट रूप से अपनी आरंभिक फ़ाइलों की खोज करता है ZDOTDIR
।
इसलिए, आप दूरस्थ मेजबान पर Zsh शुरू कर सकते हैं:
ssh -t user@host ZDOTDIR=/tmp/myhome zsh
और बैश के रूप में:
ssh -t user@host HOME=/tmp/myhome bash
बेशक आप अपनी प्रोफ़ाइल / आरंभीकरण फ़ाइलों के साथ रचनात्मक हो सकते हैं - जैसे कि उनका उपयोग HOME
अधिक उपयुक्त पथ, स्रोत की अन्य फ़ाइलों (यदि आपके पास पहले से ही दूरस्थ होस्ट पर कहीं-कहीं डॉट-फ़ाइलें हुआ है) आदि के लिए सेट करने के लिए करें।
इस दृष्टिकोण का एक न्यूनतम अनुप्रयोग, एक कमांड में संघनित हो सकता है:
ssh -t user@host 'mkdir /tmp/myhome
echo ". /tmp/my-rc" >/tmp/myhome/.bashrc
HOME=/tmp/myhome bash'
( पहले से मौजूद mkdir -p ...
होने पर दिखाई देने वाली किसी त्रुटि को रोकने के लिए उपयोग करें /tmp/myhome
, जैसे कि यदि आप दूरस्थ होस्ट से पुन: कनेक्ट हो रहे हैं और आपको पहले से ही पता है कि निर्देशिका मौजूद है)।
अपने ProxyCommand
खाते में लेना , यह हो सकता है:
ssh -t -o ProxyCommand='ssh -W \
%h:%p ec2-3-218-12-120.compute-1.amazonaws.com' \
10.0.31.122 \
'mkdir /tmp/myhome
echo ". /tmp/my-rc" >/tmp/myhome/.bashrc
HOME=/tmp/myhome bash'
अंत में, आपके प्रयासों के बारे में: ssh -t [email protected] 'bash -l; source /tmp/my-rc'
काम नहीं कर रहा है क्योंकि source
कमांड केवल इंटरैक्टिव शेल से बाहर निकलने के बाद निष्पादित होता है।
यदि UsePAM को दूरस्थ होस्ट की sshd_config फ़ाइल में हां करने के लिए सेट किया गया है , तो फ़ाइल /etc/pam.d/sshd को कॉन्फ़िगर करें आपको प्रमाणीकरण प्रक्रिया में अन्य घटनाओं के बीच सफल लॉगिन पर कमांड निष्पादन को स्वचालित करने की अनुमति देता है। इस कोड की लाइन जोड़ें
session required pam_exec.so /etc/myscripts/./sourcing-script
सीधे इन लाइनों के ऊपर
# SELinux needs to intervene at login time to ensure that the process starts
# in the proper default security context. Only sessions which are intended
# to run in the user's context should be run after this.
session [success=ok ignore=ignore module_unknown=ignore default=bad] pam_selinux.so open
जहां / आदि / myscripts / सोर्सिंग-स्क्रिप्ट बस सफल लॉगिन पर निष्पादित करने के लिए कमांड के साथ रिमोट होस्ट पर एक फ़ाइल है।
#!/bin/bash
source /tmp/my-rc
#echo $(date) >> /etc/myscripts/sourcing-script.log
#cat /tmp/my-rc >> /etc/myscripts/sourcing-script.log
मैं इस विधि का उपयोग किसी सेवा को रोकने और लॉग फ़ाइल में रिपोर्ट करने के लिए करता हूं, इससे पहले कि मेरा ssh सत्र खोला जाए। इससे पहले कि मैं लॉग आउट करता हूं मैंने सेवा शुरू करने के लिए एक क्रेस्टैब सेट किया है, इसलिए यह मेरे ssh सत्र के समानांतर कभी नहीं चलता है।
आमतौर पर आप ऐसा $HOME/.profile
या वेरिएंट में करते हैं।
ssh
वातावरण चर सेट करना शुरू कर देता है SSH_
, आप यह निर्धारित करने के लिए उपयोग कर सकते हैं कि आपने लॉग इन किया है ssh
या सीधे।