1.日常语句
1常用语句
pwd 查询当前的文件路径
cd root 即到~目录
cd xxx 打开某个文件夹
查看端口使用
netstat -anp|grep 21
关于LINUX权限-bash: ./startup.sh: Permission denied
用命令chmod 修改一下bin目录下的.sh权限就可以了
如chmod u+x *.sh
文件夹权限
sudo chmod -R 777 你的文件夹名。
创建文件夹
例:mkdir test
创建文件
touch qiantai.txt
2压缩解压
tar
-c: 建立压缩档案
-x:解压
-t:查看内容
-r:向压缩归档文件末尾追加文件
-u:更新原压缩包中的文件
这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命令连用但只能用其中一个。下面的参数是根据需要在压缩或解压档案时可选的。
-z:有gzip属性的
-j:有bz2属性的
-Z:有compress属性的
-v:显示所有过程
-O:将文件解开到标准输出
下面的参数-f是必须的
-f: 使用档案名字,切记,这个参数是最后一个参数,后面只能接档案名。
# tar -cf all.tar *.jpg
这条命令是将所有.jpg的文件打成一个名为all.tar的包。-c是表示产生新的包,-f指定包的文件名。
# tar -rf all.tar *.gif
这条命令是将所有.gif的文件增加到all.tar的包里面去。-r是表示增加文件的意思。
# tar -uf all.tar logo.gif
这条命令是更新原来tar包all.tar中logo.gif文件,-u是表示更新文件的意思。
# tar -tf all.tar
这条命令是列出all.tar包中所有文件,-t是列出文件的意思
# tar -xf all.tar
这条命令是解出all.tar包中所有文件,-x是解开的意思
压缩
tar –cvf jpg.tar *.jpg //将目录里所有jpg文件打包成tar.jpg
tar –czf jpg.tar.gz *.jpg //将目录里所有jpg文件打包成jpg.tar后,并且将其用gzip压缩,生成一个gzip压缩过的包,命名为jpg.tar.gz
tar –cjf jpg.tar.bz2 *.jpg //将目录里所有jpg文件打包成jpg.tar后,并且将其用bzip2压缩,生成一个bzip2压缩过的包,命名为jpg.tar.bz2
tar –cZf jpg.tar.Z *.jpg //将目录里所有jpg文件打包成jpg.tar后,并且将其用compress压缩,生成一个umcompress压缩过的包,命名为jpg.tar.Z
rar a jpg.rar *.jpg //rar格式的压缩,需要先下载rar for Linux
zip jpg.zip *.jpg //zip格式的压缩,需要先下载zip for linux
解压
tar –xvf file.tar //解压 tar包
tar -xzvf file.tar.gz //解压tar.gz
tar -xjvf file.tar.bz2 //解压 tar.bz2
tar –xZvf file.tar.Z //解压tar.Z
unrar e file.rar //解压rar
unzip file.zip //解压zip
总结
1、.tar 用 tar –xvf 解压
2、.gz 用 gzip -d或者gunzip 解压
3、.tar.gz和.tgz 用 tar –xzf 解压
4、.bz2 用 bzip2 -d或者用bunzip2 解压
5、.tar.bz2用tar –xjf 解压
6、.Z 用 uncompress 解压
7、.tar.Z 用tar –xZf 解压
8、.rar 用 unrar e解压
9、.zip 用 unzip 解压
3服务器状态
free 查看内存使用
free -h 以M为单位查看内存使用
total used free shared buff/cache available
Mem: 488M 354M 6.3M 368K 127M 110M
Swap: 0B 0B 0B
查看硬盘使用
df -h
文件系统 容量 已用 可用 已用% 挂载点
/dev/vda1 40G 2.2G 36G 6% /
devtmpfs 911M 0 911M 0% /dev
tmpfs 920M 0 920M 0% /dev/shm
tmpfs 920M 312K 920M 1% /run
tmpfs 920M 0 920M 0% /sys/fs/cgroup
tmpfs 184M 0 184M 0% /run/user/0

