खोज…


परिचय

शेल अपने प्रॉम्प्ट के जवाब में एक प्रोग्राम निष्पादित करता है। जब आप एक कमांड देते हैं, शेल प्रोग्राम को खोजता है, और फिर इसे निष्पादित करता है। उदाहरण के लिए, जब आप कमांड ls देते हैं, शेल ls नाम की उपयोगिता / प्रोग्राम को खोजता है, और फिर इसे शेल में चलाता है। तर्क और विकल्प जो आप उपयोगिताओं के साथ प्रदान करते हैं, जो आपको प्राप्त परिणाम को प्रभावित कर सकते हैं। शेल को सीएलआई, या कमांड लाइन इंटरफ़ेस के रूप में भी जाना जाता है।

डिफ़ॉल्ट शेल बदलना

अधिकांश आधुनिक वितरण BASH ( B ourne A gain SH ell) के साथ पहले से स्थापित और एक डिफ़ॉल्ट शेल के रूप में कॉन्फ़िगर किए जाएंगे।

आदेश (वास्तव में एक निष्पादन द्विआधारी, एक ELF) कि लिनक्स में गोले को बदलने के लिए जिम्मेदार है chsh (ch Ange ell)।

हम पहले जाँच कर सकते हैं कि chsh -l कमांड का उपयोग करके कौन सी गोले पहले से ही हमारे मशीन पर स्थापित और कॉन्फ़िगर किए गए हैं, जो इस तरह से परिणाम देगा:

[user@localhost ~]$ chsh -l
/bin/sh
/bin/bash
/sbin/nologin
/usr/bin/sh
/usr/bin/bash
/usr/sbin/nologin
/usr/bin/fish

कुछ लिनक्स वितरण में, chsh -l अमान्य है। इस स्थिति में, सभी उपलब्ध गोले की सूची / etc / गोले फ़ाइल में पाई जा सकती है। आप cat साथ फ़ाइल सामग्री दिखा सकते हैं:

[user@localhost ~]$ cat /etc/shells
# /etc/shells: valid login shells
/bin/sh
/bin/bash
/sbin/nologin
/usr/bin/sh
/usr/bin/bash
/usr/sbin/nologin
/usr/bin/fish

अब हम अपना नया डिफॉल्ट शेल चुन सकते हैं, जैसे fish , और chsh -s का उपयोग करके इसे कॉन्फ़िगर करें,

[user@localhost ~]$ chsh -s /usr/bin/fish
Changing shell for user.
Password: 
Shell changed.

अब जो कुछ करना बाकी है, वह एक लॉगऑफ-लॉगऑन चक्र से पहले है, और हमारे नए डिफ़ॉल्ट शेल का आनंद लें।

यदि आप एक अलग उपयोगकर्ता के लिए डिफ़ॉल्ट शेल बदलना चाहते हैं, और आपके पास मशीन पर प्रशासनिक विशेषाधिकार हैं, तो आप इसे chsh को root रूप में उपयोग करके पूरा कर पाएंगे। इसलिए यह मानते हुए कि हम user_2 के डिफ़ॉल्ट शेल को मछली में बदलना चाहते हैं, हम पहले की तरह ही कमांड का उपयोग करेंगे, लेकिन दूसरे उपयोगकर्ता के उपयोगकर्ता नाम, chsh -s /usr/bin/fish user_2

वर्तमान डिफ़ॉल्ट शेल क्या है, यह जांचने के लिए, हम $SHELL पर्यावरण चर को देख सकते हैं, जो हमारे डिफ़ॉल्ट शेल के पथ को इंगित करता है, इसलिए हमारे परिवर्तन के बाद, हम इसके समान परिणाम प्राप्त करने की उम्मीद करेंगे,

 ~  echo $SHELL                                 
/usr/bin/fish

chsh विकल्प:

-s shell

शेल को लॉगिन शेल के रूप में सेट करता है।

-l , --list-shells

/ Etc / गोले और निकास में सूचीबद्ध गोले की सूची प्रिंट करें।

-h , --help

एक उपयोग संदेश प्रिंट करें और बाहर निकलें।

-v , - --version

संस्करण की जानकारी प्रिंट करें और बाहर निकलें।

मूल शैल उपयोगिताएँ


शेल प्रॉम्प्ट को अनुकूलित करना

डिफॉल्ट कमांड प्रॉम्प्ट को अलग और छोटा दिखने के लिए बदला जा सकता है। यदि वर्तमान निर्देशिका लंबी डिफ़ॉल्ट है तो कमांड प्रॉम्प्ट बहुत बड़ा हो जाता है। PS1 का उपयोग इन मामलों में उपयोगी हो जाता है। एक छोटी और अनुकूलित कमांड सुंदर और सुरुचिपूर्ण। शेल प्रांप्ट के विभिन्न रूपों को दिखाने के लिए PS1 नीचे तालिका में कई तर्कों का उपयोग किया गया है। डिफ़ॉल्ट कमांड प्रॉम्प्ट कुछ इस तरह दिखता है: user@host ~ $ मेरे मामले में यह इस तरह दिखता है: bruce@gotham ~ $ । इसे नीचे दी गई तालिका के अनुसार बदला जा सकता है:

