Professional Documents
Culture Documents
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Commandmementosheet
Itisausefulcompaniontothis presentation. Examplesforthemostuseful commandsaregiveninjustone sheet. Suggestionsforuse Stickthissheetonyourwall,useit asdesktopwallpaper,makeita mousemat,printitonclothing, sliceitintobookmarks... Caution Storeawayfrommice!
Getiton http://freeelectrons.com/docs/commandline
2
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TrainingContents(1)
Shells,filesystemandfilehandling Everythingisafile GNU/Linuxfilesystemstructure Commandlineinterpreters Handlingfilesanddirectories Displaying,scanningandsortingfiles Symbolicandhardlink Fileaccessrights
3
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Trainingcontents(2)
StandardI/O,redirections,pipes Standardinputandoutput,redirectingtofiles Pipes:redirectingstandardoutputtoothercommands Standarderror
4
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TrainingContents(3)
Taskcontrol Fullcontrolontasks Executinginbackground,suspending,resumingandaborting Listofactivetasks Killingprocesses Environmentvariables PATHenvironmentvariables Shellaliases,.bashrcfile
5
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Trainingcontents(4)
Miscellaneous
6
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Unixfilesystem
7
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Everythingisafile
AlmosteverythinginUnixisafile! Regularfiles Directories Directoriesarejustfiles listingasetoffiles Symboliclinks Filesreferringtothename ofanotherfile Devicesandperipherals Readandwritefromdevices aswithregularfiles Pipes Usedtocascadeprograms cat*.log|greperror Sockets Interprocesscommunication
8
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Filenames
FilenamefeaturessincethebeginningofUnix Casesensitive Noobviouslengthlimit Cancontainanycharacter(includingwhitespace,except/). Filetypesstoredinthefile(magicnumbers). Filenameextensionsnotneededandnotinterpreted.Just usedforuserconvenience. Filenameexamples: README .bashrc index.htm index.html WindowsBuglist index.html.old
9
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Filepaths
Apathisasequenceofnesteddirectorieswithafileor directoryattheend,separatedbythe/character Relativepath:documents/fun/microsoft_jokes.html Relativetothecurrentdirectory Absolutepath: /home/bill/bugs/crash9402031614568 /:rootdirectory. Startofabsolutepathsforallfilesonthesystem(evenfor filesonremovabledevicesornetworkshared).
10
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
GNU/Linuxfilesystemstructure(1)
Notimposedbythesystem.Canvaryfromonesystemtothe other,evenbetweentwoGNU/Linuxinstallations! / /bin/ /boot/ /dev/ /etc/ /home/ /lib/ Rootdirectory Basic,essentialsystemcommands Kernelimages,initrdandconfigurationfiles Filesrepresentingdevices /dev/hda:firstIDEharddisk Systemconfigurationfiles Userdirectories Basicsystemsharedlibraries
11
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
GNU/Linuxfilesystemstructure(2)
/lost+found /media /mnt/ filesystems /opt/ /proc/ /root/ /sbin/ /sys/ Corruptfilesthesystemtriedtorecover Mountpointsforremovablemedia: /media/usbdisk,/media/cdrom Mountpointsfortemporarilymounted Specifictoolsinstalledbythesysadmin /usr/local/oftenusedinstead Accesstosysteminformation /proc/cpuinfo,/proc/version... rootuserhomedirectory Administratoronlycommands Systemanddevicecontrols (cpufrequency,devicepower,etc.)
12
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
GNU/Linuxfilesystemstructure(3)
/tmp/ /usr/ /usr/local/ /var/ Temporaryfiles Regularusertools(notessentialtothesystem) /usr/bin/,/usr/lib/,/usr/sbin... Specificsoftwareinstalledbythesysadmin (oftenpreferredto/opt/) Datausedbythesystemorsystemservers /var/log/,/var/spool/mail(incoming mail),/var/spool/lpd(printjobs)...
13
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Shellsandfilehandling
14
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Commandlineinterpreters
Shells:toolstoexecuteusercommands Calledshellsbecausetheyhidethedetailsonthe underlyingoperatingsystemundertheshell'ssurface. Commandsareinputinatextterminal,eitherawindowina graphicalenvironmentoratextonlyconsole. Resultsarealsodisplayedontheterminal.Nographicsare neededatall. Shellscanbescripted:providealltheresourcestowrite complexprograms(variable,conditionals,iterations...)
15
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Wellknownshells
Mostfamousandpopularshells sh:TheBourneshell(obsolete) Traditional,basicshellfoundonUnixsystems,bySteveBourne. csh:TheCshell(obsolete) OncepopularshellwithaClikesyntax tcsh:TheTCshell(stillverypopular) ACshellcompatibleimplementationwithevolvedfeatures (commandcompletion,historyeditingandmore...) bash:TheBourneAgainshell(mostpopular) Animprovedimplementationofshwithlotsofaddedfeatures too.
16
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
fish:agreatnewshell
TheFriendlyInteractiveSHell http://www.fishshell.org/ Standardfeatures:history,commandandfilecompletion... Brandnewfeatures:commandoptioncompletion,command completionwithshortdescription,syntaxhighlighting.. Easiertoanyopenfiles:openbuiltincommand. Muchsimplerandconsistentsyntax(notPOSIXcompliant) Makesiteasiertocreateshellscripts. Commandlinebeginnerscanlearnmuchfaster! Evenexperiencedusersshouldfindthisshellveryconvenient.
17
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
lscommand
Liststhefilesinthecurrentdirectory,inalphanumericorder, exceptfilesstartingwiththe.character. lsa(all) Listsallthefiles(including.* files) lsl(long) Longlisting(type,date,size, owner,permissions) lst(time) Liststhemostrecentfilesfirst lsS(size) Liststhebiggestfilesfirst lsr(reverse) Reversesthesortorder lsltr(optionscanbe combined) Longlisting,mostrecentfiles attheend
18
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Filenamepatternsubstitutions
Betterintroducedbyexamples! ls*txt Theshellfirstreplaces*txtbyallthefileanddirectory namesendingbytxt(including.txt),exceptthose startingwith.,andthenexecutesthelscommandline. lsd.* Listsallthefilesanddirectoriesstartingwith. dtellslsnottodisplaythecontentsofdirectories. cat?.log Displaysallthefileswhichnamesstartby1characterand endby.log
19
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Specialdirectories(1)
./ Thecurrentdirectory.Usefulforcommandstakingadirectory argument.Alsosometimesusefultoruncommandsinthe currentdirectory(seelater). So./readme.txtandreadme.txtareequivalent. ../ Theparent(enclosing)directory.Alwaysbelongstothe. directory(seelsa).Onlyreferencetotheparentdirectory. Typicalusage: cd..
20
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Specialdirectories(2)
~/ Notaspecialdirectoryindeed.Shellsjustsubstituteitbythe homedirectoryofthecurrentuser. Cannotbeusedinmostprograms,asitisnotareal directory. ~sydney/ Similarly,substitutedbyshellsbythehomedirectoryofthe sydneyuser.
21
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thecdandpwdcommands
cd<dir> Changesthecurrentdirectoryto<dir>. cd Getsbacktothepreviouscurrentdirectory. pwd Displaysthecurrentdirectory("workingdirectory").
22
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thecpcommand
cp<source_file><target_file> Copiesthesourcefiletothetarget. cpfile1file2file3...dir Copiesthefilestothetargetdirectory(lastargument). cpi(interactive) Asksforuserconfirmationifthetargetfilealreadyexists cpr<source_dir><target_dir>(recursive) Copiesthewholedirectory.
23
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
mvandrmcommands
mv<old_name><new_name> (move) Renamesthegivenfileordirectory. mvi(interactive) Ifthenewfilealreadyexits,asksforuserconfirm rmfile1file2file3... (remove) Removesthegivenfiles. rmi(interactive) Alwaysaskforuserconfirm. rmrdir1dir2dir3(recursive) Removesthegivendirectorieswithalltheircontents.
24
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Creatingandremovingdirectories
mkdirdir1dir2dir3...(makedir) Createsdirectorieswiththegivennames. rmdirdir1dir2dir3...(removedir) Removesthegivendirectories Safe:onlyworkswhendirectoriesandempty. Alternative:rmr(doesn'tneedemptydirectories).
25
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Displayingfilecontents
Severalwaysofdisplayingthecontentsoffiles. catfile1file2file3...(concatenate) Concatenatesandoutputsthecontentsofthegivenfiles. morefile1file2file3... Aftereachpage,askstheusertohitakeytocontinue. Canalsojumptothefirstoccurrenceofakeyword (/command). lessfile1file2file3... Doesmorethanmorewithless. Doesn'treadthewholefilebeforestarting. Supportsbackwardmovementinthefile(?command).
26
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Theheadandtailcommands
head[<n>]<file> Displaysthefirst<n>lines(or10bydefault)ofthegivenfile. Doesn'thavetoopenthewholefiletodothis! tail[<n>]<file> Displaysthelast<n>lines(or10bydefault)ofthegivenfile. NoneedtoloadthewholefileinRAM!Veryusefulforhugefiles. tailf<file>(follow) Displaysthelast10linesofthegivenfileandcontinuestodisplaynew lineswhentheyareappendedtothefile. Veryusefultofollowthechangesinalogfile,forexample. Examples headwindows_bugs.txt tailfoutlook_vulnerabilities.txt
27
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thegrepcommand
grep<pattern><files> Scansthegivenfilesanddisplaysthelineswhichmatchthegiven pattern. greperror*.log Displaysallthelinescontainingerrorinthe*.logfiles grepierror*.log Same,butcaseinsensitive greprierror. Same,butrecursivelyinallthefilesin.anditssubdirectories grepvinfo*.log Outputsallthelinesinthefilesexceptthosecontaininginfo.
28
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thesortcommand
sort<file> Sortsthelinesinthegivenfileincharacterorderand outputsthem. sortr<file> Same,butinreverseorder. sortru<file> u:unique.Same,butjustoutputsidenticallinesonce. Morepossibilitiesdescribedlater!
29
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thesedcommand
sedisaStreamEDitor Itparsestextfilesandimplementsaprogramminglanguageto applytransformationsonthetext. Oneofthemostcommonusageofsedistextreplacement,which reliesonregularexpressions
sede's/abc/def/'testfilewillreplaceeverystringabc bydefinthefiletestfileanddisplaytheresultonthestandard output. sed's/^[\t]*//'testfilewillremoveanytabulationor spaceatthebeginningofaline
sed's/^|\([^|]*\)|\([^|]*\)|$/\1>\2/'testfile
sed:regularexpressions
RegularexpressionsareusefulinmanyUnixtools,notonlysed. Theyallowtomatchtheinputtextagainstanexpression.
.matchesanycharacter []matchesanycharacterlistedinsidethebrackets [^]matchesanycharacternotlistedinsidethebrackets ^matchesthebeginningoftheline $matchestheendoftheline *matchesthepreviouselementzeroormoretimes,+matchesthe previouselementoneormoretimes,?matchestheprevious elementzerooronetime \(\)definesasubexpressionthatcanbelaterrecalledbyusing \n,wherenisthenumberofthesubexpressionintheregular expression Moreathttp://www.regularexpressions.info/
31
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Symboliclinks
Asymboliclinkisaspecialfilewhichisjustareferencetothe nameofanotherone(fileordirectory): Usefultoreducediskusageandcomplexitywhen2fileshave thesamecontent. Example:
anakin_skywalker_biography>darth_vador_biography
32
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Creatingsymboliclinks
Tocreateasymboliclink(sameorderasincp): lnsfile_namelink_name Tocreatealinkwithtoafileinanotherdirectory,withthe samename: lns../README.txt Tocreatemultiplelinksatonceinagivendirectory: lnsfile1file2file3...dir Toremovealink: rmlink_name Ofcourse,thisdoesn'tremovethelinkedfile!
33
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Hardlinks
Thedefaultbehaviorforlnistocreatehardlinks Ahardlinktoafileisaregularfilewithexactlythesame physicalcontents Whiletheystillsavespace,hardlinkscan'tbedistinguished fromtheoriginalfiles. Ifyouremovetheoriginalfile,thereisnoimpactonthehard linkcontents. Thecontentsareremovedwhentherearenomorefiles (hardlinks)tothem.
34
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Filesnamesandinodes
Makeshardandsymbolic(soft)linkseasiertounderstand!
Users Filenameinterface
Softlink Inode
rm
File Inode
Hardlink
rm
35
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Commanddocumentation
36
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Commandhelp
SomeUnixcommandsandmostGNU/Linuxcommands offeratleastonehelpargument: h (ismostlyusedtointroduce1characteroptions) help (isalwaysusedtointroducethecorresponding longoptionname,whichmakesscriptseasierto understand) Youalsooftengetashortsummaryofoptionswhenyou inputaninvalidargument.
37
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Manualpages
man<keyword> Displaysoneorseveralmanualpagesfor<keyword> manman MostavailablemanualpagesareaboutUnixcommands,but somearealsoaboutCfunctions,headersordatastructures, orevenaboutsystemconfigurationfiles! manstdio.h manfstab(for/etc/fstab) Manualpagefilesarelookedforinthedirectoriesspecifiedby theMANPATHenvironmentvariable.
38
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Infopages
InGNU,manpagesarebeingreplacedbyinfopages. Somemanualpageseventelltorefertoinfopages instead. info<command>
infofeatures:
Documentationstructuredinsections(nodes)andsubsections (subnodes) Possibilitytonavigateinthisstructure:top,next,prev,up InfopagesgeneratedfromthesametexinfosourceastheHTML documentationpages
39
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
SearchingtheInternetforresources(2)
Lookingfordocumentation Lookfor<tool>or<tool>pagetofindthetoolorproject homepageandthenfindthelatestdocumentation resources. Lookfor<tool>documentationor<tool>manualin yourfavoritesearchengine. Lookingforgenerictechnicalinformation WikiPedia:http://wikipedia.org Lotsofusefuldefinitionsincomputerscience.Areal encyclopedia!Opentoanyone'scontributions.
40
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
SearchingtheInternetforresources(1)
Investigatingissues Mostforumsandmailinglistarchivesarepublic,andare indexedonaveryfrequentbasisbyGoogle. Ifyouinvestigateanerrormessage,copyitverbatiminthe searchform,enclosedindoublequotes(errormessage). Lotsofchancesthatsomebodyelsealreadyfacedthe sameissue. Don'tforgettouseGoogleGroups: http://groups.google.com/ Thissiteindexesmorethan20yearsofnewsgroups messages.
41
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Usersandpermissions
42
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Fileaccessrights
Uselsltocheckfileaccessrights
3typesofaccessrights Readaccess(r) Writeaccess(w) Executerights(x) 3typesofaccesslevels User(u):fortheownerofthe file Group(g):eachfilealsohas agroupattribute, correspondingtoagivenlist ofusers Others(o):forallotherusers
43
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Accessrightconstraints
xissufficienttoexecutebinaries Bothxandrandrequiredforshellscripts. Bothrandxpermissionsneededinpracticefordirectories: rtolistthecontents,xtoaccessthecontents. Youcan'trename,remove,copyfilesinadirectoryifyou don'thavewaccesstothisdirectory. Ifyouhavewaccesstoadirectory,youCANremoveafile evenifyoudon'thavewriteaccesstothisfile(remember thatadirectoryisjustafiledescribingalistoffiles).This evenletsyoumodify(remove+recreate)afileevenwithout waccesstoit.
44
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Accessrightsexamples
rwrr Readableandwritableforfileowner,onlyreadableforothers rwr Readableandwritableforfileowner,onlyreadableforusers belongingtothefilegroup. drwx Directoryonlyaccessiblebyitsowner rx Fileexecutablebyothersbutneitherbyyourfriendsnorby yourself.Niceprotectionsforatrap...
45
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
chmod:changingpermissions
chmod<permissions><files> 2formatsforpermissions: Octalformat(abc): a,b,c=r*4+w*2+x(r,w,x:booleans) Example:chmod644<file> (rwforu,rforgando) Orsymbolicformat.Easytounderstandbyexamples: chmodgo+r:addreadpermissionstogroupand others. chmoduw:removewritepermissionsfromuser. chmodax:(a:all)removeexecutepermissionfromall.
46
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Morechmod(1)
chmodRa+rXlinux/ Makeslinuxandeverythinginitavailableto everyone! R:applychangesrecursively X:x,butonlyfordirectoriesandfilesalready executable Veryusefultoopenrecursiveaccesstodirectories, withoutaddingexecutionrightstoallfiles.
47
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Morechmod(2)
chmoda+t/tmp t:(sticky).Specialpermissionfordirectories,allowing onlythedirectoryandfileownertodeleteafileina directory. Usefulfordirectorieswithwriteaccesstoanyone, like/tmp. Displayedbylslwithatcharacter.
48
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Fileownership
Particularlyusefulin(embedded)systemdevelopment whenyoucreatefilesforanothersystem. chownRsco/home/linux/src(R:recursive) Makesuserscothenewownerofallthefilesin /home/linux/src. chgrpRempire/home/askywalker Makesempirethenewgroupofeverythingin /home/askywalker. chownRborg:aliensusss_entreprise/ chowncanbeusedtochangetheownerandgroupatthesame time.
49
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Bewareofthedarksideofroot
rootuserprivilegesareonlyneededforveryspecific taskswithsecurityrisks:mounting,creatingdevice files,loadingdrivers,startingnetworking, changingfileownership,packageupgrades... Evenifyouhavetherootpassword,yourregular accountshouldbesufficientfor99.9%ofyourtasks (unlessyouareasystemadministrator). Inatrainingsession,itisacceptabletouseroot. Inreallife,youmaynotevenhaveaccesstothis account,orputyoursystemsanddataatriskifyou do.
50
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Usingtherootaccount
Incaseyoureallywanttouseroot... Ifyouhavetherootpassword: su(switchuser) Inmoderndistributions,thesudocommandgivesyouaccesstosome rootprivilegeswithyourownuserpassword. Example:sudomount/dev/hda4/home
51
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
StandardI/O,redirections,pipes
52
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Standardoutput
Moreaboutcommandoutput Allthecommandsoutputtingtextonyourterminaldoitbywriting totheirstandardoutput. Standardoutputcanbewritten(redirected)toafileusingthe> symbol Standardoutputcanbeappendedtoanexistingfileusingthe>> symbol
53
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Standardoutputredirectionexamples
ls~saddam/*>~gwb/weapons_mass_destruction.txt catobiwan_kenobi.txt>starwars_biographies.txt cathan_solo.txt>>starwars_biographies.txt echoREADME:Nosuchfileordirectory>README Usefulwayofcreatingafilewithoutatexteditor. NiceUnixjoketoointhiscase.
54
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Standardinput
Moreaboutcommandinput Lotsofcommands,whennotgiveninputarguments,can taketheirinputfromstandardinput. sort windows linux [Ctrl][D] linux windows sorttakesitsinputfrom thestandardinput:inthiscase, whatyoutypeintheterminal (endedby[Ctrl][D])
sort<participants.txt Thestandardinputofsortistakenfromthegivenfile.
55
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Pipes
Unixpipesareveryusefultoredirectthestandardoutputofa commandtothestandardinputofanotherone. Examples
cat*.log|grepierror|sort greprierror.|grepvignored|sortu\ >serious_errors.log cat/home/*/homework.txt|grepmark|more
ThisoneofthemostpowerfulfeaturesinUnixshells!
56
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Theteecommand
tee[a]file Theteecommandcanbeusedtosendstandard outputtothescreenandtoafilesimultaneously. make|teebuild.log Runsthemakecommandandstoresitsoutputto build.log. makeinstall|teeabuild.log Runsthemakeinstallcommandandappendsits outputtobuild.log.
57
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Standarderror
Errormessagesareusuallyoutput(iftheprogramiswell written)tostandarderrorinsteadofstandardoutput. Standarderrorcanberedirectedthrough2>or2>> Example: catf1f2nofile>newfile2>errfile Note:1isthedescriptorforstandardoutput,so1>isequivalentto >. Canredirectbothstandardoutputandstandarderrortothe samefileusing&>: catf1f2nofile&>wholefile
58
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Theyescommand
Usefultofillstandardinputwithalwaysthesamestring. yes<string>|<command> Keepsfillingthestandardinputof<command>with <string>(ybydefault). Examples yes|rmrdir/ bank>yesno|credit_applicant yes""|makeoldconfig (equivalenttohitting[Enter]toacceptalldefaultsettings)
59
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Specialdevices(1)
Devicefileswithaspecialbehaviororcontents /dev/null Thedatasink!Discardsalldatawrittentothisfile. Usefultogetridofunwantedoutput,typicallylog information: mplayerblack_adder_4th.avi&>/dev/null /dev/zero Readsfromthisfilealwaysreturn\0characters Usefultocreateafilefilledwithzeros: ddif=/dev/zeroof=disk.imgbs=1kcount=2048 Seemannullormanzerofordetails
60
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Specialdevices(2)
/dev/random Returnsrandombyteswhenread.Mainlyusedby cryptographicprograms.Usesinterruptsfromsomedevice driversassourcesoftruerandomness(entropy). Readscanbeblockeduntilenoughentropyisgathered. /dev/urandom Forprogramsforwhichpseudorandomnumbersarefine. Alwaysgeneratesrandombytes,evenifnotenoughentropy isavailable(inwhichcaseitispossible,thoughstilldifficult, topredictfuturebytesequencesfrompastones). Seemanrandomfordetails.
61
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Specialdevices(3)
/dev/full Mimicsafulldevice. Usefultocheckthatyourapplicationproperlyhandles thiskindofsituation. Seemanfullfordetails.
62
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Taskcontrol
63
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Fullcontrolontasks
Sincethebeginning,Unixsupportstruepreemptivemultitasking. Abilitytorunmanytasksinparallel,andabortthemevenifthey corrupttheirownstateanddata. Abilitytochoosewhichprogramsyourun. Abilitytochoosewhichinputyourprogramstakes,andwhere theiroutputgoes.
64
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Processes
EverythinginUnixisafile EverythinginUnixthatisnotafileisaprocess Processes Instancesofarunningprograms Severalinstancesofthesameprogramcanrunatthesametime Dataassociatedtoprocesses: Openfiles,allocatedmemory,stack,processid,parent,priority, state...
65
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Runningjobsinbackground
Sameusagethroughoutalltheshells Useful
Forcommandlinejobswhichoutputcanbeexaminedlater, especiallyfortimeconsumingones. Tostartgraphicalapplicationsfromthecommandlineandthen continuewiththemouse.
Startingatask:add&attheendofyourline: find_prince_charmingcutecleverrich&
66
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Backgroundjobcontrol
jobs Returnsthelistofbackgroundjobsfromthesameshell
[1]Running~/bin/find_meaning_of_lifewithoutgod& [2]+Runningmakemistakes&
67
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Jobcontrolexample
>jobs [1]Running~/bin/find_meaning_of_lifewithoutgod& [2]+Runningmakemistakes& >fg makemistakes >[Ctrl]Z [2]+Stoppedmakemistakes >bg [2]+makemistakes& >kill%1 [1]+Terminated~/bin/find_meaning_of_lifewithoutgod
68
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Listingallprocesses
...whatevershell,scriptorprocesstheyarestartedfrom psux Listsalltheprocessesbelongingtothecurrentuser psaux(Note:psedfonSystemVsystems) Listsalltheprocessesrunningonthesystem
psaux|grepbart|grepbash USERPID%CPU%MEMVSZRSSTTYSTATSTARTTIMECOMMAND bart30390.00.259161380pts/2S14:350:00/bin/bash bart31340.00.253881380pts/3S14:360:00/bin/bash bart31900.00.263681360pts/4S14:370:00/bin/bash bart34160.00.000pts/2RW15:070:00[bash] PID: VSZ: RSS: TTY: STAT: Processid Virtualprocesssize(code+data+stack) Processresidentsize:numberofKBcurrentlyinRAM Terminal Status:R(Runnable),S(Sleep),W(paging),Z(Zombie)...
69
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Liveprocessactivity
topDisplaysmostimportantprocesses,sortedbycpu percentage
top15:44:33up1:11,5users,loadaverage:0.98,0.61,0.59 Tasks:81total,5running,76sleeping,0stopped,0zombie Cpu(s):92.7%us,5.3%sy,0.0%ni,0.0%id,1.7%wa,0.3%hi,0.0%si Mem:515344ktotal,512384kused,2960kfree,20464kbuffers Swap:1044184ktotal,0kused,1044184kfree,277660kcached PIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+COMMAND 3809jdoe250625639321312R93.80.80:21.49bunzip2 2769root160157m80m90mR2.716.05:21.01X 3006jdoe1503092815m27mS0.33.00:22.40kdeinit 3008jdoe16056248924468S0.30.20:06.59autorun 3034jdoe1502676412m24mS0.32.50:12.68kscd 3810jdoe16028929161620R0.30.20:00.06top
Killingprocesses(1)
kill<pids> Sendsanabortsignaltothegivenprocesses.Lets processessavedataandexitbythemselves.Shouldbeused first.Example: kill3039313431903416 kill9<pids> Sendsanimmediateterminationsignal.Thesystemitself terminatestheprocesses.Usefulwhenaprocessisreally stuck(doesn'tanswertokill1). kill91 Killsalltheprocessesofthecurrentuser.1:meansall processes.
71
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Killingprocesses(2)
killall[<signal>]<command> Killsallthejobsrunning<command>.Example: killallbash xkill Letsyoukillagraphicalapplicationbyclickingonit! Veryquick!Convenientwhenyoudon'tknowtheapplication commandname.
72
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Recoveringfromstuckgraphics
Ifyourgraphicalsessionisstuckandyoucannolongertypeinyour terminals,don'treboot! Itisverylikelythatyoursystemisstillfine.Trytoaccessatext consolebypressingthe[Ctrl][Alt][F1]keys (or[F2],[F3]formoretextconsoles) Inthetextconsole,youcantrytokilltheguiltyapplication. Oncethisisdone,youcangobacktothegraphicsessionby pressing[Ctrl][Alt][F5]or[Ctrl][Alt][F7](dependingon yourdistribution) Ifyoucan'tidentifythestuckprogram,youcanalsokillallyour processes:kill91 Youarethenbroughtbacktotheloginscreen.
73
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Sequentialcommands
Cantypethenextcommandinyourterminalevenwhen thecurrentoneisnotover. Canseparatecommandswiththe;symbol: echoIlovethee;sleep10;echonot Conditionals:use||(or)or&&(and): moreGod||echoSorry,Goddoesn'texist Runsechoonlyifthefirstcommandfails ls~sd6&&cat~sd6/*>~sydney/recipes.txt Onlycatsthedirectorycontentsifthelscommandsucceeds (meansreadaccess).
74
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Quoting(1)
Double(")quotescanbeusedtopreventtheshellfrom interpretingspacesasargumentseparators,aswellasto preventfilenamepatternexpansion. >echo"HelloWorld" HelloWorld >echo"Youareloggedas$USER" Youareloggedasbgates >echo*.log find_prince_charming.logcosmetic_buys.log >echo"*.log" *.log
75
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Quoting(2)
Singlequotesbringasimilarfunctionality,butwhatisbetween quotesisneversubstituted >echo'Youareloggedas$USER' Youareloggedas$USER Backquotes(`)canbeusedtocallacommandwithinanother >cd/lib/modules/`unamer`;pwd /lib/modules/2.6.91.6_FC2 Backquotescanbeusedwithindoublequotes >echo"YouareusingLinux`unamer`" YouareusingLinux2.6.91.6_FC2
76
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Measuringelapsedtime
timefind_expensive_housingnear <...commandoutput...> real0m2.304s(actualelapsedtime) user0m0.449s(CPUtimerunningprogramcode) sys0m0.106s(CPUtimerunningsystemcalls) real=user+sys+waiting waiting=I/Owaitingtime+idletime(runningothertasks)
77
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Environmentvariables
Shellslettheuserdefinevariables. Theycanbereusedinshellcommands. Convention:lowercasenames Youcanalsodefineenvironmentvariables: variablesthatarealsovisiblewithinscriptsor executablescalledfromtheshell. Convention:uppercasenames. env Listsalldefinedenvironmentvariablesandtheir value.
78
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Shellvariablesexamples
Shellvariables(bash) projdir=/home/marshall/coolstuff lsla$projdir;cd$projdir Environmentvariables(bash) cd$HOME exportDEBUG=1 ./find_extraterrestrial_life (displaysdebuginformationifDEBUGisset)
79
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Mainstandardenvironmentvariables
Usedbylotsofapplications!
LD_LIBRARY_PATH MANPATH
Manualpagesearchpath
PATH
Sharedlibrarysearchpath
DISPLAY
Commandsearchpath
PRINTER
ScreenidtodisplayX (graphical)applicationson.
EDITOR
Defaultprintername
SHELL
Defaulteditor(vi,emacs...)
HOME
Currentshellname
TERM
Currentuserhome directory
HOSTNAME
Currentterminaltype
USER
Nameofthelocalmachine
Currentusername
80
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
PATHenvironmentvariables
PATH Specifiestheshellsearchorderforcommands / home/acox/bin:/usr/local/bin:/usr/kerberos/bin: /usr/bin:/bin:/usr/X11R6/bin:/bin:/usr/bin LD_LIBRARY_PATH Specifiesthesharedlibrary(binarycodelibrariessharedby applications,liketheClibrary)searchorderforld /usr/local/lib:/usr/lib:/lib:/usr/X11R6/lib MANPATH Specifiesthesearchorderformanualpages /usr/local/man:/usr/share/man
81
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
PATHusagewarning
Itisstronglyrecommendednottohavethe.directoryinyour PATHenvironmentvariable,inparticularnotatthebeginning: Acrackercouldplaceamaliciouslsfileinyourdirectories.It wouldgetexecutedwhenyourunlsinthisdirectoryandcould donaughtythingstoyourdata. Ifyouhaveanexecutablefilecalledtestinadirectory,thiswill overridethedefaulttestprogramandsomescriptswillstop workingproperly. Eachtimeyoucdtoanewdirectory,theshellwillwastetime updatingitslistofavailablecommands. Callyourlocalcommandsasfollows:./test
82
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Alias
Shellsletyoudefinecommandaliases:shortcutsforcommandsyou useveryfrequently. Examples
aliasls='lsla' Usefultoalwaysruncommandswithdefaultarguments. aliasrm='rmi' Usefultomakermalwaysaskforconfirmation. aliasfrd='find_rambaldi_deviceasaprisky' Usefultoreplaceverylongandfrequentcommands. aliascia='./home/sydney/env/cia.sh' Usefultosetanenvironmentinaquickway (.isashellcommandtoexecutethecontentofashellscript).
83
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thewhichcommand
Beforeyourunacommand,whichtellsyouwhereitisfound bash>whichls aliasls='lscolor=tty' /bin/ls tcsh>whichls ls:aliasedtolscolor=tty bash>whichalias /usr/bin/which:noaliasin (/usr/local/bin:/usr/bin:/bin:/usr/X11R6/bin) tcsh>whichalias alias:shellbuiltincommand.
84
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
~/.bashrcfile
~/.bashrc
Shellscriptreadeachtimeabashshellisstarted Youcanusethisfiletodefine Yourdefaultenvironmentvariables(PATH,EDITOR...). Youraliases. Yourprompt(seethebashmanualfordetails). Agreetingmessage.
85
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Commandediting
Youcanusetheleftandrightarrowkeystomovethecursorin thecurrentcommand. Youcanuse[Ctrl][a]togotothebeginningoftheline,and [Ctrl][e]togototheend. Youcanusetheupanddownarrowstoselectearliercommands. Youcanuse[Ctrl][r]tosearchinsidethehistoryofprevious commands.
86
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Commandhistory(1)
history Displaysthelatestcommandsthatyouranandtheir number.Youcancopyandpastecommandstrings. Youcanrecallthelatestcommand: !! Youcanrecallacommandbyitsnumber !1003 Youcanrecallthelatestcommandmatchingastarting string: !cat
87
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Commandhistory(2)
Youcanmakesubstitutionsonthelatestcommand: ^more^less Youcanrunanothercommandwiththesamearguments: more!*
88
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Miscellaneous
Texteditors
89
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Texteditors
Graphicaltexteditors Fineformostneeds nedit Emacs,Xemacs Kate,Gedit Textonlytexteditors Oftenneededforsysadminsandgreatforpowerusers vi,vim nano
90
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thenedittexteditor
http://www.nedit.org/ Besttexteditorfornonvioremacsexperts Featurehighlights:
Veryeasytextselectionandmoving Syntaxhighlightingformostlanguagesandformats.Canbe tailoredforyourownlogfiles,tohighlightparticularerrorsand warnings. Easytocustomizethroughmenus
Notinstalledbydefaultbyalldistributions
91
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
neditscreenshot
92
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Emacs/Xemacs
EmacsandXemacsarepretty similar(uptoyourpreference) Extremelypowerfultexteditor features Greatforpowerusers Lessergonomicthannedit Nonstandardshortcuts Muchmorethanatexteditor (games,email,shell,browser). Somepowercommandshavetobe learnt.
93
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Kateandgedit
Kateisapowerfultexteditor dedicatedtoprogramming activities,forKDE
http://kate.kde.org
Geditisatexteditorforthe Gnomeenvironment
http://projects.gnome.org/gedit/
94
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
vi
TextmodetexteditoravailableinallUnixsystems.Created beforecomputerswithmiceappeared. Difficulttolearnforbeginnersusedtographicaltexteditors. Veryproductiveforpowerusers. Oftencan'tbereplacedtoeditfilesinsystemadministration orinEmbeddedSystems,whenyoujusthaveatext console.
95
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
vimviimproved
viimplementationnowfoundinmostGNU/ Linuxhostsystems Implementslotsoffeaturesavailableinmodern editors:syntaxhighlighting,commandhistory, help,unlimitedundoandmuchmuchmore. Coolfeatureexample:candirectlyopen compressedtextfiles. ComeswithaGTKgraphicalinterface(gvim) Unfortunately,notfreesoftware(becauseofa smallrestrictioninfreedomtomakechanges)
96
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
vibasiccommands
Thoughviisextremely powerful,itsmain30 commandsareeasytolearn andaresufficientfor99%of everyone'sneeds! Youcanalsotakethequick tutorialbyrunning vimtutor. Getourvimementosheetifyoudidn'tgetitwiththiscourse: http://freeelectrons.com/docs/commandline
97
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
GNUnano
http://www.nanoeditor.org/ Anothersmalltextonly,mousefreetexteditor. AnenhancedPicoclone(nonfreeeditorinPine) Friendlyandeasiertolearnforbeginnersthankstoon screencommandsummaries. Availableinbinarypackagesforseveralplatforms. Analternativetoviinembeddedsystems. However,notavailableasabusyboxbuiltin.
98
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
GNUnanoscreenshot
99
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Miscellaneous
Compressingandarchiving
100
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Measuringdiskusage
Caution:differentfromfilesize!
101
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Measuringdiskspace
dfh<dir> Returnsdiskusageandfreespaceforthefilesystem containingthegivendirectory. Similarly,thehoptiononlyexistsinGNUdf. Example:
>dfh. FilesystemSizeUsedAvailUse%Mountedon /dev/hda59.2G7.1G1.8G81%/
Compressinganddecompressing
Veryusefulforshrinkinghugefilesandsavingspace g[un]zip<file> GNUzipcompressionutility.Creates.gzfiles. Ordinaryperformance(similartoZip). b[un]zip2<file> Morerecentandeffectivecompressionutility. Creates.bz2files.Usually2025%betterthangzip. [un]lzma<file> Muchbettercompressionratiothanbzip2(upto10to20%). Compatiblecommandlineoptions.
103
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Archiving(1)
Usefultobackuporreleaseasetoffileswithin1file tar:originallytapearchive Creatinganarchive: tarcvf<archive><filesordirectories> c:create v:verbose.Usefultofollowarchivingprogress. f:file.Archivecreatedinfile(tapeusedotherwise). Example: tarcvf/backup/home.tar/home bzip2/backup/home.tar
104
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Archiving(2)
Viewingthecontentsofanarchiveorintegritycheck: tartvf<archive> t:test Extractingallthefilesfromanarchive: tarxvf<archive> Extractingjustafewfilesfromanarchive: tarxvf<archive><filesordirectories> Filesordirectoriesaregivenwithpathsrelativetothe archiverootdirectory.
105
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
ExtraoptionsinGNUtar
tar=gtar=GNUtaronGNU/Linux Cancompressanduncompressarchivesonthefly. Usefultoavoidcreatinghugeintermediatefiles Muchsimplertodothanwithtarandbzip2! joption:[un]compressesontheflywithbzip2 zoption:[un]compressesontheflywithgzip lzmaoption:[un]compressesontheflywithlzma Examples(whichonewillyouremember?)
gtarjcvfbills_bugs.tar.bz2bills_bugs tarcvfbills_bugs|bzip2>bills_bugs.tar.bz2
106
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Checkingfileintegrity
Verylowcostsolutiontocheckfileintegrity md5sumFC3i386disk*.iso>MD5SUM ComputesaMD5(MessageDigestAlgorithm5)128bitchecksumofthe givenfiles.Usuallyredirectedtoafile. Exampleoutput: db8c7254beeb4f6b891d1ed3f689b412FC3i386disc1.iso 2c11674cf429fe570445afd9d5ff564eFC3i386disc2.iso f88f6ab5947ca41f3cf31db04487279bFC3i386disc3.iso 6331c00aa3e8c088cc365eeb7ef230eaFC3i386disc4.iso md5sumcMD5SUM CheckstheintegrityofthefilesinMD5SUMbycomparingtheiractualMD5 checksumwiththeiroriginalone.
107
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Miscellaneous
Printing
108
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Unixprinting
Multiuser,multijob,multiclient,multiprinter InUnix/Linux,printingcommandsdon'treallyprint.Theysend jobstoprintingqueues,possiblyonthelocalmachine,on networkprintingserversoronnetworkprinters. Printerindependentsystem: PrintserversonlyacceptjobsinPostScript ortext.Printerdriversontheservertake careoftheconversiontoeachprintersownformat. Robustsystem: Rebootasystem,itwillcontinuetoprintpendingjobs.
109
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Printingcommands
Usefulenvironmentvariable:PRINTER Setsthedefaultprinteronthesystem.Example: exportPRINTER=lp lpr[P<queue>]<files> Sendsthegivenfilestothespecifiedprintingqueue ThefilesmustbeintextorPostScriptformat.Otherwise, youonlyprintgarbage. a2ps[P<queue>]<files> AnytoPostScriptconvertsmanyformatstoPostScriptand sendtheoutputtothespecifiedqueue.Usefulfeatures: severalpages/sheet,pagenumbering,infoframe...
110
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Printjobcontrol
lpq[P<queue>] Listsalltheprintjobsinthegivenordefaultqueue.
lpisnotready RankOwnerJobFile(s)TotalSize 1stasloane84nsa_windows_backdoors.ps60416bytes 2ndamoore85gw_bush_iraq_mistakes.ps65024000bytes
cancel<job#>[<queue>] Removesthegivenjobnumberfromthedefaultqueue.
111
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
UsingPostScriptandPDFfiles
ViewingaPostScriptfile PostScriptviewersexist,buttheirqualityisprettypoor. BetterconverttoPDFwithps2pdf: ps2pdfdecss_algorithm.ps xpdfdecss_algorithm.pdf& PrintingaPDFfile Youdon'tneedtoopenaPDFreader! BetterconverttoPostScriptwithpdf2ps: pdf2psrambaldi_artifacts_for_dummies.pdf lprrambaldi_artifacts_for_dummies.ps
112
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Miscellaneous
Synchronizingfiles
113
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Smartdirectorycopywithrsync
rsync(remotesync)hasbeendesignedtokeepinsync directorieson2machineswithalowbandwidthconnection.
Onlycopiesfilesthathavechanged.Fileswiththesamesizeare comparedbychecksums. Onlytransferstheblocksthatdifferwithinafile! Cancompressthetransferredblocks Preservessymboliclinksandfilepermissions:alsoveryusefulfor copiesonthesamemachine. Canworkthroughssh(secureremoteshell).Veryusefultoupdate thecontentsofawebsite,forexample.
114
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
rsyncexamples(1)
rsynca/home/arvin/sd6_agents//home/sydney/misc/
a:archivemode.EquivalenttorlptgoD...easywaytotellyou wantrecursionandwanttopreservealmosteverything.
rsyncPavdelete/home/steve/ideas//home/bill/my_ideas/
115
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
rsyncexamples(2)
Copyingtoaremotemachine rsyncPav/home/bill/legal/arguments/\ bill@www.sco.com:/home/legal/arguments/ Userbillwillbepromptedforapassword. Copyingfromaremotemachinethroughssh rsyncPavessh homer@tank.duff.com:/prod/beer/\ fridge/homer/beer/ Userhomerwillbepromptedforhissshkeypassword.
116
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Miscellaneous
Comparingfilesanddirectories
117
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Comparingfilesanddirectories
difffile1file2 Reportsthedifferencesbetween2files,ornothingifthe filesareidentical. diffrdir1/dir2/ Reportsallthedifferencesbetweenfileswiththesame nameinthe2directories. Thesedifferencescanbesavedinafileusingthe redirection,andthenlaterreappliedusingthepatch command. Toinvestigatedifferencesindetail,betterusegraphical tools!
118
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
tkdiff
http://tkdiff.sourceforge.net/ Usefultooltocomparefilesandmergedifferences
119
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
kompare
Anothernicetooltocomparefilesandmergedifferences Partofthekdesdkpackage(FedoraCore)
120
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
gvimdiff
Anothernicetooltoviewdifferencesinfiles Availableinmost distributionswithgvim Apparentlynotusing diff. Noissuewithfileswith binarysections!
121
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Miscellaneous
Lookingforfiles
122
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thefindcommand
Betterexplainedbyafewexamples! find.name*.pdf Listsallthe*.pdffilesinthecurrent(.)directoryor subdirectories.Youneedthedoublequotestoprevent theshellfromexpandingthe*character. finddocsname"*.pdf"execxpdf{}';' Findsallthe*.pdffilesinthedocsdirectoryand displaysoneaftertheother. Manymorepossibilitiesavailable!However,theabove2 examplescovermostneeds.
123
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thelocatecommand
Muchfasterregularexpressionsearchalternativetofind locatekeys Listsallthefilesonyoursystemwithkeysintheirname. locate*.pdf Listsallthe*.pdffilesavailableonthewholemachine locate/home/fridge/*beer* Listsallthe*beer*filesinthegivendirectory(absolutepath) locateismuchfasterbecauseitindexesallfilesina dedicateddatabase,whichisupdatedonaregularbasis. findisbettertosearchthroughrecentlycreatedfiles.
124
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Miscellaneous
Variouscommands
125
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Gettinginformationaboutusers
who Listsalltheusersloggedonthesystem. whoami TellswhatuserIamloggedas. groups TellswhichgroupsIbelongto. groups<user> Tellswhichgroups<user>belongsto. finger<user> Tellsmoredetails(realname,etc)about<user> Disabledinsomesystems(securityreasons).
126
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Changingusers
Youdonothavetologouttologonanotheruseraccount! suhyde (Rare)Changetothehydeaccount,butkeepingtheenvironment variablesettingsoftheoriginaluser. sujekyll (Morefrequent)Logonthejekyllaccount,withexactlythe samesettingsasthisnewuser. su Whennoargumentisgiven,itmeanstherootuser.
127
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Thewgetcommand
Insteadofdownloadingfilesfromyourbrowser,justcopyand pastetheirURLanddownloadthemwithwget! wgetmainfeatures httpandftpsupport Canresumeinterrupteddownloads Candownloadentiresitesoratleastcheckforbadlinks Veryusefulinscriptsorwhennographicsareavailable (systemadministration,embeddedsystems) Proxysupport(http_proxyandftp_proxyenv.variables)
128
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
wgetexamples
wgetc\ http://microsoft.com/customers/dogs/winxp4dogs.zip Continuesaninterrupteddownload. wgetmhttp://lwn.net/ Mirrorsasite. wgetrnphttp://www.xml.com/ldd/chapter/book/ Recursivelydownloadsanonlinebookforofflineaccess. np:"noparent".Onlyfollowslinksinthecurrentdirectory.
129
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Misccommands(1)
sleep60 Waitsfor60seconds (doesn'tconsumesystemresources). wcreport.txt(wordcount) 438211518302report.txt Countsthenumberoflines,wordsandcharacters inafileorinstandardinput.
130
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Misccommands(2)
bc("basiccalculator?") bcisahandybutfullfeaturedcalculator.Evenincludes aprogramminglanguage!Usetheloptiontohave floatingpointsupport. date Returnsthecurrentdate.Usefulinscriptstorecord whencommandsstartedorcompleted.
131
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Checksumcommands
Achecksumorhashsumisafixedsizedatumcomputedfroman arbitraryblockofdigitaldataforthepurposeofdetecting accidentalerrorsthatmayhavebeenintroducedduringits transmissionsorstorage. http://en.wikipedia.org/wiki/Checksum TheMD5hashalgorithmisimplementedinthemd5sum command
$md5sumpatch2.6.24.7.bz2 0c1c5d6d8cd82e18d62406d2f34d1d38patch2.6.24.7.bz2
Systemadministration
Seeourpresentationaboutsystemadministrationbasics: Networksetup Creatingandmountingfilesystems Accessingadministrator(root)priviledges Packagemanagement Alsoavailableonhttp://freeelectrons.com/docs/commandline
133
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Applicationdevelopment
134
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Compilingsimpleapplications
ThecompilerusedforallLinuxsystemsisGCC http://gcc.gnu.org Tocompileasinglefileapplication,developedinC: gccotesttest.c
Willgenerateatestbinary,fromthetest.csourcefile
Usinglibraries(1)
OnanyLinuxsystem,aClibraryisavailableandoffersalarge setofAPIsforapplicationdevelopment.
Seehttp://www.gnu.org/software/libc/manual/
Usinglibraries(2)
Inyoursourcecode,includetheproperheaderfilesofthelibrary
Usually#include<foo.h>or#include<foo/foo.h> Theseheadersarepresentin/usr/include/ Refertothedocumentationofthelibraryfordetails,availablein /usr/share/doc/<package>/,ontheWeb...orintheheader files!
137
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
MakeandMakefiles
Thecompilationprocesscanbeautomatedusingthemaketool. makereadsafilecalledMakefilefromthecurrentdirectory,and executestherulesdescribedinthisfile Everyruleishasatargetname,acolon,andalistof dependencies,andthelistofcommandstogeneratethetarget fromthedependencies target:dep1dep2 command1 command2 command3
Whensimplyrunningmake,thedefaulttargetthatisgeneratedis all.Atargetisonlyregeneratedifdependencieshavechanged.
Seehttp://www.gnu.org/software/make/manual/
138
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
139
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
SimpleMakefileexample
Variablescanbedefined andlaterexpanededwith $(VARNAME) CFLAGS=Wall all:test test:t1.ot2.o gcco$@$^$(CFLAGS) Thedefaulttargetall simplydependsonthe testtarget.
Thetesttargetdepends ont1.oandt2.o.Once thesefilesaregenerated, clean: thegcccommandis $(RM)ftest executed. $@isthetargetname install: $^isthenameofall $(CP)test/usr/bin dependencies. The.ofilesaregenerated Thesetargetsareexecutedby usingimplicit runningmakecleanandmake dependencies,knownby make. install
140
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Buildsystems
Makefilesarenice,buttheydon'teasilyalloweasyadaptationto thedifferentbuildenvironmentanddifferentbuildoptions Moreelaboratedbuildsystemshavebeendeveloped
Autotools(automake,autoconf),basedonMakefilesandshell scripts.Eventhoughtheyareoldandalittlebitdifficultto understand,theyarethemostpopularbuildsystemforfree softwarepackages. CMake,anewer,cleanerbuildsystem SconcsandWaf,otherbuildsystemsbasedonPython
Debugging
TheofficialdebuggerthatcomeswiththeGNUdevelopment toolsisgdb.
Seehttp://sourceware.org/gdb/download/onlinedocs/gdb.html
Usinggdb
gdbisatextbaseddebugger,withacommandlineinterfacelikea shell,providingdedicatedcommands.Someoftheimportant commandsare:
break(b)tosetabreakpointinthecode.Canbeusedwitha functionnameoralocationinthesourcecode,oranabsolute memoryaddress. print(p)toprintthevalueofavariable.Usedwithavariable name,evenifit'sacomplexone(whichinvolvesdereferencing structures,forexample) ctocontinuetheexecutionuntilthenextbreakpoint. next(n)toexecuteonlythenextlineofcode(stepoverany functioncall)andstep(s)toexecuteonlythenextlineofcode (stepintoanyfunctioncall) backtrace(bt)todisplaythefunctioncallstack
143
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
gdbsamplesession
thomas@surf:/tmp$gccotesttest.cg
thomas@surf:/tmp$gdbtest GNUgdb6.8debian [...) (gdb)breakfoo Breakpoint1at0x80483c7:filetest.c,line5. (gdb)run Startingprogram:/tmp/test2 Breakpoint1,foo(a=2,b=3)attest.c:5 5 returna+b; (gdb)pa $1=2 (gdb)pb $2=3 (gdb)c Continuing. foo=5 Programexitednormally.
144
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
ddd,thegraphicalgdb
Thereareseveralgraphicalfront endstogdb.Apopularoneis ddd.
Allowstonavigateinthesource codewhiledebugging Allowstosetbreakpoints, inspectandchangevariable valuedirectlybylookingatthe sourcecode
http://www.gnu.org/software/ddd/
145
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
TheUnixandGNU/Linuxcommandline
Versioncontrolsystem CVS
146
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Versioncontrol(1)
Activitythatconsistsinmaintainingthefullhistoryofprojectfiles Everyversionofeveryfileisrecorded Itallowsto:
Createaknowledgedatabaseabouttheprojectcodebase Revertincaseofmistake Reviewthemodificationsintroducedbetweentwodifferentversions Workasateamonasingleproject Createparalleldevelopmentorreleasebranches Tagpreviousversionsofaproject
147
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Versioncontrol(2)
Usefulfor:
Sourcecode,ofcourse Documentation,translationstrings,compilationscripts, configurationfiles,etc. Binarydatacanbeversioned,butthefunctionalitieswillbelimited. Besttousetextonlyfileformats.
Versioncontrolisstillveryusefulwhenworkingaloneona project.
148
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Toolsandapproaches
Alotofversioncontrolsystemsavailable
Proprietary:Perforce,Synergy,StarTeam,BitKeeper,ClearCase Freeandopensource:CVS,Subversion,Git,Mercurial,Arch, Monotone
Inthefree/opensolutions,twomainapproaches
Theclassicalone,thecentralizedapproach,implementedbyCVS andSubversion Anewerone,thedecentralizedordistributedapproach, implementedinGit,Mercurial,ArchorMonotone.
149
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Centralizedapproach
Thecentralizedapproachisbasedonthepresenceofaserver hostingarepository. Therepositorycontainsthehistoryofallfilesandactsasthe referenceforallparticipantsintheproject. Typicalclient/serverapproach.
Conflictmanagement(1)
Whentwopersonsareworkingatthesametimeonthesamefile, whenthechangesaresenttotheserver,aconflictcanoccurifthe modificationsarenotcompatible.
A'' A' A
Repository
A' A Linus
A'' A Richard
151
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Conflictmanagement(2)
Twosolutionstosolvetheconflictproblem
Thelockingapproach:preventingtwodeveloperstoworkonthe samefile. Themergeapproach:theseconddevelopersendinghischanges totheserverisresponsibleformerginghischangeswiththeother developerschangesalreadypresentontheserver.
152
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Conflictresolutionbyfusion
A* A'' A
A* A' Linus
A''
A* A'' A Richard
153
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
CVS
154
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
CVSusage
Themainclientisacommandlineone,implementedinthecvs command
cvshelpgivesthelistofavailablecommands
add,admin,annotate,checkout,commit,diff,edit, editors,export,history,import,init,log,login, logout,ls,pserver,rannotate,rdiff,release, remove,rlog,rls,rtag,server,status,tag, unedit,update,version,watch,watchers
cvshelpcommandgivesthehelpofcommand.
Graphicalinterfaces
IntegrationinVim,Emacs,Anjuta,DevC++,Eclipse,Kdevelop,etc. Graphicalclients:Cervisia(forKDE),gcvs(forGnome),CrossVC, etc. Webclients:ViewVC, cvsweb,etc.
155
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Createtheworkingcopy
Thefirststeptoworkonanexistingprojectistocreateaworking copy.Aworkingcopyisacopyonthedevelopermachineofthe fulltreeoftheprojectsourcecode.
Thedeveloperwillworkonthiscopyofthesourcecode,asusual (filesaredirectlyaccessibleandeditable).
cvsdrepositoryaddresscheckoutmodule
Createinthecurrentdirectoryaworkingcopyofthemodulemodule locatedinthegivenrepository
Arepositoryaddresscanbe:
Alocalpath,like:local:/home/user/cvsrepo/ TheaddressofaCVSpserver,like:pserver:user@host :/var/cvsrepo/ UsingSSH,bysettingtheenvironmentvariableCVS_RSHtossh,and usinganaddresslike:ext:user@host:/var/cvsrepo/
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
156
Simpleusage
Workingcopycreationtobedoneonceforall! Modificationsoftheprojectfiles
Filesaremodifieddirectly,asusual,nothingspecialisnecessary. CVSknowsthecontentsoftheoriginalversionofthefilesandisable tocomputethelistofmodificationsmadebythedeveloper. EverydirectorycontainsaCVSdirectorythatshouldnotbemodified.
Sendthemodificationstotheserver:commit
cvscommit Runsatexteditortowritethemessagethatdescribesthecommit. Thismessagewillbepreservedforeverinthehistory.Veryimportant todescribeyourchangeindetails!
Fetchthemodificationsmadebyotherdevelopers:update
cvsupdate
157
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Example
$cvsd:local:/tmp/repo/checkoutproject cvscheckout:Updatingproject Uproject/README Uproject/a.c Uproject/b.c $cdproject/ project$viREADME project$cvscommitm"Addinginfos" cvscommit:Examining. /tmp/repo/project/README,v<README newrevision:1.3;previousrevision:1.2 project$cvsupdate cvsupdate:Updating. Ua.c project$
158
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Filemanagement
Whennewfilesordirectoriesarecreatedinsidetheproject,they arenotautomaticallytakenintoaccountbyCVS Theymustbeexplicitlyaddedwiththeaddcommand
cvsaddfile1.c Thenewfileisnotpropagatedtotherepositoryuntilthenext commit Samethingwithdirectories
Filesanddirectoriescanberemovedwiththeremovecommand IssuesfixedinSubversion
Filesanddirectoriescannotberenamedwithoutlosingthehistory DirectoryremovalisbadlyhandledinCVS
159
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Example
project$vic.c project$cvsaddc.c cvsadd:schedulingfile`c.c'foraddition cvsadd:use`cvscommit'toaddthisfilepermanently project$cvscommitm"Newfilec.c" cvscommit:Examining. /tmp/repo/project/c.c,v<c.c initialrevision:1.1 project$rma.c project$cvsremovea.c cvsremove:scheduling`a.c'forremoval cvsremove:use`cvscommit'toremovethisfilepermanently project$cvscommitm"Removea.c" cvscommit:Examining. /tmp/repo/project/a.c,v<a.c newrevision:delete;previousrevision:1.2
160
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Stateoftheworkingcopy
Togetinformationsaboutthestateoftheworking,usethestatus command
Willtelltheversionofthefile,iftheyhavebeenlocallymodified, etc.
update
Diffcommandexample
project$cvsdiff cvsdiff:Diffing. Index:c.c ======================================================== RCSfile:/tmp/repo/project/c.c,v retrievingrevision1.1 diffur1.1c.c c.c 28Jan200916:48:110000 1.1 +++c.c 28Jan200916:50:410000 @@1+1,2@@ Test. +Test2.
162
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Usingthehistory
Seethecommitmessages
cvslog cvslogfile.c
Seethedifferencesbetweentwopastrevisions
cvsdiffr1.1r1.2file.c WithCVS,theversioningisdoneonaperfilebasis:acommitis notanentitythatcanbereferredtooncecompleted.Itmakesthe usageofthehistoryverycomplicated.ThisisfixedinSubversion.
Seewhomadeachange
cvsannotate
Agraphicalinterface,eitheragraphicalclientorawebclient,will beveryusefultonavigateandusethehistoryefficiently
163
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
ConflictmanagementinCVS(1)
Afterchangingafile,wetrytocommitthechangetotheserver
$cvscommitm"Modification" cvscommit:Examining. cvscommit:Uptodatecheckfailedfor`main.c' cvs[commitaborted]:correctaboveerrorsfirst!
ConflictmanagementinCVS(2)
Insidemain.c #include<stdio.h> intmain(void){ <<<<<<<main.c printf("Bonjourmonde\n"); ======= printf("Holamundo\n"); >>>>>>>1.2 return0; } Ourmodification!
165
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
ConflictresolutioninCVS
Theconflictmustbemanuallyresolvedbythedeveloper,no automatedtoolcanresolvesuchconflicts Theconflictisresolveddirectlyinthefilebyremovingthe markersandmergingthemodifications(eitherselectingoneof themorcreatinganewversionbasedonbothmodifications) Onceresolved,thefilecanbecommittedasusual
project$cvscommitm"InFrench" cvscommit:Examining. /tmp/repo/project/main.c,v<main.c newrevision:1.3;previousrevision:1.2
166
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Repositoryinitialization
Arepositorymustbeinitializedusingtheinitcommand:
mkdir/home/user/cvsrepo cvsd:local:/home/user/cvsrepoinit
Tagsandbranches
Tagsallowtoidentifyagivenversionoftheprojectthrougha meaningfulsymbolicname
Usefulforexampleiftheversionhasbeendeliveredtothetest teamortoacustomer.
Tagsarecreatedusingthecvstagcommand. Branchesallowtocreateparallelflowofdevelopments
Maintenanceofapreviousrelease Developmentofexperimentalnewfeatures
Connectionwithothertools
Mail
Sendamailateverycommit, withthediff.Allowothersto review,andnotifiesthemof thechanges..
IRC
Sendamessageat everycommit.Notifies ofthechanges.
Versioncontrol
Linkthecommitswiththebugs andthebugswiththecommits.
Buildandtest
Bugtracking
169
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
WhySubversion?
BecauseCVShasmanydrawbacksandshortcoming
Notpossibletosimplyrenamefilesanddirectorieswhilepreserving thehistory Noatomiccommitsidentifyingthecommitasawhole,makingit difficulttonavigateinthehistory,revertcommits,andisthesource ofrepositoryincoherencyincaseofcrashes Poorbranchingandmergingcapabilities
Inusage,SubversionisverysimilartoCVS:thecommandsare exactlythesame.
FixesallCVSshortcomings Andprovidesinterestingbranchingandmergingfeaturessuchas mergetracking. Manylargescaleprojectsalreadymadetheswitch.
170
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Distributedversioncontrolsystems
Sinceafewyears,anewgenerationofversioncontrolsystems Distributedversioncontrolinsteadofacentralizedapproach Principles
Notechnicallycentralrepository,everycopyisarepository Alldeveloperscancreatelocalbranches,sharethesebranches withotherdeveloperswithoutaskingacentralauthority. Advancedbranchingandmergingcapabilities.
171
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Relateddocuments
Howtohelp
Youcanhelpustoimproveandmaintainthisdocument... Bysendingcorrections,suggestions,contributionsand translations Byaskingyourorganizationtoorderdevelopment,consulting andtrainingservicesperformedbytheauthorsofthese documents(seehttp://freeelectrons.com/). Bysharingthisdocumentwithyourfriends,colleagues andwiththelocalFreeSoftwarecommunity. Byaddinglinksonyourwebsitetoouronlinematerials, toincreasetheirvisibilityinsearchengineresults.
FreeElectrons.Kernel,driversandembeddedLinuxdevelopment,consulting,trainingandsupport.http//freeelectrons.com
Linuxkernel Linuxdevicedrivers Boardsupportcode Mainstreamingkernelcode Kerneldebugging EmbeddedLinuxTraining Allmaterialsreleasedwithafreelicense! UnixandGNU/Linuxbasics Linuxkernelanddriversdevelopment RealtimeLinux,uClinux Developmentandprofilingtools Lightweighttoolsforembeddedsystems Rootfilesystemcreation Audioandmultimedia Systemoptimization
FreeElectrons
Ourservices
CustomDevelopment Systemintegration EmbeddedLinuxdemosandprototypes Systemoptimization Applicationandinterfacedevelopment Consultingandtechnicalsupport Helpindecisionmaking Systemarchitecture Systemdesignandperformancereview Developmenttoolandapplicationsupport Investigatingissuesandfixingtoolbugs