今天小编要跟大家分享的文章是官网想要成为Linux运维都需要学习哪些技能。 首先,想告诉大家,在Unix/Linux下,最有效率技巧的不是操作图形界面,而是命令行操作,因为命令行意味着自动化。如果你知道Linux有多强大,而这个强大完全来自于命令行。那么想要成为一名优秀的Linux运维工程师都需要学习哪些技能呢?下面我们一起来看一看吧!
一、基础
学习Bash
你可以man bash来看看bash的东西,并不复杂也并不长。你用别的shell也行,但是bash是很强大的并且也是系统默认的。(学习zsh或tsch只会让你在很多情况下受到限制)
学习vim
在Linux下,基本没有什么可与之竞争的编译辑器(就算你是一个Emacs或Eclipse的重度用户)。你可以看看《简明vim攻略》和 《Vim的冒险游戏》以及《给程序员的Vim速查卡》还有《把Vim变成一个编程的IDE》等等。
了解ssh
明白不需要口令的用户认证(通过ssh-agent, ssh-add),学会用ssh翻墙,用scp而不是ftp传文件,等等。你知道吗?scp远端的时候,你可以按tab键来查看远端的目录和文件(当然,需要无口令的用户认证),这都是bash的功劳。
熟悉bash的作业管理
如:&, Ctrl-Z, Ctrl-C, jobs, fg, bg, kill,等等。当然,你也要知道Ctrl+(SIGQUIT)和Ctrl+C(SIGINT)的区别。
简单的文件管理ls和ls -l (你最好知道 “ls -l” 的每一列的意思), less, head, tail和tail -f, ln和ln -s (你知道明白hard link和soft link的不同和优缺点), chown, chmod, du (如果你想看看磁盘的大小du -sk *), df, mount。当然,原作者忘了find命令。
基础的网络管理
ip或ifconfig, dig。当然,原作者还忘了如netstat, ping, traceroute,等
理解正则表达式,还有grep/egrep的各种选项
比如:-o, -A,和-B这些选项是很值得了解的。
学习使用apt-get和yum来查找和安装软件(前者的经典分发包是Ubuntu,后者的经典分发包是Redhat),我还建议你试着从源码编译安装软件。
二、日常
o 在bash里,使用Ctrl-R而不是上下光标键来查找历史命令。
o 在bash里,使用Ctrl-W来删除最后一个单词,使用Ctrl-U来删除一行。请man bash后查找Readline Key Bindings一节来看看bash的默认热键,比如:Alt-.把上一次命令的最后一个参数打出来,而Alt-*则列出你可以输入的命令。
o 回到上一次的工作目录:cd– (回到home是cd ~)
o 使用xargs。这是一个很强大的命令。你可以使用-L来限定有多少个命令,也可以用-P来指定并行的进程数。如果你不知道你的命令会变成什么样,你可以使用xargs echo来看看会是什么样。当然,-I{}也很好用。示例:
想要成为Linux运维都需要学习哪些技能
o pstree -p可以帮你显示进程树。
o 使用pgrep和pkill来找到或是kill某个名字的进程。(-f选项很有用)。
o 了解可以发给进程的信号。例如:要挂起一个进程,使用kill -STOP [pid].使用man 7 signal来查看各种信号,使用kill -l来查看数字和信号的对应表。
o 使用nohup或 disown如果你要让某个进程运行在后台。
o 使用netstat -lntp来看看有侦听在网络某端口的进程。当然,也可以使用lsof。
o 在bash的脚本中,你可以使用set -x来debug输出。使用set -e来当有错误发生的时候abort执行。考虑使用set -o pipefail来限制错误。还可以使用trap来截获信号(如截获ctrl+c)。
o 在bash脚本中,subshells (写在圆括号里的)是一个很方便的方式来组合一些命令。一个常用的例子是临时地到另一个目录中,例如:
想要成为Linux运维都需要学习哪些技能
o 在bash中,注意那里有很多的变量展开。如:检查一个变量是否存在: ${name:?error message}。如果一个bash的脚本需要一个参数,也许就是这样一个表达式input_file=${1:?usage: $0 input_file}。一个计算表达式:i=$(( (i + 1) % 5 ))。一个序列:{1..10}。截断一个字符串:${var%suffix}和${var#prefix}。示例:if var=foo.pdf, then echo ${var%.pdf}.txt prints“foo.txt”。
o 通过<(some command)可以把某命令当成一个文件。示例:比较一个本地文件和远程文件/etc/hosts:diff /etc/hosts <(ssh somehost cat /etc/hosts)。
o 了解什么叫 “here documents” ,就是诸如cat <<EOF这样的东西。
o 在bash中,使用重定向到标准输出和标准错误。如:some-command >logfile 2>&1。另外,要确认某命令没有把某个打开了的文件句柄重定向给标准输入,最佳实践是加上 “</dev/null”,把/dev/null重定向到标准输入。
o 使用man ascii来查看ASCII表。
o 在远端的ssh会话里,使用screen或dtach来保存你的会话。(参看《28个Unix/Linux的命令行神器》)
o 要来debug Web,试试curl和curl -I或是wget。我觉得debug Web的利器是firebug,curl和wget是用来抓网页的,呵呵。
o 把HTML转成文本:lynx -dump -stdin
o 如果你要处理XML,使用xmlstarlet
o 对于Amazon S3,s3cmd是一个很方便的命令(还有点不成熟)
o 在ssh中,知道怎么来使用ssh隧道。通过-L or -D (还有-R),翻墙神器。
o 你还可以对你的ssh做点优化。比如,.ssh/config包含着一些配置:避免链接被丢弃,链接新的host时不需要确认,转发认证,以前使用压缩(如果你要使用scp传文件):
想要成为Linux运维都需要学习哪些技能
o 如果你有输了个命令行,但是你改变注意了,但你又不想删除它,因为你要在历史命令中找到它,但你也不想执行它。那么,你可以按下Alt-#,于是这个命令关就被加了一个#字符,于是就被注释掉了。
三、数据处理
o 了解sort和uniq命令(包括uniq的-u和-d选项).
o 了解用cut, paste,和join命令来操作文本文件。很多人忘了在cut前使用join。
o 如果你知道怎么用sort/uniq来做集合交集、并集、差集能很大地促进你的工作效率。假设有两个文本文件a和b已解被uniq了,那么,用sort/uniq会是最快的方式,无论这两个文件有多大(sort不会被内存所限,你甚至可以使用-T选项,如果你的/tmp目录很小)
想要成为Linux运维都需要学习哪些技能
o 了解和字符集相关的命令行工具,包括排序和性能。很多的Linux安装程序都会设置LANG或是其它和字符集相关的环境变量。这些东西可能会让一些命令(如:sort)的执行性能慢N多倍(注:就算是你用UTF-8编码文本文件,你也可以很安全地使用ASCII来对其排序)。如果你想Disable那个i18n并使用传统的基于byte的排序方法,那就设置export LC_ALL=C(实际上,你可以把其放在.bashrc)。如果这设置这个变量,你的sort命令很有可能会是错的。
o 了解awk和sed,并用他们来做一些简单的数据修改操作。例如:求第三列的数字之和:awk‘{ x += $3 } END { print x }’。这可能会比Python快3倍,并比Python的代码少三倍。
o 使用shuf来打乱一个文件中的行或是选择文件中一个随机的行。
o 了解sort命令的选项。了解key是什么(-t和-k)。具体说来,你可以使用-k1,1来对第一列排序,-k1来对全行排序。
o Stable sort (sort -s)会很有用。例如:如果你要想对两例排序,先是以第二列,然后再以第一列,那么你可以这样:sort -k1,1 | sort -s -k2,2
o 我们知道,在bash命令行下,Tab键是用来做目录文件自动完成的事的。但是如果你想输入一个Tab字符(比如:你想在sort -t选项后输入<tab>字符),你可以先按Ctrl-V,然后再按Tab键,就可以输入<tab>字符了。当然,你也可以使用$’ ’。
o 如果你想查看二进制文件,你可以使用hd命令(在CentOS下是hexdump命令),如果你想编译二进制文件,你可以使用bvi命令(http://bvi.sourceforge.net/墙)
o 另外,对于二进制文件,你可以使用strings(配合grep等)来查看二进制中的文本。
o 对于文本文件转码,你可以试一下iconv。或是试试更强的uconv命令(这个命令支持更高级的Unicode编码)
o 如果你要分隔一个大文件,你可以使用split命令(split by size)和csplit命令(split by a pattern)。
四、系统调试
o 如果你想知道磁盘、CPU、或网络状态,你可以使用iostat, etstat, top (或更好的htop),还有dstat命令。你可以很快地知道你的系统发生了什么事。关于这方面的命令,还有iftop, iotop等。
o 要了解内存的状态,你可以使用free和vmstat命令。具体来说,你需要注意 “cached” 的值,这个值是Linux内核占用的内存。还有free的值。
o Java系统监控有一个小的技巧是,你可以使用kill -3 <pid>发一个SIGQUIT的信号给JVM,可以把堆栈信息(包括垃圾回收的信息)dump到stderr/logs。
o 使用mtr会比使用traceroute要更容易定位一个网络问题。
o 如果你要找到哪个socket或进程在使用网络带宽,你可以使用iftop或nethogs。
o
o Apache的一个叫ab的工具是一个很有用的,用quick-and-dirty的方式来测试网站服务器的性能负载的工作。如果你需要更为复杂的测试,你可以试试siege。
o 如果你要抓网络包的话,试试wireshark或tshark。
o 了解strace和ltrace。这两个命令可以让你查看进程的系统调用,这有助于你分析进程的hang在哪了,怎么crash和failed的。你还可以用其来做性能profile,使用-c选项,你可以使用-p选项来attach上任意一个进程。
o 了解用ldd命令来检查相关的动态链接库。注意:ldd的安全问题
o 使用gdb来调试一个正在运行的进程或分析core dump文件。
o 学会到/proc目录中查看信息。这是一个Linux内核运行时记录的整个操作系统的运行统计和信息,比如:/proc/cpuinfo, /proc/xxx/cwd, /proc/xxx/exe, /proc/xxx/fd/, /proc/xxx/smaps。
o 如果你调试某个东西为什么出错时,sar命令会有用。它可以让你看看CPU,内存,网络,等的统计信息。
o 使用dmesg来查看一些硬件或驱动程序的信息或问题。
o 以上就是小编今天为大家分享的关于想要成为Linux运维都需要学习哪些技能的文章,希望本篇文章能够对正在从Linux相关工作的小伙伴们有所帮助。想要了解更多Linux相关知识记得关注马哥教育官网。最后祝愿小伙伴们工作顺利!
来自:酷 壳 –CoolShel,作者:陈皓
https://coolshell.cn/articles/8883.html
【免责声明:本文图片及文字信息均由小编转载自网络,旨在分享提供阅读,版权归原作者所有,如有侵权请联系我们进行删除。】