1. 首页
  2. >
  3. 前端开发
  4. >
  5. HTML5

「Linux命令」-Java程序员需要掌握的10个命令

作为服务端开发的同学,经常会与linux服务器打交道,一些用的命令必须要掌握。

1.top命令-观察服务端负载情况

top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器

「Linux命令」-Java程序员需要掌握的10个命令

1.top命令

2.free命令-查看服务端内存情况

free 命令显示系统内存的使用情况,包括物理内存、交换内存(swap)和内核缓冲区内存

「Linux命令」-Java程序员需要掌握的10个命令

2.free命令

3.df命令-查看你的磁盘情况

# df -h  Filesystem      Size  Used   Avail Use% Mounted on  /dev/sda6       29G   4.2G   23G   16%     /  udev            1.5G  4.0K   1.5G   1%     /dev  tmpfs           604M  892K   603M   1%     /run  none            5.0M     0   5.0M   0%     /run/lock  none            1.5G  156K   1.5G   1%     /run/shm 

4.du命令-显示目录或文件的大小

查看指定文件

$ du -sh Identity 4.0K	Identity

查看指定目录

$ du -h Downloads  44K	Downloads/$RECYCLE.BIN/.prl_rec  48K	Downloads/$RECYCLE.BIN 7.4M	Downloads/.tmp  95M	Downloads/poko-play-with-new-friends_2.2.5 742M	Downloads

5.tail命令-查看日志

tail 命令可用于查看文件的内容,有一个常用的参数 -f 常用于查阅正在改变的日志文件

  • f 循环读取
  • -q 不显示处理信息
  • -v 显示详细的处理信息
  • -c<数目> 显示的字节数
  • -n<行数> 显示文件的尾部 n 行内容
  • --pid=PID 与-f合用,表示在进程ID,PID死掉之后结束
  • -q, --quiet, --silent 从不输出给出文件名的首部
  • -s, --sleep-interval=S 与-f合用,表示在每次反复的间隔休眠S秒

例如 循环读取一个正在运行的日志tomact.log,查找有关键字‘1024BIT’的日志

tail -f tomcat.log | grep '1024BIT'

6.find/grep-查找文件

find / -name filename.txt 根据名称查找/目录下的filename.txt文件。  find . -name "*.xml" 递归查找所有的xml文件  find . -name "*.xml" |xargs grep "hello world" 递归查找所有文件内容中包含hello world的xml文件  grep -H 'spring' *.xml 查找所以有的包含spring的xml文件  find ./ -size 0 | xargs rm -f & 删除文件大小为零的文件  ls -l | grep '.jar' 查找当前目录中的所有jar文件  grep 'test' d* 显示所有以d开头的文件中包含test的行。  grep 'test' aa bb cc 显示在aa,bb,cc文件中匹配test的行。  grep '[a-z]\{5\}' aa 显示所有包含每个字符串至少有5个连续小写字符的字符串的行。

7.netstat-查看服务及监听端口

[root@localhost ~]# netstat -ntlp   //查看当前所有tcp端口· [root@localhost ~]# netstat -ntulp |grep 80   //查看所有80端口使用情况· [root@localhost ~]# netstat -an | grep 3306   //查看所有3306端口使用情况·   [root@localhost ~]# netstat -nlp |grep LISTEN   //查看当前所有监听端口·

8.ps-查看一个程序是否运行

ps –ef|grep tomcat 查看所有有关tomcat的进程

ps aux|grep java 查看java进程

ps aux 查看所有进程

9.查看端口属于哪个程序

lsof -i :8080

10.java 常用命令

java命令

Java是通过java虚拟机来装载和执行编译文件(class文件)的,java虚拟机通过命令java  option 来启动,-option为虚拟机参数,通过这些参数可对虚拟机的运行状态进行调整

javac命令

编译命令,将java源文件编译成.class字节码文件


jps命令

jps是jdk提供的一个查看当前java进程的小工具, 可以看做是JavaVirtual Machine Process Status Tool的缩写。非常简单实用。

jstat命令

jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。

例如垃圾回收统计

「Linux命令」-Java程序员需要掌握的10个命令

1.jstat -gc pid

S0C:第一个幸存区的大小 S1C:第二个幸存区的大小 S0U:第一个幸存区的使用大小 S1U:第二个幸存区的使用大小 EC:伊甸园区的大小 EU:伊甸园区的使用大小 OC:老年代大小 OU:老年代使用大小 MC:方法区大小 MU:方法区使用大小 CCSC:压缩类空间大小 CCSU:压缩类空间使用大小 YGC:年轻代垃圾回收次数 YGCT:年轻代垃圾回收消耗时间 FGC:老年代垃圾回收次数 FGCT:老年代垃圾回收消耗时间 GCT:垃圾回收消耗总时间

每隔一秒查看gc情况

「Linux命令」-Java程序员需要掌握的10个命令

jstat -gcutil pid ms

S0:幸存1区当前使用比例 S1:幸存2区当前使用比例 E:伊甸园区使用比例 O:老年代使用比例 M:元数据区使用比例 CCS:压缩使用比例 YGC:年轻代垃圾回收次数 FGC:老年代垃圾回收次数 FGCT:老年代垃圾回收消耗时间 GCT:垃圾回收消耗总时间

