क्या उपयोगी चीजें एक व्यक्ति को जोड़ सकती हैं? [बन्द है]


141

क्या कोई ऐसी चीज है जिसके बिना आप नहीं रह सकते और मेरे जीवन को इतना आसान बना देगा? यहाँ कुछ हैं जो मैं उपयोग करता हूं ('डिस्कस्पेस' और 'फ़ोल्डर्स' विशेष रूप से उपयोगी हैं)।

# some more ls aliases
alias ll='ls -alh'
alias la='ls -A'
alias l='ls -CFlh'
alias woo='fortune'
alias lsd="ls -alF | grep /$"

# This is GOLD for finding out what is taking so much space on your drives!
alias diskspace="du -S | sort -n -r |more"

# Command line mplayer movie watching for the win.
alias mp="mplayer -fs"

# Show me the size (sorted) of only the folders in this directory
alias folders="find . -maxdepth 1 -type d -print | xargs du -sk | sort -rn"

# This will keep you sane when you're about to smash the keyboard again.
alias frak="fortune"

# This is where you put your hand rolled scripts (remember to chmod them)
PATH="$HOME/bin:$PATH"

3
यह सामुदायिक विकि होना चाहिए
टोरो

1
सामुदायिक विकि में बदल गया। का आनंद लें।
गारेथ

4
अधिक के लिए पाइप किया? मुझे यकीन है कि आप कम या कम के साथ खुश होंगे -F
derobert

सिवाय इसके कि वहाँ "सॉर्ट" अधिक से पहले है, चूंकि सॉर्ट को पूर्ण इनपुट की आवश्यकता है, कम -F बस आपको सॉर्टिंग को तेजी से देखने देगा, और मुझे यकीन है कि यह बहुत तेज़ है।
ग्रीनकिवी

1
अगर किसी को दिलचस्पी है, तो एक सेवा है जो आपको ब्राउज़ करने, एक सूची बनाने और अपने उपनामों का स्रोत बनाने की अनुमति देती है: alias.sh
Sam152

जवाबों:


81

मेरे पास एक छोटी स्क्रिप्ट है जो अभिलेखागार को निकालती है, मैंने इसे कहीं नेट पर पाया:

extract () {
   if [ -f $1 ] ; then
       case $1 in
           *.tar.bz2)   tar xvjf $1    ;;
           *.tar.gz)    tar xvzf $1    ;;
           *.bz2)       bunzip2 $1     ;;
           *.rar)       unrar x $1       ;;
           *.gz)        gunzip $1      ;;
           *.tar)       tar xvf $1     ;;
           *.tbz2)      tar xvjf $1    ;;
           *.tgz)       tar xvzf $1    ;;
           *.zip)       unzip $1       ;;
           *.Z)         uncompress $1  ;;
           *.7z)        7z x $1        ;;
           *)           echo "don't know how to extract '$1'..." ;;
       esac
   else
       echo "'$1' is not a valid file!"
   fi
 }

1
अच्छा लगा। फिर भी, वहाँ है कि IDE / विम तर्क के बारे में स्मृति से आदेश पता है। हालांकि स्क्रिप्ट का शानदार सा। निश्चित रूप से .bashrc चीयर्स में जा रहा है!
गारेथ

19
एक अच्छा और सरल लिनक्स कमांड है जिसे "अनप" कहा जाता है, अनपैकर जो ऐसा करता है और अधिक।
सैंडर मारेचल

कमांड में एक लापता सुविधा है। यह 7.org पैकेज को boost.org/doc/libs/1_39_0/more/getting_started/… पर सही ढंग से नहीं खोल सकता है। क्या आप जानते हैं कि समस्या का समाधान कैसे किया जाता है?
लेओ लेपोल्ड हर्ट्ज़ '

7
टार के नए संस्करण स्वचालित रूप से संग्रह प्रकार का पता लगाते हैं, इसलिए सभी समर्थित स्वरूपों को केवल 'टार xvf' द्वारा निकाल सकते हैं।
प्रो। मोरियार्टी

@ सैंडर dtrx उस पर भी बुरा नहीं है। यह सुनिश्चित करता है कि संग्रह अपनी स्वयं की उपनिर्देशिका का अर्क निकाले।
टोबू

39

चूंकि मैं बहुत सारी विभिन्न मशीनों का उपयोग करता हूं, इसलिए मेरा .bashrcकमांड कमांड प्रॉम्प्ट को शामिल करने के लिए सेट करता है, अन्य चीजों के अलावा, सर्वर का नाम जो मैं वर्तमान में लॉग इन हूं। इस तरह, जब मैं टेलनेट / ssh में तीन स्तर गहरे होते हैं, मैं गलत विंडो में गलत चीज टाइप नहीं करता। यह वास्तव rm -rf .में गलत खिड़की में बेकार है ! (नोट: घर पर, टेलनेट सभी मशीनों पर अक्षम है। काम पर, ssh हमेशा सक्षम नहीं है और मेरे पास बहुत अधिक मशीनों तक रूट एक्सेस नहीं है।)