आदेश उपयोगिता
PS1 = '\ w $' निर्देशिका नाम के रूप में ~ $ शेल प्रॉम्प्ट। इस मामले में रूट डायरेक्टरी रूट है।
PS1 = '\ h $' होस्टनाम के रूप में gotham $ शेल प्रॉम्प्ट
PS1 = '\ u $' उपयोगकर्ता नाम के रूप में bruce $ शैल शीघ्र bruce $
PS1 = '\ t $' 24 घंटे के प्रारूप में 22:37:31 $ शैल शीघ्र
PS1 = '@ $' 10:37 PM 12 घंटे के समय के प्रारूप में 10:37 PM
PS1 = '! $ ' 732 शेल प्रॉम्प्ट के स्थान पर कमांड का इतिहास नंबर दिखाएगा
PS1 = 'दोस्त $' dude $ खोल दिखाएगा जिस तरह से आप की तरह

कुछ बुनियादी शेल कमांड

आदेश उपयोगिता
Ctrl-k कटौती / मार
Ctrl-y झटका / पेस्ट
Ctrl-a लाइन की शुरुआत में कर्सर ले जाएगा
Ctrl-e लाइन के अंत में कर्सर ले जाएगा
Ctrl-d कर्सर पर / के बाद वर्ण हटा देगा
Ctrl-l स्क्रीन / टर्मिनल को साफ़ करेगा
Ctrl-u शीघ्र और कर्सर के बीच सब कुछ साफ हो जाएगा
Ctrl-_ कमांड लाइन पर टाइप की गई अंतिम चीज को पूर्ववत कर देगा
Ctrl-c अग्रभूमि में चल रही नौकरी / प्रक्रिया को बाधित / रोक देगा
Ctrl-r इतिहास में रिवर्स खोज
~/.bash_history शेल पर उपयोग की जाने वाली अंतिम 500 कमांड / ईवेंट
history कमांड इतिहास दिखाएगा
history | grep <key-word> इतिहास में सभी कमांड दिखाएंगे जिनमें कीवर्ड <की-वर्ड> (उन मामलों में उपयोगी होगा जब आप अतीत में उपयोग किए गए कमांड का हिस्सा याद करते हैं)

अपनी खुद की कमान उपनाम बनाएँ

यदि आप bash में लंबे कमांड का उपयोग करके थक गए हैं तो आप अपना खुद का कमांड उपनाम बना सकते हैं।

ऐसा करने का सबसे अच्छा तरीका आपके घर के फ़ोल्डर में .bash_aliases नामक फ़ाइल को संशोधित करना (या मौजूद नहीं है) बनाना है। सामान्य वाक्यविन्यास है:

alias command_alias='actual_command'

जहां actual_command वह कमांड है जिसका आप नाम बदल रहे हैं और command_alias नया नाम है जिसे आपने दिया है। उदाहरण के लिए

alias install='sudo apt-get -y install'

नक्शे नया आदेश उर्फ install वास्तविक आदेश को sudo apt-get -y install । इसका मतलब यह है कि जब आप किसी टर्मिनल में इंस्टॉल का उपयोग करते हैं, तो इसे सस्पो एप्ट-गेट-इंस्टॉल के रूप में बश किया जाता है।

अपने सिस्टम पर एक फ़ाइल का पता लगाएँ

साथ पार्टी का उपयोग आप आसानी से एक फ़ाइल को ढूँढ सकते हैं locate आदेश। उदाहरण के लिए, आप फ़ाइल mykey.pem की तलाश कर रहे हैं:

locate mykey.pem

कभी-कभी फ़ाइलों में अजीब नाम होते हैं उदाहरण के लिए आपके पास random7897_mykey_0fidw.pem जैसी फ़ाइल हो सकती है। मान लीजिए कि आप इस फ़ाइल को ढूंढ रहे हैं, लेकिन आपको केवल mykey और pem भागों की याद है। आप इस तरह से एक पाइप का उपयोग करके grep साथ locate कमांड को जोड़ सकते हैं:

locate pem | grep mykey

जो सभी परिणामों को सामने लाएगा जिसमें ये दोनों टुकड़े होंगे।

ध्यान दें कि सभी प्रणालियों में locate उपयोगिता नहीं है, और कई जो इसे सक्षम नहीं करते हैं। locate तेज़ और कुशल है क्योंकि यह समय-समय पर आपके सिस्टम को स्कैन करता है और उस पर हर फ़ाइल के नाम और स्थानों को कैश करता है, लेकिन यदि वह डेटा संग्रह सक्षम नहीं है, तो यह आपको कुछ भी नहीं बता सकता है। आप अपने फाइल सिस्टम पर फाइलों के बारे में कैश्ड जानकारी को अपडेट करने के लिए फाइलसिस्टम स्कैन को मैन्युअल रूप से शुरू करने के लिए updatedb का उपयोग कर सकते हैं।

क्या आपके पास काम का locate नहीं होना चाहिए, आप find उपयोगिता पर वापस गिर सकते find :

find / -name mykey.pem -print

मोटे तौर पर locate mykey.pem का locate mykey.pem बराबर है, लेकिन आपके फ़ाइल सिस्टम को स्कैन करने के लिए प्रत्येक बार जब आप इसे फ़ाइल के लिए चलाते हैं, तो कैश्ड डेटा का उपयोग करने के बजाय। यह स्पष्ट रूप से धीमा और कम कुशल है, लेकिन अधिक वास्तविक समय है। find उपयोगिता फाइलों को खोजने की तुलना में बहुत अधिक कर सकती है, लेकिन इसकी क्षमताओं का पूरा विवरण इस उदाहरण के दायरे से परे है।



Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow