https://mp.weixin.qq.com/s/IR4yy7Q0mOA_XV16R21CdQ

一:Linux下tomcat服务的启动、关闭与错误跟踪

使用PuTTy远程连接到服务器以后,通常通过以下几种方式启动关闭tomcat服务:
切换到tomcat主目录下的bin目录

> cd usr/local/tomcat/bin

启动tomcat服务

  • 方式一:直接启动

> ./startup.sh
  • 方式二:作为服务启动

> nohup ./startup.sh &
  • 方式三:控制台动态输出方式启动

> ./catalina.sh run

动态地显示tomcat后台的控制台输出信息,Ctrl+C后退出并关闭服务

解释:
通过方式一、方式三启动的tomcat有个弊端,当客户端连接断开的时候,tomcat服务也会立即停止,通过方式二可以作为linux服务一直运行
通过方式一、方式二方式启动的tomcat,其日志会写到相应的日志文件中,而不能动态地查看tomcat控制台的输出信息与错误情况,通过方式三可以以控制台模式启动tomcat服务,
直接看到程序运行时后台的控制台输出信息,不必每次都要很麻烦的打开catalina.out日志文件进行查看,这样便于跟踪查阅后台输出信息。
tomcat控制台信息包括log4j和System.out.println()等输出的信息。

关闭tomcat服务

> ./shutdown.sh

tomcat运行时jvm内存分配

  • ⑴ 开发环境下在myeclipse中配置

-Xms256m -Xmx512m -XX:NewSize=64m -XX:MaxNewSize=128m -XX:PermSize=512m -XX:MaxPermSize=512m
  • ⑵ 线上环境(直接通过catalina或startup命令行的方式启动)

①Linux下:catalina.sh

# OS specific support. $var _must_ be set to either true or false.在该注释之后加下面一行

JAVA_OPTS="-server -Xms256m -Xmx512m -XX:NewSize=64m -XX:MaxNewSize=128m -XX:PermSize=512m -XX:MaxPermSize=512m"

②Windows下:cattalina.bat

rem Guess CATALINA_HOME if not defined    在该注释之后加下面一行
set JAVA_OPTS=-Xms256m -Xmx512m -XX:NewSize=64m -XX:MaxNewSize=128m -XX:PermSize=512m -XX:MaxPermSize=512m

二:Linux 下的一些常用命令解释:

pwd显示当前的工作目录(pwd:print working directory)

ls显示当前目录内容(list)

ls|more

分屏显示(“|”为管道符,将前一个命令结果传递给后面的命令,more表示分屏)

> ls /usr>test01/abc.txt

将指定目录的内容追加到test01目录下的abc.txt文本文档中

ls -l    #显示长格式,简写ll,主要看文件的名,大小,权限等
ls -a    #显示隐藏文件

cd改变当前工作目录

> cd /usr	 #转到指定目录
> cd usr    #转到指定目录的子目录
> cd ..      #返回到上一级目录
> cd ~ 	  #返回到主目录

clear清屏

cat显示文件内容

> cat file|more	   #分屏显示文件内容(先显示文件内容,再将结果内容传给后一个命令分屏)
> cat file|grep abc    #显示包含字符abc的文件内容(先显示文件内容,再将结果内容传给后一个命令搜索,grep具有搜索功能)
cat > catalina.out      #清空日志内容

touch创建新文件

mkdir创建新目录

rm删除文件或目录

> rm file.txt	#删除文件
> rm -rf test01  #删除不为空的目录(参数r:递归recursion,f:强制force)

rmdir删除空目录

cp复制文件

> cp src.txt dest.txt

mv移动文件

> mv abc.txt def.txt     #改名
> mv test01 test02    #改目录名
> mv test     #相当于mv t+(按Tab键),tab键有查找补充命令功能。

chmod改变权限模式

> chmod +x catalina.sh   #为catalina.sh加可执行的权限(参数x:执行execute)。linux下的文件是否可执行取决于文件属性,不看扩展名。
> chmod a+r catalina.out    #将文件 catalina.out 设为所有人皆可读取。(参数a:所有人all)
> chmod ugo+r catalina.out     #也是将文件 catalina.out 设为所有人皆可读取。(参数u:档案拥有者user,g:group群组,o:other其他)

viLinux下的一个简单编辑器

> vi .bash_profile     #打开Linux的用户级初始文件,:wq保存退出,:q!不保存退出

tail显示文件尾部内容

> tail -f ./catalina.out    #将文件最尾部内容显示在屏幕上,并不断刷新显示,按ctrl+c或delete退出。

netstat、lsof查看网络端口与进程号

① 直接查看指定端口的进程pid

> netstat -anp|grep 8080
# 结果为:
 协议  本地地址          外部地址        状态           PID
 TCP   0.0.0.0:80      0.0.0.0:8080    LISTENING      5144/java

② 直接查看指定端口的进程pid

lsof -i:8080
# 结果为
  COMMAND   PID   USER   FD   TYPE  DEVICE     SIZE NODE NAME
  java     5144   root   33u  IPv6  127800   TCP *:8080 (LISTEN)

则5144为8080这个端口的tomcat进程的pid,然后就可以kill这个进程:

kill -9 5144

对比Windows下netstat命令:

> netstat -ano|findstr 8080,taskkill -f -pid 5144 		#(f:force强制)

ping查看网络是连通

> ping 127.16.8.66    #查看当前机器与目录机器是否能正常通信(主要是看TCP/IP协议是否正常)

ipconfig查看ip地址

> ipconfig -all    #可以看到各个网络适配器(本地网卡、无线网卡)的IP地址和MAC地址

ps查看程序活动进程