मेरे पास एक स्क्रिप्ट ~/bin/setpromptहै .bashrcजो मेरे द्वारा निष्पादित की गई है , जिसमें शामिल हैं:

RESET="\[\017\]"
NORMAL="\[\033[0m\]"
RED="\[\033[31;1m\]"
YELLOW="\[\033[33;1m\]"
WHITE="\[\033[37;1m\]"
SMILEY="${WHITE}:)${NORMAL}"
FROWNY="${RED}:(${NORMAL}"
SELECT="if [ \$? = 0 ]; then echo \"${SMILEY}\"; else echo \"${FROWNY}\"; fi"

# Throw it all together 
PS1="${RESET}${YELLOW}\h${NORMAL} \`${SELECT}\` ${YELLOW}>${NORMAL} "

यह स्क्रिप्ट होस्ट नाम के लिए संकेत देता है, उसके बाद :)यदि अंतिम कमांड सफल रही और :(अंतिम कमांड विफल रही।


द $? जाँच एक बहुत साफ विचार है, मुझे यह पसंद है।
derobert

6
मैं अपने संकेत में स्थिति भी दिखाता हूं, लेकिन संख्यात्मक मान रखता हूं और गैर-शून्य, अन्यथा हरा होने पर इसे लाल रंग देता हूं।
पृ

दिलचस्प ....
imapollo

25

कम में manpages के लिए रंग manpages पढ़ने के लिए थोड़ा आसान बनाता है:

export LESS_TERMCAP_mb=$'\E[01;31m'
export LESS_TERMCAP_md=$'\E[01;31m'
export LESS_TERMCAP_me=$'\E[0m'
export LESS_TERMCAP_se=$'\E[0m'
export LESS_TERMCAP_so=$'\E[01;44;33m'
export LESS_TERMCAP_ue=$'\E[0m'
export LESS_TERMCAP_us=$'\E[01;32m'

रंगीन manpages को सबसे अधिक स्थापित करके और इसे MANPAGER env variable के रूप में उपयोग करके भी प्राप्त किया जा सकता है। यदि आप इस पेजर का उपयोग न केवल मनुष्य के लिए करना चाहते हैं, तो इस तरह के पैराग्राफ चर का उपयोग करें:

export PAGER="/usr/bin/most -s"

24

कोई और सीडी ../../../ .. लेकिन 4

संख्या के तर्क के रूप में पारित किए गए कई डायरियों को छोड़ देता है, अगर कोई भी डिफ़ॉल्ट रूप से 1 से ऊपर नहीं जाता है (स्टैकओवरफ़्लो.कॉम में एक टिप्पणी में लिंक में पाया गया है और थोड़ा संशोधित किया गया है)

up(){
  local d=""
  limit=$1
  for ((i=1 ; i <= limit ; i++))
    do
      d=$d/..
    done
  d=$(echo $d | sed 's/^\///')
  if [ -z "$d" ]; then
    d=..
  fi
  cd $d
}

अप () का यह संस्करण अनावश्यक रूप से जटिल लगता है। मैं इस संस्करण का उपयोग करता हूं: up () {cd $ (eval printf '../'%.0s {1 .. $ 1}) && pwd; }। यदि आप स्पष्ट रूप से चाहते हैं तो आप 'pwd' पर कॉल हटा सकते हैं।
मैथ्यू जी

मैं कुछ इस तरह का उपयोग करता हूं: # डायरेक्टरी नेविगेशन एलियासेसalias ..='cd ..' alias ...='cd ../..' alias ....='cd ../../..' alias .....='cd ../../../..'
मैट किंफिक

19

मैं कई अलग-अलग मशीनों से निपटता हूं, इसलिए मेरे पसंदीदा में से एक प्रत्येक मशीन के लिए उपनाम है जिसे मुझे अक्सर एसएसएच करने की आवश्यकता है:

alias claudius="ssh dinomite@claudius"

मशीनों के बीच में और भी आसान बनाने के लिए एक अच्छी .ssh/configऔर ssh कीज़ को सेटअप करना उपयोगी है।

मेरी पसंदीदा उपनामों में से एक निर्देशिका को आगे बढ़ाने के लिए है:

alias ..="cd .."
alias ...="cd ../.."
alias ....="cd ../../.."
alias .....="cd ../../../.."

और आम तौर पर ls(और टाइपो) के विभिन्न रूपों के लिए :

alias ll="ls -l"
alias lo="ls -o"
alias lh="ls -lh"
alias la="ls -la"
alias sl="ls"
alias l="ls"
alias s="ls"

इतिहास बहुत उपयोगी हो सकता है, लेकिन अधिकांश वितरण पर डिफ़ॉल्ट रूप से आपका इतिहास प्रत्येक शेल से बाहर निकलने से उड़ा दिया जाता है, और इसके साथ शुरू करने के लिए बहुत कुछ नहीं है। मुझे इतिहास की 10,000 पंक्तियाँ पसंद हैं:

export HISTFILESIZE=20000
export HISTSIZE=10000
shopt -s histappend
# Combine multiline commands into one in history
shopt -s cmdhist
# Ignore duplicates, ls without options and builtin commands
HISTCONTROL=ignoredups
export HISTIGNORE="&:ls:[bf]g:exit"

इस तरह, अगर मुझे पता है कि मैंने पहले कुछ किया है, लेकिन बारीकियों को याद नहीं कर सकते हैं, एक त्वरित history | grep fooमेरी याददाश्त को कम करने में मदद करेगा।

मैंने अक्सर अपने प्रत्येक डिस्क के आकार का पता लगाने awkके लिए आउटपुट के एक निश्चित कॉलम को प्राप्त करने के लिए अपने आप से आउटपुट प्राप्त किया df -h | awk '{print $2}'। इसे आसान बनाने के लिए, मैंने fawkअपने .bashrc में एक फ़ंक्शन बनाया :

function fawk {
    first="awk '{print "
    last="}'"
    cmd="${first}\$${1}${last}"
    eval $cmd
}

अब मैं चला सकता हूं df -h|fawk 2जो एक अच्छा सा टाइपिंग बचाता है।

यदि आपको एक सीमांकक निर्दिष्ट करने की आवश्यकता है ( उदाहरण के awk -F:लिए /etc/passwd), तो यह फ़ंक्शन स्पष्ट रूप से संभाल नहीं सकता है। इस gist में थोड़ा-अधिक ओवरहॉल किया गया संस्करण awkफ़ील्ड संख्या से पहले मनमाने ढंग से तर्क को संभाल सकता है (लेकिन स्टड से इनपुट की आवश्यकता होती है)।


2
मैं ssh उर्फ ​​और ssh कुंजियों का भी उपयोग करता हूं ... यह हर इतनी आसान
डेविन

1
इतिहास नियंत्रण सुझावों के लिए +1।
रेने सरसो

2
आप एक ही प्रभाव में होस्टनाम उपनामों को .ssh / config में डाल सकते हैं। इस स्थिति में, 'यूज़रनेम डाइनोमाइट' के साथ 'होस्ट क्लाउडियस' में एक प्रविष्टि जोड़ें
Sirex

15

GPG एन्क्रिप्टेड bashrc

मुझे यकीन है कि हम सब चीजें हैं जो हम अपने bashrc में रखना चाहते हैं कि हम sudoers द्वारा आसानी से पठनीय नहीं चाहते हैं। मेरा समाधान यह है:

if [ -f ~/.bash_private.gpg ]; then
   eval "$(gpg --decrypt ~/.bash_private.gpg 2>/dev/null)"
fi

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

alias MYsql='mysql -uadmin -psecret'
wglatest(){ wget -O https://admin:secret@server.com/latest; }

क्या आप भी उस मामले में अपना इतिहास एन्क्रिप्ट करते हैं? क्यों नहीं अपने $ घर एन्क्रिप्ट
Rqomey

@ रिकी, पूरी बात यह है कि मुझे अपने इतिहास को एन्क्रिप्ट करने की आवश्यकता नहीं है क्योंकि मेरे पासवर्ड मेरे .bash_history में दिखाई नहीं देते हैं क्योंकि वे एलियंस या फ़ंक्शन द्वारा छिपे हुए हैं। इसमें फिर आप देख MYsql < garbagecollect.sqlके बजायmysql -uadmin -psecret < garbagecollect.sql
ब्रूनो Bronosky


12

मैं इन सभी जगहों पर सेट करता था, लेकिन फिर महसूस किया कि केवल उन्हें 'मैन्युअल रूप से' कैसे करना है, यह याद रखना बेहतर है क्योंकि इसका मतलब है कि मैं 1) पूरी तरह से समझ जाऊंगा कि क्या चल रहा था और 2) इन क्षमताओं तक पहुंच है भले ही मेरा कस्टम .bashrc स्थापित नहीं था।