jmap

jmap命令是一个可以输出所有内存中对象的工具,甚至可以将VM 中的heap,以二进制输出成文本。

例如打印堆栈信息

jmap -heap pid

$ jmap -heap 3550 Attaching to process ID 3550, please wait... Debugger attached successfully. Server compiler detected. JVM version is 25.65-b01  using thread-local object allocation. Parallel GC with 4 thread(s)  Heap Configuration:    MinHeapFreeRatio         = 0    MaxHeapFreeRatio         = 100    MaxHeapSize              = 2147483648 (2048.0MB)    NewSize                  = 44564480 (42.5MB)    MaxNewSize               = 715653120 (682.5MB)    OldSize                  = 89653248 (85.5MB)    NewRatio                 = 2    SurvivorRatio            = 8    MetaspaceSize            = 21807104 (20.796875MB)    CompressedClassSpaceSize = 1073741824 (1024.0MB)    MaxMetaspaceSize         = 17592186044415 MB    G1HeapRegionSize         = 0 (0.0MB)  Heap Usage: PS Young Generation Eden Space:    capacity = 34078720 (32.5MB)    used     = 23307912 (22.22815704345703MB)    free     = 10770808 (10.271842956542969MB)    68.39432936448317% used From Space:    capacity = 5242880 (5.0MB)    used     = 0 (0.0MB)    free     = 5242880 (5.0MB)    0.0% used To Space:    capacity = 5242880 (5.0MB)    used     = 0 (0.0MB)    free     = 5242880 (5.0MB)    0.0% used PS Old Generation    capacity = 89653248 (85.5MB)    used     = 0 (0.0MB)    free     = 89653248 (85.5MB)    0.0% used  3124 interned Strings occupying 227824 bytes.

导出dump堆

jmap -dump:live,format=b,file=文件名称 pid

「Linux命令」-Java程序员需要掌握的10个命令

jmap导出堆信息


jstack

jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项"-J-d64",

例如打印pid为3550的java程序的堆栈信息

jstat -l 3550

结果

$ jstack -l 3550 2020-09-20 09:04:49 Full thread dump Java HotSpot(TM) 64-Bit Server VM (25.65-b01 mixed mode):  "Attach Listener" #12 daemon prio=9 os_prio=31 tid=0x00007f8835143800 nid=0x5103 waiting on condition [0x0000000000000000]    java.lang.Thread.State: RUNNABLE     Locked ownable synchronizers: 	- None  "nioEventLoopGroup-2-1" #11 prio=10 os_prio=31 tid=0x00007f8835a6a800 nid=0x4f03 runnable [0x000070000c3cf000]    java.lang.Thread.State: RUNNABLE 	at sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) 	at sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:198) 	at sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) 	at sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:86) 	- locked <0x000000079607a3b0> (a io.netty.channel.nio.SelectedSelectionKeySet) 	- locked <0x00000007960687d0> (a java.util.Collections$UnmodifiableSet) 	- locked <0x00000007960637e0> (a sun.nio.ch.KQueueSelectorImpl) 	at sun.nio.ch.SelectorImpl.select(SelectorImpl.java:97) 	at io.netty.channel.nio.SelectedSelectionKeySetSelector.select(SelectedSelectionKeySetSelector.java:62) 	at io.netty.channel.nio.NioEventLoop.select(NioEventLoop.java:753) 	at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:408) 	at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:897) 	at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30) 	at java.lang.Thread.run(Thread.java:745)     Locked ownable synchronizers: 	- None  "Service Thread" #9 daemon prio=9 os_prio=31 tid=0x00007f88348a1800 nid=0x4b03 runnable [0x0000000000000000]    java.lang.Thread.State: RUNNABLE     Locked ownable synchronizers: 	- None  "C1 CompilerThread2" #8 daemon prio=9 os_prio=31 tid=0x00007f88360ae800 nid=0x4903 waiting on condition [0x0000000000000000]    java.lang.Thread.State: RUNNABLE     Locked ownable synchronizers: 	- None  "C2 CompilerThread1" #7 daemon prio=9 os_prio=31 tid=0x00007f88350b8800 nid=0x4703 waiting on condition [0x0000000000000000]    java.lang.Thread.State: RUNNABLE     Locked ownable synchronizers: 	- None  "C2 CompilerThread0" #6 daemon prio=9 os_prio=31 tid=0x00007f8835062800 nid=0x4503 waiting on condition [0x0000000000000000]    java.lang.Thread.State: RUNNABLE     Locked ownable synchronizers: 	- None

这里我们就可以分析线程是不是有问题。


这十个命令是开发中常用的命令,特别是JAVA程序员在面临JVM调优的时候,JAVA相关命令熟悉非常重要。这些命令我工作当中经常使用到。

uni-app漂亮UI框架分享-兼容头条/微信等小程序
« 上一篇 2020年11月03日 pm23:23
Nginx部署Vue项目以及解决刷新页面404
下一篇 » 2020年11月04日 am07:46

相关推荐