检查远程端口是否对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:
复制代码 代码如下:
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提取到新目录里:
复制代码 代码如下:
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;

快速备份一个文件:
复制代码 代码如下:
cp some_file_name{,.bkp}

访问Windows共享目录:
复制代码 代码如下:
smbclient -U "DOMAIN\user" //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 git@github.com: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 "me@example.com"

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:
复制代码 代码如下:
< space >cmd

去之前的工作目录:
复制代码 代码如下:
cd -

拆分大体积的tar.gz文件(每个100MB),然后合并回去:
复制代码 代码如下:
split –b 100m /path/to/large/archive /path/to/output/files
cat files* > archive

使用curl获取HTTP status code:
复制代码 代码如下:
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 '%100s\n' | tr ' ' =

标签:
Linux,Shell,小技巧

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
内蒙古资源网 Copyright www.nmgbbs.com

评论“Linux Shell的一些使用小技巧收集”

暂无“Linux Shell的一些使用小技巧收集”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。