केवल एक चीज जो मैं इन दिनों के लिए उपनाम का उपयोग करता हूं, वह वास्तव में लंबी लाइनों (जैसे। alias myhost='ssh -T user@my.remote.host screen -dAr') के दोहराव वाले टाइपिंग में कटौती करना है।


2
लंबे उपयोगी आदेशों को याद करने के बारे में सहमत। हालांकि मुझे लगता है कि मैं भागते हुए सर्वर पर अक्सर 'डिस्कस्पेस' चला रहा हूं (यानी php सभी जगह coredumping है)।
गैरेथ

हाँ, मेरे पास वास्तव में कुछ ऐसा ही है (du / home / * --max-गहराई 1 | sort -n> /home/.sizes) रात को चलाते हैं ताकि मैं अपने उपयोगकर्ताओं की अंतरिक्ष की खपत पर बड़ी नज़र रख सकूं साझा मशीन।
पीजेड

1
हालाँकि, आपके द्वारा नियमित रूप से उपयोग की जाने वाली प्रणालियों पर अपने कस्टम कॉन्फ़िगरेशन को लागू करना काफी आसान है।
तोबू

बस के रूप में आप के लिए एक उपनाम sias, यह कुछ मैं हर समय कर रहा है। मैं हमेशा DNS आउटेज के मामले में आईपी के साथ ऐसा करता हूं।
jwbensley

