【编程基础】Linux环境开发效率--那些强大的命令

之前写了一篇关于linux下常用的几个命令,参考Linux入门--提高工作效率的命令。接下来接着介绍一些在linux下做开发经常使用到得命令,其中有打包压缩命令tar,文件查找命令find,文件内容查找命令grep,elf可执行文件分析工具readelf等。

1、打包压缩命令tar

在linux下经常会遇到给源码打包解压等,如果你还是用linux的X window来做那你就out了。下面是该工具的常用命令参数及运用举例:

主要命令:

-c 创建包

-x 解包

-t 列出包中的内容

-r 增加文件到指定包中

-u 更新包中的文件

可选命令:

-j 创建或解开包时 使用bzip2 进行压缩或解压;

-z 创建或解开包时 使用gzip 进行压缩或解压;

-Z 创建或解开包时 使用compress 进行压缩或解压;

-f 后面跟指定的包文件名;

-v 显示打包/解包过程

-C 指定解包后的路径

例如:

tar -czf tmp.tar.gz /tmp 将 “/tmp” 目录压缩打包存放为tmp.tar.gz;

tar -xzf tmp.tar.gz -C /home 将 tmp.tar.gz 包解到“/home” 目录下;

tar -t tmp.tar.gz 查看 tmp.tar.gz 包中的文件信息;

2、文件查找命令find

突然不知道xxx.c在那个路径下了,你不会还在用linux里面的X window来搜索这个文件吧?find才是简单强暴的查找利器啊。

其命令格式为:

find 要查找的路径表达式

例如:

find . -name 1.txt 在当前目录及其子目录下查找文件 “1.txt”;

find /tmp -name 1.txt 在 “/tmp” 目录及其子目录下查找文件“1.txt”。

另外,find也支持模糊查找:

find . -name *test*.c

更高级的用法可参考man手册等。

3、文件内容查找命令grep

我在查一个bug,看日志啊看日志,突然发现了一个关键的log信息,那么这个信息是在那个源文件中打印出来的呢?这时候就用到grep了。

文件内容查找命令grep

grep 命令用于查找指定的模式匹配,格式为:

grep [命令选项] 要查找的匹配模式 [要查找的文件]

例如:

grep cams test.txt 在 “test.txt” 文件中查找cams 字符串;

grep -r cams /root/cams 在 “/root/cams” 目录及其子目录下的所有文件中,查找cams 字符串;

grep 命令除了能够查找文件外,还能够将任意输出流重定向到grep 进行查找:

ps -ef | grep ora 查找进程名中包含 “ora” 的所有进程信息。

其实以上都是grep最简单最常用的用法,更高级的用法可参考grep的man手册等。

4、ELF文件分析工具readelf

此命令算是一个比较高级的命令,没有上述命令常用,但是也是一个很实用的软件,这里抛砖引玉,介绍一些简单的用法。

查询文件所有信息

readelf object-file-name -a

查询elf header

readelf object-file-name -h

查询符号表

readelf object-file-name -s

查询所有section详细信息

readelf object-file-name -t或者 readelf object-file-name -S

dump某个section的信息

readelf object-file-name -p section-name|section-index

readelf object-file-name -x section-name|section-index

readelf object-file-name -R section-name|section-index

原文发布于微信公众号 - 程序员互动联盟(coder_online)

原文发表时间:2015-05-15

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏散尽浮华

linux下core file size设置笔记

现象说明:突然发现一台测试机器的java程序莫名其妙地没了,但是没有core dump!这就需要打开服务器的core文件生成的功能了,(即core dump文件...

36110
来自专栏简单聊聊Spark

hadoop2.5.0完全分布式环境搭建(亲测有效)

      说在前头的一些东西,关于Linux本身环境本身的一些处理见如下链接,主要是讲Hadoop环境的前期准备:http://www.jianshu.co...

643
来自专栏小白安全

无损数据 无损硬盘 无需重装修复硬盘锁

如果出现下图情况就必须要进PE操作  因为硬盘的系统已经损坏了 1,进PE 2.打开diskgenius分区工具 可以看到硬盘的数据全都完蛋了 3...

34510
来自专栏Strive

hive 初始化msyql报错 SQL Error code: 1045

搭建环境 | 系统:centos 7 | Hadoop: 3.4.12 | hive:2.3.3 | mysql:5.6.40

1171
来自专栏程序员互动联盟

【编程基础】聊聊如何学习Java—Java开发环境配置

之前两篇文章介绍了为什么学习Java和Java语言的特性,很多网友询问如何配置Java开发环境,这一篇我就给大家聊聊如何配置Java环境。 1、下载J...

3559
来自专栏lgp20151222

服务器部署nginx报错 nginx: [warn] conflicting server name "localhost" on xxx.xxx.xxx.xxx:80, ignored

提示successfull后就可以使用 nginx -s reload来重新加载配置

922
来自专栏网络

shell全自动登录远程终端

先看效果 ? 你需要做的事情,在配置文件中配置服务器信息,选择对应的服务器,进行连接。 传统手工连接 弊端很明显,需要记服务器地址、ip、key位置、密码等,每...

20810
来自专栏重庆的技术分享区

windows下mongodb的安装与配置(全)

1252
来自专栏有刻

dotnetcore 自动迁移工具

3358
来自专栏蓝天

Linux find命令详解

find pathname -options [-print -exec -ok ...]

872

扫码关注云+社区