成为Java顶尖程序员,先过了下面问题!(四)

2017-12-24  本文已影响120人  d394af621d4c

五、Linux使用与问题分析排查

1.使用两种命令创建一个文件?
touch hello.txt
echo "" > hello.txt

vim hello.txt
:wq
2.硬链接和软链接的区别?

硬链接是有着相同 inode 号仅文件名不同的文件,存在以下几点特性:

# 硬链接命令
link oldfile newfile 
ln oldfile newfile

软链接与硬链接不同,若文件用户数据块中存放的内容是另一文件的路径名的指向,则该文件就是软连接。软链接就是一个普通文件,只是数据块内容有点特殊。软链接有着自己的 inode 号以及用户数据块(见

图 2.)。因此软链接的创建与使用没有类似硬链接的诸多限制:

soft-hard-link.jpg
# 软链接命令
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
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并且拿到结果, 也是一样.

  1. ps -ef | grep java找到你的java程序的进程id, 定位 pid

  2. top -Hp $pidshift+t 查看耗cpu时间最多的几个线程, 记录下线程的id

  3. 把上诉线程ID转换成16进制小写 比如 : 0x12ef

  4. kill -3 $pid 触发tomcat的thread dump

  5. 找到tomcat的catalin.out 日志, 把 上面几个线程对应的代码段拿出来.DONE.

目录列表
一、数据结构与算法基础
二、Java基础
三、JVM
四、多线程/并发
五、Linux使用与问题分析排查
六、框架使用
七、数据库相关
八、网络协议和网络编程
九、Redis等缓存系统/中间件/NoSQL/一致性Hash等
十、设计模式与重构
本文是针对知乎文章《成为Java顶尖程序员,先过了下面问题》的解答

上一篇下一篇

猜你喜欢

热点阅读