9

एक लाइनर और छोटे स्क्रिप्ट वहाँ हमेशा के लिए जा सकते हैं। मैं खुद को मैन बैश और चीजें लिखने की सलाह देता हूं। Http://www.commandlinefu.com पर कुछ अच्छे शॉर्ट बैश सामान । कुछ चीजें पा लेता है।

#use extra globing features. See man bash, search extglob.
shopt -s extglob
#include .files when globbing.
shopt -s dotglob
#When a glob expands to nothing, make it an empty string instead of the literal characters.
shopt -s nullglob
# fix spelling errors for cd, only in interactive shell
shopt -s cdspell
# vi mode
set -o vi

s() { # do sudo, or sudo the last command if no argument given
    if [[ $# == 0 ]]; then
        sudo $(history -p '!!')
    else
        sudo "$@"
    fi
}

prompt_command() {
    p=$PWD  # p is much easier to type in interactive shells
    # a special IFS should be limited to 1 liners or inside scripts.
    # Otherwise it only causes mistakes.
    unset IFS
}
PROMPT_COMMAND=prompt_command


# smart advanced completion, download from
# http://bash-completion.alioth.debian.org/
if [[ -f $HOME/local/bin/bash_completion ]]; then
    . $HOME/local/bin/bash_completion
fi


extract () { # extract files. Ignore files with improper extensions.
    local x
    ee() { # echo and execute
        echo "$@"
        $1 "$2"
    }
    for x in "$@"; do
        [[ -f $x ]] || continue
        case "$x" in
            *.tar.bz2 | *.tbz2 )    ee "tar xvjf" "$x"  ;;
            *.tar.gz | *.tgz ) ee "tar xvzf" "$x"   ;;
            *.bz2 )             ee "bunzip2" "$x"   ;;
            *.rar )             ee "unrar x" "$x"   ;;
            *.gz )              ee "gunzip" "$x"    ;;
            *.tar )             ee "tar xvf" "$x"   ;;
            *.zip )             ee "unzip" "$x"     ;;
            *.Z )               ee "uncompress" "$x" ;;
            *.7z )              ee "7z x" "$x"      ;;
        esac
    done
}

2
मुझे आपकी history -pचाल अच्छी लगती है ।
टोबू

9

बैश के लिए एक छोटी सी टिप यदि आप एक sysadmin हैं और जड़ विशेषाधिकारों के साथ काम करते हैं:

shopt -o noclobber

यदि आप आउटपुट (> फ़ाइल नाम) को रीडायरेक्ट करते हैं तो यह आपको पहले से मौजूद फ़ाइल की सामग्री को गलती से नष्ट करने से रोकेगा। आप हमेशा> | फ़ाइल नाम के साथ अधिलेखित करने के लिए बाध्य कर सकते हैं।


8

मैं अपने bashrc में निम्नलिखित है

function __setprompt {
  local BLUE="\[\033[0;34m\]"
  local NO_COLOUR="\[\033[0m\]"
  local SSH_IP=`echo $SSH_CLIENT | awk '{ print $1 }'`
  local SSH2_IP=`echo $SSH2_CLIENT | awk '{ print $1 }'`
  if [ $SSH2_IP ] || [ $SSH_IP ] ; then
    local SSH_FLAG="@\h"
  fi
  PS1="$BLUE[\$(date +%H:%M)][\u$SSH_FLAG:\w]\\$ $NO_COLOUR"
  PS2="$BLUE>$NO_COLOUR "
  PS4='$BLUE+$NO_COLOUR '
}
__setprompt

एक स्थानीय मशीन पर ऐसा दिखता है:

[17:57][user:~]$

लेकिन एक दूरस्थ (ssh के माध्यम से) यह है:

[17:57][user@machine:~]$

6

