Linux命令学习_2

本文最后更新于2014年8月8日,已超过 1 年没有更新,如果文章内容失效,还请反馈给我,谢谢!

———————
:%s/hello/&/gn        #在Vim中查找文件里任何地方出现了“hello”的次数
:%s/<hello>/&/gn    #在Vim中查找文件里任何地方出现了单词“hello”的次数
———————
VIM统计单词数、行数等 *count-items*
:%s/./&/gn 字符数
:%s/i+/&/gn 单词数
:%s/^//n 行数
:%s/the/&/gn 任何地方出现的 “the”
———————
pgrep和pkill命令

实例:
获取指定后缀名的文件总个数命令:
获取当前目录下文件总行数以及单个文件行数:
统计某文件夹下文件的个数
ls -l |grep “^-“|wc -l
统计某文件夹下目录的个数
ls -l |grep “^d”|wc -l
统计文件夹下文件的个数,包括子文件夹里的
ls -lR|grep “^-“|wc -l
统计文件夹下目录的个数,包括子文件夹里的
ls -lR|grep “^d”|wc -l
说明:
 ls -l
长列表输出该目录下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等)
grep “^-”
这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d
wc -l
统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于一行信息对应一个文件,所以也就是文件的个数。
Linux环境中统计文件夹中文件数目
第一种方法:
 ls -l|grep “^-”|wc -l
ls -l 长列表输出该目录下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等)。如果ls -lR | grep “^-” | wc -l 则可以连子目录下的文件一起统计。
grep ^- 这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d
wc -l 统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于一行信息对应一个文件,所以也就是文件的个数。
第二种方法:
find ./ -type f | wc -l
由于默认find会去子目录查找,如果只想查找当前目录的文件用find ./ -maxdepth 1 -type f | wc -l即可。
需要说明的是第二种方法会比第一种方法快很多,尤其是也统计子目录时。

Linux shell用法和技巧
使用Linux shell是我每天的基本工作,但我经常会忘记一些有用的shell命令和技巧。当然,命令我能记住,但我不敢说能记得如何用它执行某个特定任务。于是,我开始在一个文本文件里记录这些用法,并放在我的Dropbox里,现在,向大家分享这个文件。这个文件我会不断的更新。需要注意一点的是,有些用法需要在你的Linux系统里安装额外的软件。
检查远程端口是否对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抓取完整的网站目录结构,存放到本地目录中:
一次创建多个目录:
mkdir -p /home/user/{test,test1,test2}
列出包括子进程的进程树( pstree -a ):
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格式:

将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 “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 -o remount,rw /
挂载一个目录(这是不能使用链接的情况):

动态更新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


在bash历史记录里禁止记录最后一次会话:
kill -9 $$
扫描网络寻找开放的端口:
nmap -p 8081 172.20.0.0/16
设置git email:

To sync with master if you have unpublished commits:

将所有文件名中含有”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
不将命令记入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 ‘ ‘ =
参考地址:

声明: 除非注明,ixyzero.com文章均为原创,转载请以链接形式标明本文地址,谢谢!
https://ixyzero.com/blog/archives/914.html

《Linux命令学习_2》上有1条评论

  1. Linux 基于tar与openssl加密解密压缩包
    https://blog.csdn.net/leshami/article/details/80118746

    [root@node249 ~]# tar -czPf - /u02/mysqlbak | openssl enc -e -des3 -a -salt -k PassW@rd | dd of=mysqlbak.tar.gz.desc
    [root@node249 ~]# head mysqlbak.tar.gz.desc

    [root@node249 ~]# rm -rf /u02/mysqlbak/*
    [root@node249 ~]#
    [root@node249 ~]# dd if=mysqlbak.tar.gz.desc | openssl enc -d -des3 -a -salt -d -k PassW@rd | tar -zxPf -

发表评论

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