[转]Linux shell中的那些小把戏
我日常使用Linux shell(Bash),但是我经常忘记一些有用的命令或者shell技巧。是的,我能记住一些命令,但是肯定不会只在特定的任务上使用一次,所以我就开始在我的Dropbox账号里用文本文件写下这些Linux shell的小技巧,现在我决定共享它给你。这个表我以后还会更新。记住,这里的一些贴士需要在你的Linux发行版上安装额外的软件。
在bash中检查远程端口是否打开:
echo >/dev/tcp/8.8.8.8/53 && echo "open"
将进程挂起:
Ctrl + z
将进程移到前台:
fg
(译注,挂起的进程是不执行的,如果希望在后台执行,可以使用bg命令,并且指定通过jobs命令获得的任务号。)
生成随机16进制数字,n是字符的数量:
openssl rand -hex n
在当前shell中执行一个文件中的命令(译注:这个文件不是一个bash脚本,比如.bashrc、bash_profile等):
source /home/user/file.name
提取字符串的前5个字符:
${variable:0:5}
打开SSH调试模式(译注:当你遇到SSH连接问题时很有用):
ssh -vvv user@ip_address
使用pem key的进行SSH连接:
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 conv=fdatasync; rm -rf /tmp/output.img
测试磁盘读速度:
hdparm -Tt /dev/sda
获取文本的md5值:
echo -n "text" | md5sum
检测xml语法:
xmllint --noout file.xml
将tar.gz文件解压到指定目录:
tar zxvf package.tar.gz -C new_dir
用curl获取HTTP头:
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;
快速创建一个文件的备份(扩展名是.bkp):
cp some_file_name{,.bkp}
访问Windows共享:
smbclient -U "DOMAIN\user" //dc.domain.com/share/test/dir
运行history中的命令 (这里在history中的第100个):
!100
unzip到目录中:
unzip package_name.zip -d dir_name
输入多行文字 (按 CTRL + d 退出):
cat > test.txt
创建空白的文件或者清空已存在的文件:
> test.txt
从Ubuntu NTP服务器上更新日期:
ntpdate ntp.ubuntu.com
netstat 显示所有IPv4的TCP监听的端口:
netstat -lnt4 | awk '{print $4}' | cut -f2 -d: | grep -o '[0-9]*'
将qcow2的镜像转化成raw格式:
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 -o remount,rw /
挂载目录 (适合于符号链接不能工作的情况下):
mount --bind /source /destination
发送DNS动态更新给DNS:
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 clone特定branch (本例是master分支):
git clone git@github.com:name/app.git -b master
git切换到另外一个branch (本例是develop分支):
git checkout develop
git删除一个branch(本例是myfeature):
git branch -d myfeature
Git删除一个远程branch:
git push origin :branchName
Git push 新的branch到远程:
git push -u origin mynewfeature
打印history中最后的cat命令
!cat:p
运行history中的最后的cat命令:
!cat
找出在/home/user中的所有空子目录:
find /home/user -maxdepth 1 -type d -empty
得到test.txt中50到60行的文本:
< test.txt sed -n '50,60p'
以sudo权限重新运行上一个执行的命令 (如果是: mkdir /root/test, 下面会运行: sudo mkdir /root/test)(译注:当你执行一个命令忘记sudo时,可以这样重新执行,而不必再把完整命令敲一遍):
sudo !!
创建临时RAM文件系统 - ramdisk (请先创建 /tmpram 目录):
mount -t tmpfs tmpfs /tmpram -o size=512m
Grep完整的单词(译注:而不是其它单词的一部分):
grep -w "name" test.txt
提升权限后在一个文件后追加文本:
echo "some text" | sudo tee -a /path/file
列出所有支持的kill信号:
kill -l
生成随机密码 (本例中16个字符长):
openssl rand -base64 16
在bash历史中不记录最后的会话:
kill -9 $$
扫描网络来找出开放的端口:
nmap -p 8081 172.20.0.0/16
设置git email:
git config --global user.email "me@example.com"
如果你有未提交的commit,与master同步:
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发送数据给服务器:
echo "hosts.sampleHost 10 `date +%s`" | nc 192.168.200.2 3000
转换tab为空格:
expand test.txt > test1.txt
跳过bash历史:
<<空格>>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
当 Ctrl + c 没用时:
Ctrl + \
获取文件所有者:
stat -c %U file.txt
列出块设备:
lsblk -f
找出文件中带有末尾空格的文件:
find . -type f -exec egrep -l " +$" "{}" \;
找出用tab缩进的文件:
find . -type f -exec egrep -l $'\t' "{}" \;
用"="打印水平行
printf '%100s\n' | tr ' ' =
[转]Linux shell中的那些小把戏的更多相关文章
- linux shell 中的sleep命令
开始还以为是这样的语法: sleep(1), 后面发现是: linux shell 中的sleep命令 分类: LINUX 在有的shell(比如linux中的bash)中sleep还支持睡眠(分,小 ...
- 理解 Linux shell 中的一个方言:2>&1
理解 Linux shell 中的一个方言:2>&1 2016-11-14 杜亦舒 前言 在使用 linux 命令或者 shell 编程时,这个用法常会遇到 2>&1 如 ...
- linux shell 中的位置变量
对于linux shell 中的位置变量,我一直以来都是吐不出来又咽不下去,每次看到都不懂,不懂了就去百度google,看完了又忘,真是慢性咽炎啊.现在认真想想也是,其实自己一直以来都没有好好学习过, ...
- Linux shell中的一个问题 ${}带正则匹配的表达式
目前在准备龙芯项目的PMON,在研究其编译过程的时候,看到一些make 语句,百思不得其解.后来在shell编程中看到一点资料,牵扯到Shell中的正则表达式.故记录下来,以备后来查阅. 问题: 在某 ...
- Linux shell中的竖线(|)——…
原文地址:Linux shell中的竖线(|)--管道符号作者:潇潇 管道符号,是unix一个很强大的功能,符号为一条竖线:"|". 用法: command 1 | command ...
- [转载]Linux shell中的竖线(|)——管道符号
原文地址:Linux shell中的竖线(|)--管道符号作者:潇潇 管道符号,是unix一个很强大的功能,符号为一条竖线:"|". 用法: command 1 | command ...
- Linux Shell中有三种引号的用法
Linux Shell中有三种引号,分别为双引号(" ").单引号(' ')以及反引号(` `). 其中双引号对字符串中出现的$.''.`和\进行替换:单引号不进行替换,将字符串中 ...
- Linux Shell中的特殊符号和含义简明总结(包含了绝大部份)
case语句适用于需要进行多重分支的应用情况. case分支语句的格式如下: case $变量名 in 模式1) 命令序列1 ;; 模式2) 命令序列2 ;; *) 默认执行的命令序列 ...
- Linux shell 中提取zip或jar文件中的某个文件
Linux shell 中提取zip或jar文件中的某个文件 假如有个压缩包 abc.jar, 里面文件如下 (可以用unzip -l abc.jar 查看): data/1.txt data/2.t ...
随机推荐
- 物理的alpha blend
alpha blend主要是可以用来模拟半透明的笔触..然而它是有缺陷的.. 因为一般的alpha blend的(线性混合)模型没有考虑反射光的问题..然而其实反射光是很重要的大家都知道.. 好..如 ...
- 关于在生命周期当中进行setState操作的问题
当需要监听组件的属性改变的时候有两个生命周期componentWillReceiveProps和componentWillUpdate 当使用componentWillUpdate的时候可以获取到将要 ...
- iOS - 倒计时封装
+(NSString *)countdownStartTime:(NSString *)startTime{ NSString *TIME = [startTime substringToIndex: ...
- 美食节(bzoj 2879)
Description CZ市为了欢迎全国各地的同学,特地举办了一场盛大的美食节.作为一个喜欢尝鲜的美食客,小M自然不愿意错过这场盛宴.他很快就尝遍了美食节所有的美食.然而,尝鲜的欲望是难以满足的.尽 ...
- pat 甲级 1066. Root of AVL Tree (25)
1066. Root of AVL Tree (25) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue An A ...
- 汇编中的 imul 指令
1.这是整形乘法指令,无论是 unsigned int 还算是 signed int 实际上指令都是进行相同的运算,只不过最终的结果是由程序中的类型来做相应的解读 2.imul 指令实际上不会发生 o ...
- BZOJ 3876 支线剧情
支线剧情 [故事背景] 宅男JYY非常喜欢玩RPG游戏,比如仙剑,轩辕剑等等.不过JYY喜欢的并不是战斗场景,而是类似电视剧一般的充满恩怨情仇的剧情.这些游戏往往都有很多的支线剧情,现在JYY想花费最 ...
- UnionFind(PYthon实现)
UnionFind用于解决图的连通性问题,不需要给出具体路径的情况,可用来计算连通分支数 参考链接: https://blog.csdn.net/dm_vincent/article/details/ ...
- 记录: 一次解决整型溢出攻击(使用scala,隐式转换)
最近项目遇到一次整型溢出攻击 有一个功能,玩家购买num个物品. 每个物品花费14货币. 客户端限制玩家只能购买 1-9999个该物品. 但是某玩家通过技术手段,获得了客户端的运行权限. 于是发送协议 ...
- poj 2299(离散化+树状数组)
Ultra-QuickSort Time Limit: 7000MS Memory Limit: 65536K Total Submissions: 53777 Accepted: 19766 ...