मैंने इसे कुछ समय के लिए अपने .bashrc में लिया है और मैंने इसे मददगार पाया है। यदि आप बॉक्स में sshing कर रहे हैं, तो लॉगिन करते समय स्वचालित रूप से स्क्रीन शुरू हो जाती है, इस तरह जब आपका नेटवर्क कनेक्शन बाधित होता है या जो भी हो, आप जो कुछ भी कर रहे थे उसे खोना नहीं है। इसे अंत में रखा जाना चाहिए।

if [ "$PS1" != "" -a "${STARTED_SCREEN:-x}" = x  -a "${SSH_TTY:-x}" != x ]
then
STARTED_SCREEN=1 ; export STARTED_SCREEN
[ -d $HOME/lib/screen-logs ] || mkdir -p $HOME/lib/screen-logs

sleep 1
screen -U -RR && exit 0

echo "Screen failed! continuing with normal bash startup"
fi

यदि आप अपने लॉगिन शेल को स्क्रीन के रूप में सेट करते हैं (और अपने स्क्रीन में bash को कॉन्फ़िगर करें), तो जब भी आप SSH करेंगे, स्क्रीन स्वचालित रूप से डिस्कनेक्ट की गई स्क्रीन को फिर से कनेक्ट करने का प्रयास करेगी। यदि वह विफल रहता है, तो यह एक नई स्क्रीन बनाएगा।
डान उडे

@Dan Uey मैंने आपके लिए जो भी सुझाव दिया है, उसे मैंने आजमाया नहीं है, लेकिन मैंने जो bash पोस्ट किया है, वह स्क्रीन को केवल ssh लॉगिन पर शुरू करेगा, आपके लॉगिन शेल के रूप में स्क्रीन को सेट करने के रूप में था, इसे स्थानीय लॉगिन पर भी शुरू करेंगे। जो शायद आप चाहते हैं। यह सिर्फ वही नहीं है जो मैं चाहता हूं। :-)
बॉडटैक

यदि आप वियोग के बारे में चिंतित हैं, तो मॉश देखें
jwbensley

5

fortuneवैसे भी आपको कितने उपनामों की ज़रूरत है?

मुझे एक cddउपनाम बनाना पसंद है जो मुझे उस जगह ले जाता है जहां मैं वर्तमान में उस सर्वर पर काम करने की सबसे अधिक संभावना है।

PATHपुनर्वित्त वास्तव में अंतर्गत आता है .bash_profile, नहीं .bashrc

एक सर्वर पर जहां मैं नियमित रूप से बड़े सेट का उपयोग करता screenहूं, मेरे .bashrcपास होगा:

alias s1="screen -dr chaos1"
alias s2="screen -dr chaos2"
alias s3="screen -dr chaos3"
# ... and so on

( screenउदाहरण के लिए, सेट अप किए गए थे screen -U -S chaos1।)


2
@ अचोस "आपको कितने एलियनों की जरूरत है, वैसे भी?"। जीत के लिए लुभाना। Frak (और वैकल्पिक वर्तनी) विफल।
गैरेथ

कृपया इन चरणों का पालन करें। 1) अपने PATH को अपने .bashrc में बढ़ाएं। 2) 'बैश' टाइप करें। 3) 'इको $ पाथ' टाइप करें। 4) 'बैश' टाइप करें। 5) 'इको $ पाथ' टाइप करें। 6) अपने आप को अनजाने में अपमानित करने वाले और अपमानजनक लोगों के लिए सिर में पंच करें क्योंकि वे आपके मुकाबले सिसादमिन सर्वोत्तम प्रथाओं के बारे में अधिक जानते हैं।
अराजकता

मैं प्रभावित हूं कि आपके पास थोड़ा वैध कारण है, हालांकि खुद को चेहरे पर पंच नहीं करना है। गैर-लॉगिन गोले प्राप्त करना आसान है जहां आपका मार्ग पहले से विस्तारित नहीं था। मैं वापस लेता हूं कि इसका गूंगा, मैं मूल रूप से इसे पढ़ता हूं कि आप यह कहने की कोशिश कर रहे थे कि आपको अपने .bashrc या कुछ महत्वपूर्ण चर सेट नहीं करने चाहिए।
इयान कीलिंग

शायद किसी को "क्या मुझे अपने PATH चर को .bashrc या .bash_profile" में सेट करना चाहिए?
गैरेथ

3
@ इयान केलिंग: जो मैं वास्तव में कह रहा हूं वह यह है कि एक बार लॉगिन के अनुसार जो ऑपरेशन किए जाने चाहिए, वह है .bash_profile और ऐसे ऑपरेशन जिन्हें एक बार किए जाने के बाद शेल इंस्टेंशन में होना चाहिए।
अराजकता

5

