常用Linux命令
cd
- cd /root/Docements # 切换到目录/root/Docements
- cd ./path # 切换到当前目录下的path目录中,“.”表示当前目录
- cd …/path # 切换到上层目录中的path目录中,“…”表示上一层目录
ls
- -l :列出长数据串,包含文件的属性与权限数据等
- -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)
- -d :仅列出目录本身,而不是列出目录的文件数据
- -h :将文件容量以较易读的方式(GB,kB等)列出来
- -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来
grep
命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等
- grep [-acinv] [–color=auto] ‘查找字符串’ filename
- -a :将binary文件以text文件的方式查找数据
- -c :计算找到‘查找字符串’的次数
- -c :计算找到‘查找字符串’的次数
- -c :计算找到‘查找字符串’的次数
- -i :忽略大小写的区别,即把大小写视为相同
- -v :反向选择,即显示出没有‘查找字符串’内容的那一行
find 寻找
find [PATH] [option] [action]
与时间有关的参数:
- -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;
- -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;
- -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;
- -newer file : 列出比file还要新的文件名
cp 复制
- -a :将文件的特性一起复制
- -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
- -i :若目标文件已经存在时,在覆盖时会先询问操作的进行
- -r :递归持续复制,用于目录的复制行为
- -u :目标文件与源文件有差异时才会复制
cp from to 拷贝文件
cp -fr ./j2sdk1.4.2_04 /usr/java 拷贝目录
mv 剪切或重命名
- -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
- -i :若目标文件已经存在,就会询问是否覆盖
- -u :若目标文件已经存在,且比目标文件新,才会更新
rm 删除
- -f :就是force的意思,忽略不存在的文件,不会出现警告消息
- -i :互动模式,在删除前会询问用户是否操作
- -r :递归删除,最常用于目录删除,它是一个非常危险的参数
ps 查看进程
- -A :所有的进程均显示出来
- -a :不与terminal有关的所有进程
- -u :有效用户的相关进程
- -x :一般与a参数一起使用,可列出较完整的信息
- -l :较长,较详细地将PID的信息列出
- ps aux # 查看系统所有的进程数据
- ps ax # 查看不与terminal有关的所有进程
- ps -lA # 查看系统所有的进程数据
- ps axjf # 查看连同一部分进程树状态
- ps -ef|grep java 查看进程
- pstree |grep java 查看进程树
ps aux|sort -n -r -k 5|head -5 按资源占用情况来排序,第一个 5 表示第几列,第二个 5 表示前几位
kill
该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:kill -signal PID
-
1:SIGHUP,启动被终止的进程
-
2:SIGINT,相当于输入ctrl+c,中断一个程序的进行
-
9:SIGKILL,强制中断一个进程的进行
-
15:SIGTERM,以正常的结束进程方式来终止进程
-
17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行
-
kill somePid 杀掉某进程
-
kill -9 $(ps -ef|grep udpserver | grep java|awk ‘{print $2}’ ) 删除 udpserver 进程
如果存在进程杀掉
ps -ef | grep container-common-server-0.0.1.jar | grep -v grep | awk ‘{print $2}’ | xargs kill -9后台启动进程输出>/dev/null
setsid java -Xms256m -Xmx512m -jar container-common-server-0.0.1.jar --eureka.client.service-url.defaultZone=http://127.0.0.1:12111/eureka --spring.cloud.config.profile=test > /dev/null 2>&1 &
killall
- -i :交互式的意思,若需要删除时,会询问用户
- -e :表示后面接的command name要一致,但command name不能超过15个字符
- -I :命令名称忽略大小写
例如:
- killall -SIGHUP syslogd # 重新启动syslogd
file
用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的
- file filename
例如:
file ./test
tar
- -c :新建打包文件
- -t :查看打包文件的内容含有哪些文件名
- -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
- -j :通过bzip2的支持进行压缩/解压缩
- -z :通过gzip的支持进行压缩/解压缩
- -v :在压缩/解压缩过程中,将正在处理的文件名显示出来
- -f filename :filename为要处理的文件
- -C dir :指定压缩/解压缩的目录dir
常用tar命令 - 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称
- 查询:tar -jtv -f filename.tar.bz2
- 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录
- tar -xvzf some.tar.gz 解压缩包
- tar –cvzf some.tar.gz fileDir 打压缩包
chgrp 改变文件所属所属用户组
- chgrp [-R] dirname/filename
- -R :进行递归的持续对所有文件和子目录更改
例如:
- chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users
文件权限
-
chown 改变文件所有者
-
chmod 改变文件权限
-
chmod [-R] xyz 文件或目录
-
-R:进行递归的持续更改,即连同子目录下的所有文件都会更改
-
chmod a+x somefile 所有用户都可以执行
-
chmod u+x somefile 当前用户可以执行
-
man rm ( rm --help ) 查看帮助
rpm
-
rpm -qa|grep php 查找RPM 文件
-
rpm -ivh some.rpm 安装软件
-
rpm -Uvh some.rpm 更新软件
-
rpm -qa |grep somesoftName 是否已安装某软件
系统层面
-
pwd 查看当前目录
-
ifconfig IP 地址配置,可以使用 setup 命令启动字符界面来配置
-
查看环境变量 env |grep PATH
-
输出变量名 echo
-
查看端口
netstat -npl
ss -tanl -
开放端口
80端口 iptables -I INPUT -p TCP --dport 80 -j ACCEPT -
mkdir 创建目录
-
rm -r 递归删除, -f 表示 force
-
which java 查看 java 进程对应的目录
-
where java 查看 java 命令目录
-
who 显示当前用户
-
zip -r filename.zip filesdir 某个文件夹打 zip 包
-
unzip somefile.zip 解压 zip 文档到当前目录
-
gunzip somefile.cpio.gz 解压 .gz
-
hostname -i 显示本机机器名,添加 i ,显示 etc/hosts 对应 ip 地址
-
reboot 立即重启服务器,相当于 shutdow –r now
-
关机, init 0
-
定时重启
-
shutdonw -r 23:30
-
shutdown -r +15
-
shutdonw -r +30
-
-
setup 启动文字配置管理界面
-
vi /etc/sysconfig/network 修改机器名 , 然后要重启机器或者 service network restart
-
export LANG=zh_CN.GBK 设定系统语言,解决 consol 中文乱码
-
last 倒序查看已登陆用户历史
-
history 查看历史命令
-
date -s 10/09/2009 修改日期
-
date -s 13:24:00 修改时间,直接 date 显示时间
-
df -k 查看文件磁盘空间
-
df -v 查看文件空间
-
du 查看磁盘空间使用情况
-
free 查看内存使用情况
-
top 查看当前系统资源使用情况
-
service mysqld start 启动 mysql 服务,其他如此
-
service mysqld stop 停止 mysql 服务
-
serice mysqld status 显示 mysql 服务状态
-
service –status-al 查看已有服务
-
服务 systemctl
docker 部分命令
-
docker run --name ldj-mysql -e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306 -d docker.io/mysql
-
docker run -p 8000:80 --name myNginx -d docker.io/nginx
-
docker run -it --name dockerGit -d docker/git:git
-
docker run -it -d --name docker-web -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock docker.io/uifd/ui-for-docker
-
docker exec -it ldj-mysql /bin/bash
文件
find 查找文件
-
grep someText * 在当前目录所有文本中查找
-
cat
用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据 -
cat text | less # 查看text文件中的内容 注:这条命令也可以使用less text来代替
-
tail -10 someFile 查看文件后 10 行内容
-
head -10 someFile 查看文件前 10 行内容
-
tail -f someFile 实时查看文件内容,用于调试
-
Linux 向文件末尾追加命令
//echo后边用单引号包围要添加的内容
echo ‘add content’>>/home/data/test.sh
注意:>> 是追加
echo ‘add content’>/home/data/test.sh
注意:> 是删除原有内容,添加
文件替换
-
文件内全部替换:
- :%s#abc#123#g (如文件内有#,可用/替换,:%s/abc/123/g)
–注:把abc替换成123
(或者: %s/str1/str2/g 用str2替换文件中所有的str1)
- :%s#abc#123#g (如文件内有#,可用/替换,:%s/abc/123/g)
-
文件内局部替换:
- :20,30s#abc#123(如文件内有#,可用/替换,:%s/abc/123/g)
–注:把20行到30行内abc替换成123
- :20,30s#abc#123(如文件内有#,可用/替换,:%s/abc/123/g)
scp
-
远程到本地
- scp -r root@远程ip:/opt/soft/mongodb /opt/soft/
-
本地到远程
- scp -r /opt/veolia/*.jar test@远程ip:/home/test
-
从linux系统复制文件到windows系统:
- scp /oracle/a.txt administrator@ip:/d:/
-
在linux环境下,将windows下的文件复制到linux系统中:
- scp administrator@192.168.3.181:/d:/test/abc.txt /oracle
其中的administrator是windows的用户名,比如我的windows用户名是fts。192.168.3.181是你windows的ip/oracle是你要存放的Windows路径
- scp administrator@192.168.3.181:/d:/test/abc.txt /oracle
需要注意的是:因为windows系统本身不支持ssh协议,所以,要想上面的命令成功执行,必须在windows客户端安装ssh for windows的客户端软件,
比如winsshd,使windows系统支持ssh协议才行。