日常开发,上线的服务器系统一般都是Linux系统,所以,熟练的掌握常用的命令操作就尤其的重要了
1) 查看某个服务的运行情况 (例如Redis)
ps -ef | grep redis //e-显示程序使用的环境变量 f-显示UID,PPIP,C与STIME栏位
2) 查看某个端口是否在监听
netstat -lntp | grep 6379
//查看监听的端口的程序
netstat -anp | grep 9501
3)查看linux占用内存/CPU最多的进程
可以使用一下命令查使用内存最多的10个进程
ps -aux | sort -k4nr | head -n 可以使用一下命令查使用CPU最多的10个进程
ps -aux | sort -k3nr | head -n 10 参数说明:
sort
-k: 进行排序的栏位
4/3 对应的栏位位置
-n: 按照数值大小排序
-r: 反向排序
动态的查看进程: 用top命令指定固定的PID
top -p 32199
使用了top期间,支持命令,
h ==》 会显示如何使用的帮助
M ==〉 通过内存占用率大小进行排序
P ==》 按照CPU使用率进行大小排序 默认只是显示部分的进程数据, 如果想要查看全部的进程信息, 可以将信息重定向到文件中
top -n -b 1 -d 3 >> file.txt
参数:
-b :batch模式,可以重定向到文件中
-n 1:一共取1次top数据。后边加数字,表示次数
-d 3:每次top时间间隔是3秒钟
-c : 不仅仅显示进程名称, 而是显示完整执行命令
查看更详细的内存占比
cat /proc//status Name: java
State: S (sleeping)
Tgid:
Ngid:
Pid:
PPid:
TracerPid:
Uid:
Gid:
FDSize:
Groups:
NStgid:
NSpid:
NSpgid:
NSsid:
VmPeak: kB
VmSize: kB
VmLck: kB
VmPin: kB
VmHWM: kB
VmRSS: kB
VmData: kB
VmStk: kB
VmExe: kB
VmLib: kB
VmPTE: kB
VmPMD: kB
VmSwap: kB
HugetlbPages: kB
Threads:
SigQ: /
SigPnd:
ShdPnd:
SigBlk:
SigIgn:
SigCgt: 2000000181005ccc
CapInh:
CapPrm:
CapEff:
CapBnd: 0000003fffffffff
CapAmb:
Seccomp:
Cpus_allowed: ff
Cpus_allowed_list: -
Mems_allowed: ,
Mems_allowed_list:
voluntary_ctxt_switches:
nonvoluntary_ctxt_switches:
VmRSS为内存
Redis
(1) 开启客户端连接Redis
redis-cli
(2) 退出客户端的连接
redis-cli shutdown
或
kill -9 PID
(3)常用启动/停止/重启
./etc/init.d/redis-server start ./etc/init.d/redis-server stop ./etc/init.d/redis-server restart
MySQL
查看MySQL的运行状态
/etc/rc.d/init.d/mysqld status
频繁使用
1. 计算某个文件大小
1) du -h 文件
2) ls -hl 文件
2. 重启网卡服务
service network restart
3. 相关服务重启
/etc/init.d/redis restart
4. 查看磁盘信息
df -h //以kb显示(常用) 默认使用b显示
5. 关机,重启
init 0 //关机 init 6 //友好重启 reboot //出状况或强制重启
6. 软连接
ln -s 源文件 目标文件
7.查找某个命令或文件
find / -name 文件名称 // find的方式进行查找 whereis 文件名称 //使用whereis方式进行查找 which 文件名称 // 使用which的方式进行查找 locate 文件名称 //使用locate的方式进行查找
8. 常见统计
wc -l 文件名称 // 统计行数 wc -c 文件名称 // 统计字节数 wc -w 文件名称 // 统计字数 //以上命令可以同时组合使用,例如:
wc -lwc file1 file2
.sql
.sql
total
9. 文件排序
. 按照文件大小排序 ls -lSh
total 89M
-rw-r--r-- Administrator 8月 :
89M -rw-r--r-- Administrator 89M 8月 : .sql
36K -rw-r--r-- Administrator 36K 8月 : .sql
20K -rw-r--r-- Administrator 17K 8月 : .sql
16K -rw-r--r-- Administrator 15K 8月 : .sql
.0K -rw-r--r-- Administrator .3K 8月 : .sql
解释:
-l : 长格式显示
-S: 排序,默认降序(注意是大写S)
-h: 表示文件大小转成M来显示 当然可以使用升序 -r : 升序排列 . 按照文件修改时间排序
ls -lt
total
-rw-r--r-- Administrator 8月 :
-rw-r--r-- Administrator 8月 : .sql
-rw-r--r-- Administrator 8月 : .sql
-rw-r--r-- Administrator 8月 : .sql
-rw-r--r-- Administrator 8月 : .sql
-rw-r--r-- Administrator 8月 : .sql
解释:
-t: 最近的修改时间
默认是降序: 最后修改的在前面
当然也可以加上参数 -r 进行升序排序
10.文件或目录统计
1. 显示目录或者文件所占空间
du 2. 显示指定文件所占空间
du filename/dirname 3. 显示多个文件所占空间
du file1 file2 file3 4. 只显示总和的大小
du -sh
-s:仅显示总计
-h:以友好的单位显示K,M,G 5. 显示几个文件或目录各自占用磁盘空间的大小,还统计它们的总和
du -ch file1 file2 file3 6. 按照空间大小排序
du|sort -nr|more 7. 输出当前目录下各个子目录所使用的空间
du -h --max-depth=1 8. 统计目录下文件大小
du -sh * 9. 统计文件大小并排序
du -s * | sort -nr (倒叙)
10 内容匹配 grep
grep -rn '匹配词' .
//递归的匹配所有的搜索词
11. 文件压缩与解压 tar
文件压缩: tar zcvf FileName.tar.gz DirName 文件解压:
tar zxvf FileName.tar.gz tar.bz2格式
解压:[*******]$ tar jxvf FileName.tar.bz2
压缩:[*******]$ tar jcvf FileName.tar.bz2 DirName tar.gz格式
解压:[*******]$ tar zxvf FileName.tar.gz
压缩:[*******]$ tar zcvf FileName.tar.gz DirName tar格式
解包:[*******]$ tar xvf FileName.tar
打包:[*******]$ tar cvf FileName.tar DirName(注:tar是打包,不是压缩!) zip格式
解压:[*******]$ unzip FileName.zip
压缩:[*******]$ zip FileName.zip DirName
问题: 如果在备份的过程中,文件发生变化会出现报错的情况,导致终端, 可以添加命令 --warning=no-file-changed
12. 查看当前登陆的终端
w :: up days, :, user, load average: 0.00, 0.01, 0.05
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
root pts/ 58.101.106.224 : .00s .10s .00s w 用户名 终端 登陆IP 登陆时间 正在执行的操作
13. 查看CPU信息
. 物理CPU的个数:
cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc -l
. 每个物理CPU的核心数量:
cat /proc/cpuinfo | grep "cpu cores" | uniq
. 逻辑CPU个数:
cat /proc/cpuinfo | grep "processor" | wc -l
centos7
1)systemctl 命令
设置nginx为开机启动项:
systemctl enable nginx
服务相关操作
systemctl start/stop/reload/restart nginx (服务名称)
防火墙
查看防火墙开启状态:
systemctl status firewalld 启动/关闭/重启 防火墙
systemctl [start|stop|restart] firewalld.service 查看80端口是否开放成功:
firewall-cmd --zone=public --query-port=80/tcp 永久开放80端口:
firewall-cmd --zone=public --add-port=80/tcp --permanent 移除80端口号:
firewall-cmd --permanent --zone=public --remove-port=80/tcp 重启防火墙(设置完成一定要设置):
firewall-cmd --reload
2)sudo
临时获取最高权限
sudo -s
切换用户
su - vagrant //切换回vagrant用户
华丽分割线
命令安装
1) locate
可能一开始使用这个命令的时候,是无法使用的,需要你自己进行安装
yum install locate
//可能发生的错误, 没有可用的软件包 locate 的情况 //进行安装mlocate进行解决
yum install -y mlocate //安装成功之后,就可以愉快的使用locate命令进行内容的查找了, 呃呃呃,但是好像还是有问题,还差一步,对,那就是更新索引库
updatedb //如果更新之后,还是搜索不到的话,那么可以查看配置文件,是否有限制
vim /etc/updatedb.conf
- PRUNE_BIND_MOUNTS = “yes” 表示开启搜索限制,如果为’no’则表示不开启搜索限制;
- PRUNEFS = 表示搜索时,不搜索的文件系统;
- PRUNENAMES = 表示搜索时,不搜索的文件类型;
- PRUNEPATHS = 表示搜索时,不搜索的路径;
日常
pbcopy < ~/.ssh/id_rsa.pub //Windows中的类似使用
clip < ~/.ssh/id_rsa.pub
//使用命令split (windows 下使用git bash工具即可使用该命令) 常用参数:
-<行数> : 指定每多少行切成一个小文件
-b<字节> : 指定每多少字节切成一个小文件 1KB = 1000B 1MB = 1000KB
--help : 在线帮助
--version : 显示版本信息
-C<字节> : 与参数"-b"相似,但是在切 割时将尽量维持每行的完整性
[输出文件名] : 设置切割后文件的前置文件名, split会自动在前置文件名后再加上编号 //实例:
split - index.log #将index.log文件每3000行分割成一个文件 默认多个以''x''开头的文件
3) kill 掉所有匹配到名字的进程
ps aux | grep swoole_job | awk '{print $2}' | xargs kill -
ps 列出所有进程,
参数:
a - 显示现行终端机下的所有进程,包括其他用户的进程;
u - 以用户为主的进程状态 ;
x - 通常与 a 这个参数一起使用,可列出较完整信息。
grep 过滤掉不包含 "swoole" 的行
awk '{print $2}' 获取进程 ID (PID, Process Identification),我们想 kill 掉某一个进程的时候需要通过 PID 指定特定进程
xargs 将标准输入数据转换成命令行参数,xargs能够处理管道或者stdin并将其转换成特定命令的命令参数。
也就是将管道传递过来的每一个 PID 作为 kill -9 的参数
find /tmp -mtime + -exec rm -rf {} \; 注意: 不要忘记最后的分号 mtime: 修改时间(天) {} \; 固定写法, 一堆大括号+空格+\;