4编写脚本
/home/wwwroot/ftptest/config/server.properties
/Users/apple/MyProject/myFile
5vim 编辑
如何直接不保存退出
保存退出(推荐)
:wq
不保存退出(推荐)
:q!
直接退出
:q
6权限配置
开放文件权限
sudo chmod -R 777 file
#! /bin/bash
# redeploy my project
# write by lys
echo "打印tomcat的webapps的东西"
7查看文件内容的命令
Cat file:用于显示指定文件的全部内容
More file:用分页的形式显示指定文件的内容
Less file:用分页的形式显示指定文件的内容,区别是more和less翻页使用的操作键不同。
Head file:用于显示文件的前n行内容。
Tail file:用于显示文件的后n行内容。
Tail -f file:用于自动刷新的显示文件后n行数据内容。
8系统相关
显示系统中有哪些用户正在使用
(结果会扎实使用人的信息 发起连接的时间 以及ip地址)
[root@test2 local]# who
root pts/0 2020-07-10 08:42 (192.168.21.15)
显示系统时间
[root@test2 local]# date
2020年 07月 10日 星期五 08:50:36 CST
clear:清屏
9查找文件
find命令
输入find --help 可查看该命令的使用说明
find -name "*.txt",查找后辍名为.txt的文件。
[root@test2 ~]# find -name "*.txt"
./antDep/release_build/build/ipmsLogin/readme.txt
./antDep/release_build/build/ipms/readme.txt
./antDep/database/updatestructsql/pos/pos_deposit_history.txt
./antDep/database/updatestructsql/pos/pos_deposit.txt
./antDep/database/updatestructsql/resrv/code_dictionary.txt
在指定目录下查找
输入命令:find Test2 -name "*.txt",在目录Test2下查找后辍名为.txt的文件。
[root@test2 tomcat5]# find logs -name "*.out"
logs/catalina.out
输入命令:find -ctime 15,查找最近15天修改过的文件。bash
[root@test2 local]# find -ctime 15
./nginx/proxy_temp/9/05
./nginx/proxy_temp/9/00
./nginx/proxy_temp/9/11
查找文件大小大于20M的文件。
[root@test2 local]# find -size +20M
./nodejs/bin/node
./publish_platform_admin4ui/admin.war
./publish_platform-job-admin/platform-job-admin.war
./publish_platform-data-center-admin/platform-data-center-admin.war
10.下载文件
sz file
[root@test2 logs]# ls
catalina.2020-07-09.log catalina.out host-manager.2020-07-09.log localhost.2020-07-09.log manager.2020-07-09.log platform-distribution-web.log
[root@test2 logs]# sz catalina.out
2.问题排查常用
1.查询所有tomcat的进程
ps -ef|grep tomcat
2.查询某个日志中关键字
比如线上有一个bug,想知道日志输出的错误再哪里,找日志的关键字
方法一:cat 路径/文件名 | grep 关键词
cat test.log | grep "http" # 返回test.log中包含http的所有行
[root@test2 logs]# cat catalina.out | grep "updateResrvBaseSync"
at com.greencloud.facade.impl.WxPlatformResrvFacadeServiceImpl.updateResrvBaseSync(WxPlatformResrvFacadeServiceImpl.java:224)
at com.sun.proxy.$Proxy259.updateResrvBaseSync(Unknown Source)
at com.sun.proxy.$Proxy330.updateResrvBaseSync(Unknown Source)
at com.greencloud.facade.impl.WxPlatformResrvFacadeServiceImpl.updateResrvBaseSync(WxPlatformResrvFacadeServiceImpl.java:224)
根据关键字查看后10行日志
cat catalina.out | grep "updateResrvBaseSync" -A 10
根据关键字查看前10行日志
cat catalina.out | grep "updateResrvBaseSync" -B 10
根据关键字查看前后10行日志,并显示出行号(推荐前后50行,一般就可以确定问题了☆)
cat catalina.out | grep "updateResrvBaseSync" -C 10
3.查询端口是否被占用,以及杀死线程
netstat -anp |grep 端口号 如果没有LISTEN那一行,就表示没有被占用
[root@test2 local]# netstat -anp |grep 8080
tcp 0 0 0.0.0.0:8080 0.0.0.0:* LISTEN 10203/java
tcp 0 0 192.168.0.106:6379 192.168.0.202:28080 ESTABLISHED 15333/redis-server
4.查看当前所有已经使用的端口情况
[root@test2 local]# netstat -nultp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 127.0.0.1:8032 0.0.0.0:* LISTEN 9451/java
tcp 0 0 127.0.0.1:2208 0.0.0.0:* LISTEN 3921/./hpiod
tcp 0 0 127.0.0.1:8035 0.0.0.0:* LISTEN 11494/java
tcp 0 0 0.0.0.0:8101 0.0.0.0:* LISTEN 19952/java
tcp 0 0 127.0.0.1:8005 0.0.0.0:* LISTEN 10203/java
tcp 0 0 0.0.0.0:9999 0.0.0.0:* LISTEN 22832/java