> ps -ef |grep tomcat	#查看是否已经有tomcat在运行了,如果有则将其进程杀死
#结果为:
sun 1540 1 0 10:21 pts/1 00:00:06 /java/jdk/bin/java -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/java/tomcat/common/endorsed -classpath :/java/tomcat/bin/bootstrap.jar:/java/tomcat/bin/commons-logging-api.jar -Dcatalina.base=/java/tomcat -Dcatalina.home=/java/tomcat -Djava.io.tmpdir=/java/tomcat/temp org.apache.catalina.startup.Bootstrap start

Bootstrap start 说明tomcat已经正常启动,则 1540 就为进程号 pid = 1540,然后就可以kill这个进程:

> kill -9 1540

对比Windows下tasklist命令:

> tasklist | findstr tomcat,taskkill -f -pid 5144

telnet测试远程端口是否连通

> telnet 10.4.200.114 1433

①端口通畅的情况

Trying 10.4.200.114...
Connected to 10.4.200.114 (10.4.200.114).
Escape character is '^]'.

②端口不通的情况

Trying 10.4.200.114...

如果能ping通,但端口不通,说明有可能被防火墙禁用了该端口
解决办法:
linux下:查看防火墙:

> iptables –L

即时生效,重启后失效。 (开启: service iptables start ,关闭: service iptables stop)

设置防火墙:setup (乱码) 解决Putty工具乱码:查看Linux系统当中使用的字符集echo $LANG $LANGUAGE,选择菜修改设置(change settings)—>转换(translation)–>选utf-8–>应用(apply)

win7下防火墙开放端口方法:控制面板–系统和安全—windows防火墙—高级设置–入站规则–新建规则–>添加1433端口。

df查看磁盘空间(diskfree)

> df -lh /usr/local

du查看已使用空间(diskused)

> du -h /usr
> du -h --max-depth=1	#查看文件夹大小

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

> top -s	#查看内存使用情况> top -s | grep java    #查看java进程的信息

tar、zip

1. tar.gz这种格式是Linux下使用得最多的压缩格式。它在压缩时不会占用太多CPU的,而且可以得到一个非常理想的压缩率。

> tar -zcvf archive_name.tar.gz directory_to_compress     #压缩一个目录
> tar -zxvf archive_name.tar.gz      #解压缩到当前目录下
> tar -zxvf archive_name.tar.gz -C /usr/temp/     #解压缩到指定目录下
参数解释:
-z  -gzip 调用gzip对tar归档文件进一步压缩成tar.gz格式,或者对tar.gz格式完成解压缩
-x  -extract 解压缩已归档的指定(或所有)文件
-c  -create 创建新的归档文件
-v  -verbose 生成详细输出
-f  -file 指定归档文件名
-r  向归档文件末尾追加文件
-C 改变目录

2. 压缩/解压zip格式

> zip file.zip ./directory/*    #压缩指定目录下的所有文件及目录
> unzip file.zip -d ./test    #解压缩到指定目录
> unzip file.zip     #解压缩到当前目录
> unzip -v largefile.zip  #只查看压缩包的内容,并不解压缩

三:Linux与Windows的几点区别:

> echo $PATH      #回显Linux环境变量PATH的值,Linux下的环境变量必须大写
> echo %path%    #回显Windows环境变量path的值
> export PATH=/usr/local/tomcat     #修改设置Linux环境变量PATH的值(临时),Linux文件系统路径是斜杠
> set path=D:\Program Files\tomcat    #修改Windows环境变量path的值(临时),Windows文件系统路径是反斜杠

Linux:查看、修改Linux下的用户级初始文件(.bash_profile),它是个隐藏文件(永久)
Windows:计算机–>属性–>高级–>环境变量;查看、修改环境变量(永久)

Linux命令搜索用grep:

> netstat -anp|grep 8080

Windows Dos命令搜索用findstr:

> netstat -anp|findstr 8080

Linux下Tomcat的启动、关闭、杀死进程

> `cd /java/tomcat`
> bin/startup.sh #启动tomcat
> bin/shutdown.sh #停止tomcat
> tail -f logs/catalina.out #看tomcat的控制台输出;

看是否已经有tomcat在运行了:

> `ps -ef |grep tomcat`

如果有,用kill:

> kill -9 pid #pid 为相应的进程号

例如 ps -ef |grep tomcat 输出如下

sun 5144 1 0 10:21 pts/1 00:00:06 /java/jdk/bin/java -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/java/tomcat/common/endorsed -classpath :/java/tomcat/bin/bootstrap.jar:/java/tomcat/bin/commons-logging-api.jar -Dcatalina.base=/java/tomcat -Dcatalina.home=/java/tomcat -Djava.io.tmpdir=/java/tomcat/temp org.apache.catalina.startup.Bootstrap start

则 5144 就为进程号 pid = 5144kill -9 5144 就可以彻底杀死tomcat

直接查看指定端口的进程pid:

> netstat -anp|grep 9217`
 tcp   0   0 :::9217     :::*        LISTEN      26127/java`

则26127为9217这个端口的tomcat进程的pid,然后就可以kill这个进程:

> kill -9 26127

然后再启动tomcat即可

linux下实时查看tomcat运行日志

1. 实时查看tomcat运行日志,先切换到:

> cd tomcat/logs
> tail -f catalina.out
> Ctrl+c  #是退出tail命令。

2. 通过关键字搜索查看日志:

> cat jeewx-2015-09-20.log | grep 验证码

3. 查看固定时间日志:

> cat jeewx-2015-09-20.log | grep '2015-09-20 18:50:15'

4. 查看最近50行日志:

> tail -n 50 -f catalina.out