अन्य बातों के अलावा, मैंने कम के लिए कुछ चूक निर्धारित की हैं, गलती से अपने टर्मिनल को बंद करने और इतिहास के माध्यम से आगे नेविगेशन को सक्षम करने के लिए:

# ignore case, long prompt, exit if it fits on one screen, allow colors for ls and grep colors
export LESS="-iMFXR"

# must press ctrl-D 2+1 times to exit shell
export IGNOREEOF="2"

# allow ctrl-S for history navigation (with ctrl-R)
stty -ixon

+1 के लिएexport IGNOREEOF="2"
सर्वरहोल्ड

5

मेरे पास कुछ बिट्स हैं:

# stop the pc speaker ever annoying me :)
setterm -bfreq 0

# don't put duplicate lines in the history. See bash(1) for more options
HISTCONTROL=ignoredups
# ... and ignore same sucessive entries.
HISTCONTROL=ignoreboth

# Expand the history size
HISTFILESIZE=10000 
HISTSIZE=100

# commands with leading space do not get added to history
HISTCONTROL=ignorespace

# am I on the internet?
alias p4='ping 4.2.2.2 -c 4'

# pwsafe
alias pw='pwsafe -p'

# ls aliases
alias ll='ls -l'
alias la='ls -A'
alias l='ls -CF'
alias lt='ls -laptr' #oldest first sort
alias labc='ls -lap' #alphabetical sort

# cd aliases
alias ..='cd ..'
alias ...='cd ../..'
alias ....='cd ../../..'

# cd into the old directory
alias bd='cd "$OLDPWD"'

# install a package and automatically respond yes to confirmation prompt
alias ins="sudo aptitude install"

# remove a package and its configuration files
alias remp="sudo aptitude purge"

# search for a package - apt-cache and aptitude search in different ways
# so have both
alias searchc="apt-cache search"
alias search="aptitude search"
alias show="aptitude show"

3
आपकी HISTCONTROL लाइनें एक-दूसरे को ओवरराइड करती हैं, क्योंकि यह सिर्फ शेल वेरिएबल है। इग्नोबोथ इग्नोरस्पेस और इग्नोरडअप को जोड़ती है।
अन्निका बैकस्ट्रॉम

4
cd -
Bd

5

/ लॉग / लॉग में सभी लॉग पूंछ

alias logs="find /var/log -type f -exec file {} \; | grep 'text' | cut -d' ' -f1 | sed -e's/:$//g' | grep -v '[0-9]$' | xargs tail -f"


4

'फ़ोल्डर्स' उर्फ ​​महान है! मैंने इसे थोड़ा संशोधित किया ताकि रिक्त स्थान वाली निर्देशिकाओं में त्रुटि न हो।

alias folders='find . -maxdepth 1 -type d -print0 | xargs -0 du -sk | sort -rn'

2
फ़ोल्डर्स डिस्क उपयोग द्वारा क्रमबद्ध, अच्छा
dotjoe

3

मैं चीजों को मैन्युअल रूप से सेट करने के बजाय चीजों को जानने के बारे में @ pjz की टिप्पणी को प्रतिध्वनित करूंगा। खासकर अगर आप कई मशीनों का उपयोग करते हैं, जैसे मैं हमेशा करता हूं।

तो एक मैं निश्चित रूप से जानता हूँ set -o viक्योंकि मैं vi- संपादन आदेश को बाश में जानता हूँ और मैं emacs वाले (इसके अलावा, Ctrl + A के साथ हस्तक्षेप screen) नहीं जानता । अपने बक्सों पर, मैंने उसे अंदर डाला.bashrc

मुझे यह भी लगता है कि मुझे शामिल करना होगा export EDITOR=vimक्योंकि नैनो के लिए हाल ही में डिस्ट्रोफ डिफ़ॉल्ट की एक संख्या जो एक उपयोगिता द्वारा फेंके जाने के लिए सबसे अधिक कष्टप्रद है जिसे आपको कुछ संपादित करने की आवश्यकता होती है, जब मुझे vi की उम्मीद थी। : - /

मैं भी अपना संकेत बदल देता हूं। मुझे बहुत समय पहले पता चला कि अंतिम त्रुटि कोड जोड़ना केवल इतना उपयोगी है कि मुझे यह पसंद है। और मुझे प्रॉम्प्ट में पूरा पथनाम पसंद है। और वर्तमान screenसंख्या, भी। और यह सिर्फ वर्तमान उपयोगकर्ता और hostname शामिल करने के लिए समझ में आता है। मेरा संकेत हैPS1='\u@\h $PWD $WINDOW [$?] \$ '


\ w आपको पूर्ण पथनाम देना चाहिए (जब तक कि आप अपने होम डायरेक्टरी पदानुक्रम के भीतर न हों जब '/ होम / मी' उदाहरण के लिए '~' बन जाता है :-)
dr-jan

