成为Java顶尖程序员,先过了下面问题!(四)
五、Linux使用与问题分析排查
1.使用两种命令创建一个文件?
touch hello.txt
echo "" > hello.txt
vim hello.txt
:wq
2.硬链接和软链接的区别?
硬链接是有着相同 inode 号仅文件名不同的文件,存在以下几点特性:
- 文件有相同的 inode 及 data block;
- 只能对已存在的文件进行创建;
- 不能交叉文件系统进行硬链接的创建;
- 不能对目录进行创建,只可对文件创建;
- 删除一个硬链接文件并不影响其他有相同 inode 号的文件。
# 硬链接命令
link oldfile newfile
ln oldfile newfile
软链接与硬链接不同,若文件用户数据块中存放的内容是另一文件的路径名的指向,则该文件就是软连接。软链接就是一个普通文件,只是数据块内容有点特殊。软链接有着自己的 inode 号以及用户数据块(见
图 2.)。因此软链接的创建与使用没有类似硬链接的诸多限制:
- 软链接有自己的文件属性及权限等;
- 可对不存在的文件或目录创建软链接;
- 软链接可交叉文件系统;
- 软链接可对文件或目录创建;
- 创建软链接时,链接计数 i_nlink 不会增加;
- 删除软链接并不影响被指向的文件,但若被指向的原文件被删除,则相关软连接被称为死链接(即 dangling link,若被指向路径文件被重新创建,死链接可恢复为正常的软链接)。
# 软链接命令
link -s oldfile newfile
ln -s oldfile newfile
3.Linux常用命令有哪些?
1、显示日期的指令: date
2、显示日历的指令:cal
3、简单好用的计算器:bc
4、重要的几个热键[Tab],[ctrl]-c, [ctrl]-d
5、man
6、数据同步写入磁盘: sync
7、惯用的关机指令:shutdown 重启,关机: reboot, halt,poweroff
8、切换执行等级: init
9、改变文件的所属群组:chgrp
10、改变文件拥有者:chown
11、改变文件的权限:chmod
12、查看版本信息等 uname -r cat /etc/issue
13、变换目录:cd
14、显示当前所在目录:pwd
15、建立新目录:mkdir
16、删除『空』的目录:rmdir
17、档案与目录的显示:ls
18、复制档案或目录:cp
19、移除档案或目录:rm
20、移动档案与目录,或更名:mv
21、取得路径的文件名与目录名:basename,dirname
22、由第一行开始显示档案内容:cat
23、从最后一行开始显示:tac(可以看出 tac 是 cat 的倒着写)
24、显示的时候,顺道输出行号:nl
25、一页一页的显示档案内容:more
26、与 more 类似,但是比 more 更好的是,他可以往前翻页:less
27、只看头几行:head
28、只看尾几行:tail
29、以二进制的放置读取档案内容:od
30、修改档案时间或新建档案:touch
31、档案预设权限:umask
32、配置文件档案隐藏属性:chattr
33、显示档案隐藏属性:lsattr
34、观察文件类型:file
35、寻找【执行挡】:which
36、寻找特定档案:whereis
37、寻找特定档案:locate
38、寻找特定档案:find
39、压缩文件和读取压缩文件:gzip,zcat
40、压缩文件和读取压缩文件:bzip2,bzcat
41、压缩文件和读取压缩文件:tar
4.怎么看一个Java线程的资源耗用?
- 先用top命令找出占用资源厉害的java进程id
top
top -p 12377 -H
要想找到到底是哪段具体的代码占用了如此多的资源,先使用jstack打出当前栈信息到一个文件里, 比如stack.log:
jstack 12377 > stack.log
然后使用'jtgrep'脚本把这个进程号为'15417'的java线程在stack.log中抓出来:
jtgrep 15417 stack.log
常用jvm命令:
#虚拟机进程状况
jps [ options ] [ hostid ]
#虚拟机统计信息监视工具
jstat
#java配置信息工具。(pid为进程号)
jinfo [ option ] pid
#java 内存映像工具 (vmid一般是通过jps查到)
jmap [ option ] vmid
#虚拟机堆转储快照分析工具
jhat
#java堆栈跟踪工具 (vmid一般是通过jps查到)
jstack [ option ] vmid
5.Load过高的可能性有哪些?
uptime
13:33:37 up 7 days, 1:52, 1 user, load average: 4.15, 2.00, 3.14
load average 后面三个值代表系统在1分钟、5分钟和15分钟的负载情况,都知道数字越高表示系统负载越大,第一直觉就是这个系统不行了。load average 是0的时候都认为他很低,10的时候就觉得高,20就不用讲了!
6./etc/hosts文件什么做用?
本地的DNS
7.如何快速的将一个文本中所有“abc”替换为“xyz”?
sudo sed -i "s/abc/xyz/g" file_path
8.如何在log文件中搜索找出error的日志?
cat xxx.log > grep error
9.发现磁盘空间不够,如何快速找出占用空间最大的文件?
一级一级的找
du -sh /*
10.Java服务端问题排查(OOM,CPU高,Load高,类冲突)
常用jvm命令:
#虚拟机进程状况
jps [ options ] [ hostid ]
#虚拟机统计信息监视工具
jstat
#java配置信息工具。(pid为进程号)
jinfo [ option ] pid
#java 内存映像工具 (vmid一般是通过jps查到)
jmap [ option ] vmid
#虚拟机堆转储快照分析工具
jhat
#java堆栈跟踪工具 (vmid一般是通过jps查到)
jstack [ option ] vmid
11.Java常用问题排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)
12.Thread dump文件如何分析(Runnable,锁,代码栈,操作系统线程ID关联)
13.如何查看Java应用的线程信息?
以下是针对tomcat上的应用的. 其他的java程序, 只要你能触发他的thread dump并且拿到结果, 也是一样.
-
ps -ef | grep java找到你的java程序的进程id, 定位 pid
-
top -Hp $pidshift+t 查看耗cpu时间最多的几个线程, 记录下线程的id
-
把上诉线程ID转换成16进制小写 比如 : 0x12ef
-
kill -3 $pid 触发tomcat的thread dump
-
找到tomcat的catalin.out 日志, 把 上面几个线程对应的代码段拿出来.DONE.
目录列表
一、数据结构与算法基础
二、Java基础
三、JVM
四、多线程/并发
五、Linux使用与问题分析排查
六、框架使用
七、数据库相关
八、网络协议和网络编程
九、Redis等缓存系统/中间件/NoSQL/一致性Hash等
十、设计模式与重构
本文是针对知乎文章《成为Java顶尖程序员,先过了下面问题》的解答