ഷെൽ പ്രോഗ്രാമിംഗ് പഠിക്കാൻ Linux നു പുതിയ 5 ഷെൽ സ്ക്രിപ്റ്റുകൾ - ഭാഗം II
എന്തെങ്കിലും പഠിക്കാൻ, പരാജയപ്പെടുമെന്ന ഭയമില്ലാതെ നിങ്ങൾ അത് ചെയ്യണം. ഞാൻ പ്രായോഗികതയിൽ വിശ്വസിക്കുന്നു, അതിനാൽ സ്ക്രിപ്റ്റിംഗ് ഭാഷയുടെ പ്രായോഗിക ലോകത്തേക്ക് നിങ്ങളെ അനുഗമിക്കും.
ഈ ലേഖനം ഞങ്ങളുടെ ആദ്യ ലേഖനത്തിന്റെ വിപുലീകരണമാണ് ലിനക്സ് ഷെല്ലും അടിസ്ഥാന ഷെൽ സ്ക്രിപ്റ്റിംഗും മനസ്സിലാക്കുക - ഭാഗം I, അവിടെ ഞങ്ങൾ നിങ്ങൾക്ക് സ്ക്രിപ്റ്റിംഗിന്റെ ഒരു രുചി നൽകി, ഈ ലേഖനത്തിൽ ഞങ്ങൾ നിങ്ങളെ നിരാശപ്പെടുത്തില്ല.
സ്ക്രിപ്റ്റ് 1: ഒരു പ്രത്യേക പാറ്റേൺ വരയ്ക്കുന്നു
#!/bin/bash MAX_NO=0 echo -n "Enter Number between (5 to 9) : " read MAX_NO if ! [ $MAX_NO -ge 5 -a $MAX_NO -le 9 ] ; then echo "WTF... I ask to enter number between 5 and 9, Try Again" exit 1 fi clear for (( i=1; i<=MAX_NO; i++ )) do for (( s=MAX_NO; s>=i; s-- )) do echo -n " " done for (( j=1; j<=i; j++ )) do echo -n " ." done echo "" done ###### Second stage ###################### for (( i=MAX_NO; i>=1; i-- )) do for (( s=i; s<=MAX_NO; s++ )) do echo -n " " done for (( j=1; j<=i; j++ )) do echo -n " ." done echo "" done echo -e "\n\n\t\t\t Whenever you need help, linux-console.net is always there"
മേൽപ്പറഞ്ഞ മിക്ക 'പ്രധാന പദങ്ങളും' നിങ്ങൾക്ക് അറിയാമായിരിക്കും, അവയിൽ മിക്കതും സ്വയം വിശദീകരിക്കുന്നതാണ്. ഉദാ., വേരിയബിളിന്റെ പരമാവധി മൂല്യം MAX സജ്ജീകരിക്കുന്നു, കാരണം ഒരു ലൂപ്പാണ്, നൽകിയിരിക്കുന്ന ഇൻപുട്ടിന്റെ മൂല്യത്തിന് ലൂപ്പ് സാധുതയുള്ളത് വരെ ലൂപ്പിനുള്ളിലെ എന്തും വീണ്ടും വീണ്ടും എക്uസിക്യൂട്ട് ചെയ്യുന്നു.
chmod 755 Special_Pattern.sh ./Special_Pattern.sh Enter Number between (5 to 9) : 6 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Whenever you need help, linux-console.net is always there
നിങ്ങൾക്ക് ഏതെങ്കിലും പ്രോഗ്രാമിംഗ് ഭാഷയെക്കുറിച്ച് അൽപ്പം ബോധമുണ്ടെങ്കിൽ, മുകളിലുള്ള സ്ക്രിപ്റ്റ് പഠിക്കുന്നത് ബുദ്ധിമുട്ടുള്ള കാര്യമല്ല, നിങ്ങൾ കമ്പ്യൂട്ടേഷൻ, പ്രോഗ്രാമിംഗ്, ലിനക്സ് എന്നിവയിൽ പുതിയ ആളാണെങ്കിൽ പോലും അത് വലിയ ബുദ്ധിമുട്ടുള്ള കാര്യമല്ല.
സ്ക്രിപ്റ്റ് 2: വർണ്ണാഭമായ സ്ക്രിപ്റ്റ് സൃഷ്ടിക്കുന്നു
ആരാണ് പറയുന്നത്, Linux നിറമില്ലാത്തതും ബോറടിപ്പിക്കുന്നതുമാണ്, താഴെയുള്ള കോഡുകൾ എന്തിനിലേക്കും [ഡോട്ട്] സേവ് ചെയ്യുക, അത് എക്സിക്യൂട്ടബിൾ ആക്കി പ്രവർത്തിപ്പിക്കുക, അത് എങ്ങനെയായിരുന്നുവെന്ന് എന്നോട് പറയാൻ മറക്കരുത്, നിങ്ങൾക്ക് എന്ത് നേടാനാകുമെന്ന് ചിന്തിക്കുക, അത് എവിടെയെങ്കിലും നടപ്പിലാക്കുക.
#!/bin/bash clear echo -e "33[1m Hello World" # bold effect echo -e "33[5m Blink" # blink effect echo -e "33[0m Hello World" # back to normal echo -e "33[31m Hello World" # Red color echo -e "33[32m Hello World" # Green color echo -e "33[33m Hello World" # See remaining on screen echo -e "33[34m Hello World" echo -e "33[35m Hello World" echo -e "33[36m Hello World" echo -e -n "33[0m" # back to normal echo -e "33[41m Hello World" echo -e "33[42m Hello World" echo -e "33[43m Hello World" echo -e "33[44m Hello World" echo -e "33[45m Hello World" echo -e "33[46m Hello World" echo -e "33[0m Hello World"
ശ്രദ്ധിക്കുക: ഇപ്പോൾ കളർ കോഡിനെക്കുറിച്ച് വിഷമിക്കേണ്ടതില്ല, നിങ്ങൾക്ക് പ്രധാനപ്പെട്ടവ ക്രമേണ നിങ്ങളുടെ നാവിൽ ഉണ്ടാകും.
മുന്നറിയിപ്പ്: നിങ്ങളുടെ ടെർമിനലിൽ മിന്നാനുള്ള സൗകര്യം ഉണ്ടായിരിക്കില്ല.
chmod 755 Colorfull.sh ./Colorfull.sh Hello World Blink Hello World Hello World Hello World Hello World Hello World Hello World Hello World Hello World Hello World Hello World Hello World Hello World Hello World Hello World
സ്ക്രിപ്റ്റ് 3: ഒരു ഫയൽ/ഡയറക്uടറി എൻക്രിപ്റ്റ് ചെയ്യുക
ഈ സ്ക്രിപ്റ്റ് ഒരു ഫയൽ എൻക്രിപ്റ്റ് ചെയ്യും (ഓർക്കുക? ഡയറക്ടറി/ഡ്രൈവർ/.... എല്ലാം ഫയലായി കണക്കാക്കുന്നു, ലിനക്സിൽ). മുകളിലെ സ്ക്രിപ്റ്റിന്റെ നിലവിലെ പരിമിതി, TAB ഉപയോഗിച്ച് പേര് സ്വയമേവ പൂർത്തിയാക്കുന്നതിനെ അത് പിന്തുണയ്ക്കുന്നില്ല എന്നതാണ്. മാത്രമല്ല, അതേ ഫോൾഡറിൽ എൻക്രിപ്റ്റുചെയ്യാൻ നിങ്ങൾ സ്ക്രിപ്റ്റും ഫയലും സ്ഥാപിക്കേണ്ടതുണ്ട്. ആവശ്യമെങ്കിൽ നിങ്ങൾ yum അല്ലെങ്കിൽ apt ഉപയോഗിച്ച് \pinentry-gui ഇൻസ്റ്റാൾ ചെയ്യേണ്ടതുണ്ട്.
yum install pinentry-gui apt-get install pinentry-gui
Encrypt.sh എന്ന പേരിൽ ഒരു ഫയൽ ക്രീറ്റ് ചെയ്ത് ഇനിപ്പറയുന്ന സ്ക്രിപ്റ്റ് സ്ഥാപിക്കുക, അത് എക്സിക്യൂട്ടബിൾ ആക്കി കാണിച്ചിരിക്കുന്നതുപോലെ പ്രവർത്തിപ്പിക്കുക.
#!/bin/bash echo "Welcome, I am ready to encrypt a file/folder for you" echo "currently I have a limitation, Place me to thh same folder, where a file to be encrypted is present" echo "Enter the Exact File Name with extension" read file; gpg -c $file echo "I have encrypted the file successfully..." echo "Now I will be removing the original file" rm -rf $file
സാമ്പിൾ ഔട്ട്പുട്ട്
chmod 755 Encrypt.sh ./Encrypt.sh Welcome, I am ready to encrypt a file/folder for you currently I have a limitation, Place me to the same folder, where a file to be encrypted is present Enter the Exact File Name with extension package.xml ┌─────────────────────────────────────────────────────┐ │ Enter passphrase │ │ │ │ │ │ Passphrase *******_________________________________ │ │ │ │ <OK> <Cancel> │ └─────────────────────────────────────────────────────┘ Please re-enter this passphrase ┌─────────────────────────────────────────────────────┐ │ Please re-enter this passphrase │ │ │ │ Passphrase ********________________________________ │ │ │ │ <OK> <Cancel> │ └─────────────────────────────────────────────────────┘ I have encrypted the file successfully... Now I will be removing the original file </pre>
gpg -c : ഇത് ഒരു പാസ്uകീ അല്ലെങ്കിൽ പാസ്uവേഡ് ഉപയോഗിച്ച് നിങ്ങളുടെ ഫയലിനെ എൻക്രിപ്റ്റ് ചെയ്യും. ഈ പഠന പ്രക്രിയയിൽ, യഥാർത്ഥ പഠന പ്രക്രിയ വളരെ എളുപ്പമാകുമെന്ന് നിങ്ങൾ ഒരിക്കലും കരുതിയിരിക്കില്ല. അപ്പോൾ ഒരു ഫയൽ എൻക്രിപ്റ്റ് ചെയ്ത ശേഷം നിങ്ങൾക്ക് എന്താണ് വേണ്ടത്? സ്പഷ്ടമായി! ഫയൽ ഡീക്രിപ്റ്റ് ചെയ്യുന്നു. ഞാൻ നിങ്ങളെ ആഗ്രഹിക്കുന്നു - പഠിതാവ്, വായനക്കാരൻ സ്വയം ഡീക്രിപ്ഷൻ സ്ക്രിപ്റ്റ് എഴുതണം, വിഷമിക്കേണ്ട, ഞാൻ നിങ്ങളെ മധ്യത്തിൽ ഉപേക്ഷിക്കുന്നില്ല, ഈ ലേഖനത്തിൽ നിന്ന് നിങ്ങൾ എന്തെങ്കിലും നേടണമെന്ന് ഞാൻ ആഗ്രഹിക്കുന്നു.
ശ്രദ്ധിക്കുക: gpg -d filename.gpg > ഫയലിന്റെ പേര് നിങ്ങളുടെ ഡീക്രിപ്ഷൻ സ്ക്രിപ്റ്റിൽ നടപ്പിലാക്കേണ്ടതുണ്ട്. വിജയകരമാണെങ്കിൽ നിങ്ങളുടെ സ്uക്രിപ്റ്റ് കമന്റിൽ പോസ്റ്റ് ചെയ്യാം, ഇല്ലെങ്കിൽ നിങ്ങൾക്കത് എഴുതാൻ എന്നോട് ആവശ്യപ്പെടാം.
സ്ക്രിപ്റ്റ് 4: സെർവർ ഉപയോഗം പരിശോധിക്കുന്നു
സെർവർ വിനിയോഗം പരിശോധിക്കുന്നത് ഒരു അഡ്മിനിസ്ട്രേറ്ററുടെ പ്രധാന കടമകളിലൊന്നാണ്, കൂടാതെ ദൈനംദിന ജോലികൾ എങ്ങനെ യാന്ത്രികമാക്കാമെന്ന് അറിയുന്ന ഒരാളാണ് നല്ല അഡ്മിനിസ്ട്രേറ്റർ. നിങ്ങളുടെ സെർവറിനെക്കുറിച്ച് അത്തരം നിരവധി വിവരങ്ങൾ നൽകുന്ന സ്ക്രിപ്റ്റ് ചുവടെയുണ്ട്. അത് സ്വയം പരിശോധിക്കുക.
#!/bin/bash date; echo "uptime:" uptime echo "Currently connected:" w echo "--------------------" echo "Last logins:" last -a |head -3 echo "--------------------" echo "Disk and memory usage:" df -h | xargs | awk '{print "Free/total disk: " $11 " / " $9}' free -m | xargs | awk '{print "Free/total memory: " $17 " / " $8 " MB"}' echo "--------------------" start_log=`head -1 /var/log/messages |cut -c 1-12` oom=`grep -ci kill /var/log/messages` echo -n "OOM errors since $start_log :" $oom echo "" echo "--------------------" echo "Utilization and most expensive processes:" top -b |head -3 echo top -b |head -10 |tail -4 echo "--------------------" echo "Open TCP ports:" nmap -p- -T4 127.0.0.1 echo "--------------------" echo "Current connections:" ss -s echo "--------------------" echo "processes:" ps auxf --width=200 echo "--------------------" echo "vmstat:" vmstat 1 5
chmod 755 Server-Health.sh ./Server-Health.sh Tue Jul 16 22:01:06 IST 2013 uptime: 22:01:06 up 174 days, 4:42, 1 user, load average: 0.36, 0.25, 0.18 Currently connected: 22:01:06 up 174 days, 4:42, 1 user, load average: 0.36, 0.25, 0.18 USER TTY FROM [email IDLE JCPU PCPU WHAT tecmint pts/0 116.72.134.162 21:48 0.00s 0.03s 0.03s sshd: tecmint [priv] -------------------- Last logins: tecmint pts/0 Tue Jul 16 21:48 still logged in 116.72.134.162 tecmint pts/0 Tue Jul 16 21:24 - 21:43 (00:19) 116.72.134.162 -------------------- Disk and memory usage: Free/total disk: 292G / 457G Free/total memory: 3510 / 3838 MB -------------------- OOM errors since Jul 14 03:37 : 0 -------------------- Utilization and most expensive processes: top - 22:01:07 up 174 days, 4:42, 1 user, load average: 0.36, 0.25, 0.18 Tasks: 149 total, 1 running, 148 sleeping, 0 stopped, 0 zombie Cpu(s): 0.1%us, 0.0%sy, 0.0%ni, 99.3%id, 0.6%wa, 0.0%hi, 0.0%si, 0.0%st PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1 root 20 0 3788 1128 932 S 0.0 0.0 0:32.94 init 2 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd 3 root RT 0 0 0 0 S 0.0 0.0 0:14.07 migration/0
ശ്രദ്ധിക്കുക: ടെർമിനലിൽ തന്നെ ഔട്ട്uപുട്ട് നൽകുന്ന സ്uക്രിപ്റ്റ് ഞാൻ നിങ്ങൾക്ക് നൽകിയിട്ടുണ്ട്, ഭാവിയിലെ റഫറൻസിനായി ഒരു ഫയലിൽ ഔട്ട്uപുട്ട് എങ്ങനെ ലഭിക്കും. റീഡയറക്uട് ഓപ്പറേറ്റർ ഉപയോഗിച്ച് ഇത് നടപ്പിലാക്കുക.
- ‘>‘ : റീഡയറക്ഷൻ ഓപ്പറേറ്റർ ഒരു ഫയൽ സൃഷ്uടിക്ക് കാരണമാകുന്നു, അത് നിലവിലുണ്ടെങ്കിൽ, ഉള്ളടക്കങ്ങൾ തിരുത്തിയെഴുതപ്പെടും.
- ‘>>‘ : നിങ്ങൾ >> ഉപയോഗിക്കുമ്പോൾ, അത് മാറ്റിസ്ഥാപിക്കുന്നതിനുപകരം നിങ്ങൾ വിവരങ്ങൾ ചേർക്കുന്നു.
- '>>', '>' എന്നതുമായി താരതമ്യം ചെയ്യുമ്പോൾ സുരക്ഷിതമാണ്
സ്ക്രിപ്റ്റ് 5: ഡിസ്ക് സ്പേസ് പരിശോധിച്ച് ഒരു ഇമെയിൽ അലേർട്ട് അയയ്ക്കുന്നു
പാർട്ടീഷനിൽ ഡിസ്ക് ഉപയോഗം അനുവദനീയമായതിലും വലുതായിരിക്കുമ്പോൾ ഒരു ഇമെയിൽ ലഭിക്കുന്നത് എങ്ങനെ, ചെറിയ പരിഷ്ക്കരണങ്ങളുള്ള വെബ് അഡ്മിനിസ്ട്രേറ്റർമാർക്കുള്ള ലൈഫ് സേവർ സ്ക്രിപ്റ്റാണിത്.
MAX=95 [email PART=sda1 USE=`df -h |grep $PART | awk '{ print $5 }' | cut -d'%' -f1` if [ $USE -gt $MAX ]; then echo "Percent used: $USE" | mail -s "Running out of disk space" $EMAIL fi
ശ്രദ്ധിക്കുക: നിങ്ങളുടെ ഉപയോക്തൃനാമം ഉപയോഗിച്ച് USER നീക്കം ചെയ്യുക. 'mail' കമാൻഡ് ഉപയോഗിച്ച് നിങ്ങൾക്ക് മെയിൽ പരിശോധിക്കാം.
സ്ക്രിപ്റ്റ് എഴുത്തും പ്രോഗ്രാമിംഗും അതിരുകൾക്കപ്പുറമാണ്, എന്തും എല്ലാം ആവശ്യാനുസരണം നടപ്പിലാക്കാം. ഇപ്പോൾ അത്രയേയുള്ളൂ, എന്റെ അടുത്ത ലേഖനത്തിൽ ഞാൻ നിങ്ങൾക്ക് സ്ക്രിപ്റ്റിംഗിന്റെ ചില വ്യത്യസ്ത രുചികൾ നൽകും. അതുവരെ കൂളായി നിൽക്കൂ, ആസ്വദിക്കൂ.