यह "बिट को छोड़कर" है जिसका मैं उपयोग नहीं करता / करती हूं। :-)
स्टेटिक्सन

3

यह देखने के लिए बैश चेक करें कि क्या खिड़की का आकार बदल गया है (यदि आप अपनी टर्मिनल विंडो का आकार बदलते हैं तो रेखा-संपादन को अजीब होने से बचाता है)

shopt -s checkwinsize

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

यह स्निपेट इसे सबसे पहले केवल बदलावों (पूरे बफर के साथ ओवरराइट करने के बजाय) में बदल देता है, और फिर इसे करने के लिए, प्रत्येक आदेश के बाद, परिवर्तनों को लिखें। वास्तव में, आपको लाइव अपडेटिंग .bash_history मिलता है, इसलिए यदि आप एक नया टर्मिनल शुरू करते हैं, तो आपके पास आपके अन्य चालू सत्रों के इतिहास के सभी आदेश हैं।

shopt -s histappend
PROMPT_COMMAND='history -a'


3

यहाँ खदानें हैं:

export HISTCONTROL=ignoredups
export HISTIGNORE="&:ls:bg:fg"

# set variable identifying the chroot you work in (used in the prompt below)
if [ -z "$debian_chroot" ] && [ -r /etc/debian_chroot ]; then
    debian_chroot=$(cat /etc/debian_chroot)
fi

# shows you if you are in a chroot or in a git repository
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;30m\]\h\[\033[00m\]:\[\033[01;34m\]\W\[\033[00m\]$(__git_ps1)\$ '


if [ -f /etc/bash_completion ]; then
    . /etc/bash_completion
fi

# two handy single-letter aliases

alias u='ls -hltr'
alias e='du * -cs | sort -nr | head'
alias g='grep -C5 --color=auto'

# creates a temp dir and cds into it
alias td='pushd $(mktemp -d)'

# find <dir> <file name regexp> <file contents regexp>
function fing { find "$1" -name "$2" -exec grep -H "$3" "{}" \; }

# shows "git diff" across any project in any subdirectory
alias git-differ='for g in $(find . -name ".git"); do g=${g%%.git};printf "$g\t\t\t";pu $g >/dev/null && git diff |wc -l; p >/dev/null; done'

# does git house keeping across any project in any subdirectory
alias git-housekeep='for g in $(find . -name ".git"); do g=${g%%.git};echo $g;pu $g && git repack && git gc --auto && p;done'

# Debian update
alias apg='aptitude update && aptitude dist-upgrade && aptitude clean'

# Quick way to serve files in HTTP from the local dir
alias webs='python -m SimpleHTTPServer'

2

ये मेरे पसंदीदा हैं:

export HISTFILESIZE=1000000000
export HISTSIZE=1000000

मुझे कमांड-लाइन का इतिहास पसंद है जो कभी नहीं भूलता।

दुर्भाग्य से, थोड़ी देर बाद मैंने क्रोन से एक शेल लॉन्च किया, जो किसी भी तरह से पढ़ा नहीं गया था। और एक साल के इतिहास को नष्ट करते हुए, 500 लाइनों तक सब कुछ काट दिया। तो मैं इन / / bashrc में जाने की सलाह देता हूं।


2

ये मेरे कुछ पसंदीदा हैं:

alias ls='ls -F --color=auto'
alias l='ls'
alias ll='ls -ahl'
alias ..='cd ..'
alias ...='cd ../..'
alias mv='mv -i'

mkcd() {
        if [ $# != 1 ]; then
                echo "Usage: mkcd <dir>"
        else
                mkdir -p $1 && cd $1
        fi
}

# Git related
alias gs='git status'
alias gc='git commit'
alias ga='git add'
alias gd='git diff'
alias gb='git branch'
alias gl='git log'
alias gsb='git show-branch'
alias gco='git checkout'
alias gg='git grep'
alias gk='gitk --all'
alias gr='git rebase'
alias gri='git rebase --interactive'
alias gcp='git cherry-pick'
alias grm='git rm'

2

मैं इसे पिछले परिवर्तित निर्देशिका में सीडी के लिए दिन में लगभग 20 बार उपयोग करता हूं:

cl()
{
        last_dir="$(ls -Frt | grep '/$' | tail -n1)"
        if [ -d "$last_dir" ]; then
                cd "$last_dir"
        fi
}

ये दोनों अक्सर इस्तेमाल की गई निर्देशिकाओं के स्थायी बुकमार्क रखते हैं:

rd(){
    pwd > "$HOME/.lastdir_$1"
}

crd(){
        lastdir="$(cat "$HOME/.lastdir_$1")">/dev/null 2>&1
        if [ -d "$lastdir" ]; then
                cd "$lastdir"
        else
                echo "no existing directory stored in buffer $1">&2
        fi
}

2

से स्वचालित लिनक्स और यूनिक्स प्रशासन किर्क Bauer द्वारा (महान किताब!)

PS1='\n[\u@\h]: \w\n$?> '

शुरुआत में नई लाइन मेरी है, मैं पिछले आउटपुट और प्रॉम्प्ट के बीच एक स्पष्ट रेखा रखना पसंद करता हूं। बाकी है:

\ u = उपयोगकर्ता नाम

\ h = मेजबान

\ w = कार्यशील निर्देशिका

$? = अंतिम रिटर्न कोड


1

मैं बहुत सी चीज़ों को मैन्युअल रूप से $ HOME / स्थानीय में संकलित करता हूं ताकि मेरे पास यह थोड़ा स्निपेट हो:

for prog in $HOME/local/*
do
    if [ -d "$prog/bin" ]; then
        export PATH=$prog/bin:$PATH
    fi
    if [ -d "$prog/include" ]; then
        export C_INCLUDE_PATH=$prog/include:$C_INCLUDE_PATH
    fi
    if [ -d "$prog/lib" ]; then
        export LD_LIBRARY_PATH=$prog/lib:$LD_LIBRARY_PATH
        export LIBRARY_PATH=$prog/lib:$LIBRARY_PATH
    fi
    if [ -d "$prog/man" ]; then
        export MANPATH=$prog/man:$MANPATH
    fi
    if [ -d "$prog/share/man" ]; then
        export MANPATH=$prog/share/man:$MANPATH
    fi
done

मेरे पास मेरा IRC क्लाइंट मेरे स्क्रीन पर चल रहे सर्वर पर है इसलिए मेरे पास यह (एक .bashrc चीज़ नहीं है, लेकिन फिर भी उपयोगी है)

#!/usr/bin/env bash

RUNNING=`screen -ls | grep irc`
if [ "" = "$RUNNING" ]; then
   screen -S irc irssi
else
   screen -dr irc
fi

1

मैं कई मशीनों पर अपने bashrc का उपयोग करता हूं, इसलिए मुझे यह सुनिश्चित करने के लिए थोड़ा सा स्निपेट मिला है कि एलएस कोलोरिज़्ड है। यदि आप अनाम रेखा को समायोजित करते हैं, तो यह OSX मशीनों पर भी ठीक हो जाएगा, भले ही बीएसडी *।

if [ "$TERM" != "dumb" ]; then
    if [ `uname` == "Darwin" ]; then
       alias ls='ls -G'
    else
       eval "`dircolors -b`"
       alias ls='ls --color=auto'
    fi
fi

इसके अलावा, मुझे एक फ़ाइल का बैकअप लेने के लिए एक कमांड मिली है, उपयोगी यदि आपकी कॉन्फ़िग फ़ाइल को बदलने के बारे में और हाथ से पहले एक त्वरित प्रतिलिपि बनाना चाहते हैं।

bu () { cp $1 ~/.backup/`basename $1`-`date +%Y%m%d%H%M`.backup ; }

@Andrew: मैं OSX में आपका पहला कोड असफलता से चलाता हूं। यह मेरी प्रॉम्प्ट सेटिंग्स को तोड़ता है।
लेओ लेपोल्ड हर्ट्ज़ '31

यहां ठीक काम करता है (10.6.X)
Rev316

1

यह मेरे पसंदीदा में से एक है:

alias ssh='if [ "$(ssh-add -l)" = "The agent has no identities." ]; then ssh-add; fi; /usr/bin/ssh "$@"'

अगर मैं प्रमाणित करना भूल गया हूं, तो यह मुझे ssh सत्र के बाद अपने टाइपिंग ssh-add को बर्बाद किए बिना करने की अनुमति देता है ।


1

एक जोड़ी अच्छे वाले

SSH अपने द्वारा होस्टनाम को स्वचालित रूप से पूरा करें (यदि यह आपके विन्यास या इतिहास में है)

complete -o default -o nospace -W "$(/usr/bin/env ruby -ne 'puts $_.split(/[,\s]+/)[1..-1].reject{|host| host.match(/\*|\?/)} if $_.match(/^\s*Host\s+/);' < $HOME/.ssh/config)" scp sftp ssh

कुछ उपयोगी बैश पूर्णता सेटिंग्स

bind "set completion-ignore-case on" # note: bind used instead of sticking these in .inputrc
bind "set bell-style none" # no bell
bind "set show-all-if-ambiguous On" # show list automatically, without double tab

मैक ओएस एक्स के लिए कुछ उपयोगी

alias nospotlight='sudo mdutil -a -i off'
alias cleardnscache='sudo killall -HUP mDNSResponder'
alias ldd='otool -L'
alias seq='jot - '
alias eject='drutil eject'
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.