# docs **Repository Path**: 292634346/docs ## Basic Information - **Project Name**: docs - **Description**: my docs. - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 1 - **Forks**: 0 - **Created**: 2022-02-17 - **Last Updated**: 2022-02-18 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Linux > Linux常用命令.
10.13.29.162
10.13.29.160
root
dbplus03 ### 一、基本命令 #### 1.1 关机和重启
**关机**
shutdown -h now        立刻关机
shutdown -h 5        5分钟后关机
poweroff            立刻关机 **重启**
shutdown -r now        立刻重启
shutdown -r 5        5分钟后重启
reboot                立刻重启
#### 1.2 帮助命令
**--help命令**
shutdown --help:
ifconfig  --help:查看网卡信息 **man命令**(命令说明书)
man shutdown
注意:man shutdown打开命令说明书之后,使用按键q退出
### 二、目录操作命令 #### 2.1 目录切换 cd 命令:cd 目录
cd /        切换到根目录
cd /usr        切换到根目录下的usr目录
cd ../        切换到上一级目录 或者  cd ..
cd ~        切换到home目录
cd -        切换到上次访问的目录
#### 2.2 目录查看 ls [-al] 命令:ls [-al]
ls                查看当前目录下的所有目录和文件
ls -a            查看当前目录下的所有目录和文件(包括隐藏的文件)
ls -l 或 ll       列表查看当前目录下的所有目录和文件(列表查看,显示更多信息)
ls /dir            查看指定目录下的所有目录和文件   如:ls /usr
#### 2.3 目录操作【增,删,改,查】
**2.3.1 创建目录【增】 mkdir**
命令:mkdir 目录
mkdir    aaa            在当前目录下创建一个名为aaa的目录
mkdir    /home/aaa    在指定目录下创建一个名为aaa的目录 **2.3.2 删除目录或文件【删】rm**
命令:rm [-rf] 目录
删除文件:
rm 文件        删除当前目录下的文件
rm -f 文件    强制删除当前文件(不询问)
删除目录:
rm -r aaa    递归删除当前目录下的aaa目录
rm -rf aaa    递归删除当前目录下的aaa目录(不询问)
全部删除:
rm -rf *      将当前目录下的所有目录和文件全部删除
rm -rf /*    【自杀命令!慎用!慎用!慎用!】将根目录下的所有文件全部删除
注意:rm不仅可以删除目录,也可以删除其他文件或压缩包,为了方便大家的记忆,无论删除任何目录或文件,都直接使用 rm -rf 目录/文件/压缩包 **2.3.3 目录修改【改】mv 和 cp**
① 重命名目录
命令:mv 当前目录  新目录
例如:mv aaa bbb    将目录aaa改为bbb
注意:mv的语法不仅可以对目录进行重命名而且也可以对各种文件,压缩包等进行    重命名的操作
② 剪切目录
命令:mv 目录名称 目录的新位置
示例:将/usr/tmp目录下的aaa目录剪切到 /usr目录下面     mv /usr/tmp/aaa /usr
注意:mv语法不仅可以对目录进行剪切操作,对文件和压缩包等都可执行剪切操作
③ 拷贝目录
命令:cp -r 目录名称 目录拷贝的目标位置   -r代表递归
示例:将/usr/tmp目录下的aaa目录复制到 /usr目录下面     cp /usr/tmp/aaa  /usr
注意:cp命令不仅可以拷贝目录还可以拷贝文件,压缩包等,拷贝文件和压缩包时不    用写-r递归
scp  复制到远程主机
scp -r 2022-02-16.log [root@192.168.181.128](mailto:root@192.168.181.128):/root/
④ 搜索目录【查】find
命令:find 目录 参数 文件名称
示例:find /root -name 'nginx*'    查找/usr/tmp目录下的所有以a开头的目录或文件
### 三、文件操作命令 #### 3.1 文件操作【增,删,改,查】
**3.1.1 新建文件【增】touch**
命令:touch 文件名
示例:在当前目录创建一个名为aa.txt的文件        touch  aa.txt **3.1.2 删除文件 【删】 rm**
命令:rm -rf 文件名 **3.1.3 修改文件【改】 vi或vim**
【vi编辑器的3种模式】
基本上vi可以分为三种状态,分别是命令模式(command mode)、插入模式(Insert mode)和底行模式(last line mode),各模式的功能区分如下:
1. 命令行模式command mode)
控制屏幕光标的移动,字符、字或行的删除,查找,移动复制某区段及进入Insert mode下,或者到 last line mode。
命令行模式下的常用命令:
【1】控制光标移动:↑,↓,j
【2】删除当前行:dd
【3】查找:/字符
【4】进入编辑模式:i o a
【5】进入底行模式:: 1. 编辑模式(Insert mode)
只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。
编辑模式下常用命令:
【1】ESC 退出编辑模式到命令行模式; 1. 底行模式(last line mode)
将文件保存或退出vi,也可以设置编辑环境,如寻找字符串、列出行号……等。
底行模式下常用命令:
【1】退出编辑:   :q
【2】强制退出:   :q!
【3】保存并退出:  :wq
**打开文件**
命令:vi 文件名
示例:打开当前目录下的aa.txt文件     vi aa.txt 或者 vim aa.txt
注意:使用vi编辑器打开文件后,并不能编辑,因为此时处于命令模式,点击键盘i/a/o进入编辑模式。 **编辑文件**
使用vi编辑器打开文件后点击按键:i ,a或者o即可进入编辑模式。
i:在光标所在字符前开始插入
a:在光标所在字符后开始插入
o:在光标所在行的下面另起一新行插 **保存或者取消编辑**
**保存文件:**
第一步:ESC  进入命令行模式
第二步::     进入底行模式
第三步:wq     保存并退出编辑 **取消编辑:**
第一步:ESC  进入命令行模式
第二步::     进入底行模式
第三步:q!     撤销本次修改并退出编辑 **3.1.4 文件的查看【查】**
文件的查看命令:cat   more   less    tail
cat:看最后一屏
示例:使用cat查看/etc/nginx.conf文件,只能显示最后一屏内容
cat sudo.conf
more:百分比显示
示例:使用more查看/etc/sudo.conf文件,可以显示百分比,回车可以向下一行,空格可以向下一页,q可以退出
输入/ 可以搜索字符
more error.log
less:翻页查看
示例:使用less查看/etc/sudo.conf文件,可以使用键盘上的PgUp和PgDn向上    和向下翻页,q结束查看
less sudo.conf
tail:指定行数或者动态查看
示例:使用tail -10 查看/etc/sudo.conf文件的后10行,Ctrl+C结束
cd /apps/scada2.1/excutor/CPQXLoading/publish_CPJ_MC_1/logs
tail -f 2022-02-18.log
#### 3.2 权限修改 rwx:r代表可读,w代表可写,x代表该文件是一个可执行文件,如果rwx任意位置变为-则代表不可读或不可写或不可执行文件。
示例:给aaa.txt文件权限改为可执行文件权限,aaa.txt文件的权限是-rw-------
第一位:-就代表是文件,d代表是文件夹
第一段(3位):代表拥有者的权限
第二段(3位):代表拥有者所在的组,组员的权限
第三段(最后3位):代表的是其他用户的权限
命令:chmod +x test.sh
或者
命令:chmod 755 test.sh
### 四、压缩文件操作 #### 4.1 打包和压缩 Windows的压缩文件的扩展名  .zip/.rar
linux中的打包文件:aa.tar
linux中的压缩文件:bb.gz
linux中打包并压缩的文件:.tar.gz
Linux中的打包文件一般是以.tar结尾的,压缩的命令一般是以.gz结尾的。
而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。
命令:tar -zcvf 打包压缩后的文件名 要打包的文件
其中:z:调用gzip压缩命令进行压缩
c:打包文件
v:显示运行过程
f:指定文件名
示例:打包并压缩/usr/tmp 下的所有文件 压缩后的压缩包指定名称为xxx.tar
tar -zcvf ab.tar aa.txt bb.txt
或:tar -zcvf ab.tar  *
#### 4.2 解压 命令:tar [-zxvf] 压缩文件
其中:x:代表解压
示例:将/usr/tmp 下的ab.tar解压到当前目录下
示例:将/usr/tmp 下的ab.tar解压到根目录/usr下
tar -zxvf ab.tar -C /usr------C代表指定解压的位置
### 五、查找命令 #### 5.1 grep grep命令是一种强大的文本搜索工具
使用实例:
ip addr | grep en   查找en3网卡IP
ps -ef | grep sshd  查找指定ssh服务进程
ps -ef | grep sshd | grep -v grep 查找指定服务进程,排除gerp身
ps -ef | grep sshd -c 查找指定进程个数
#### 5.2 find find命令在目录结构中搜索文件,并对搜索结果执行指定的操作。
find 默认搜索当前目录及其子目录,并且不过滤任何结果(也就是返回所有文件),将它们全都显示在屏幕上。
使用实例:
find . -name "*.log" -ls  在当前目录查找以.log结尾的文件,并显示详细信息。
find /root/ -perm 600   查找/root/目录下权限为600的文件
find . -type f -name "*.log"  查找当目录,以.log结尾的普通文件
find . -type d | sort   查找当前所有目录并排序
find . -size +100M  查找当前目录大于100M的文件
#### 5.3 whereis 和 which **whereis:**
whereis命令是定位可执行文件、源代码文件、帮助文件在文件系统中的位置。这些文件的属性应属于原始代码,二进制文件,或是帮助文件。
使用实例:
whereis ls    将和ls文件相关的文件都查找出来
**which:**
which命令的作用是在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。
使用实例:
which pwd  查找pwd命令所在路径
which java  查找path中java的路径
### 六、su、sudo #### 6.1 su su用于用户之间的切换。但是切换前的用户依然保持登录状态。如果是root 向普通或虚拟用户切换不需要密码,反之普通用户切换到其它任何用户都需要密码验证。
su test:切换到test用户,但是路径还是/root目录
su - test : 切换到test用户,路径变成了/home/test
su : 切换到root用户,但是路径还是原来的路径
su - : 切换到root用户,并且路径是/root
su不足:如果某个用户需要使用root权限、则必须要把root密码告诉此用户。
退出返回之前的用户:exit
#### 6.2 sudo sudo是为所有想使用root权限的普通用户设计的。可以让普通用户具有临时使用root权限的权利。只需输入自己账户的密码即可。
### 七、系统相关 #### 7.1 查看硬盘信息 df 命令是一个显示文件系统使用情况状态的命令。
df -h
#### 7.2 查看cpu和内存使用率 top
#### 7.3 上传 rz -be
#### 7.4 下载 sz -be  ./xxx.txt
#### 7.5 设置时间同步 date -R
timedatectl set-timezone Asia/Shanghai
sudo yum -y install ntp
ntpdate pool.ntp.org
date
systemctl start ntpd
systemctl enable ntpd
systemctl status ntpd
### 八、网络管理 #### 8.1 主机名配置 [root[@node1](/node1) ~]# vi /etc/sysconfig/network
NETWORKING=yes
HOSTNAME=node1
#### 8.2 IP 地址配置 [root[@node1](/node1) ~]# vi /etc/sysconfig/network-scripts/ifcfg-eth0
#### 8.3 域名映射 /etc/hosts文件用于在通过主机名进行访问时做ip地址解析之用。所以,你想访问一个什么样的主机名,就需要把这个主机名和它对应的ip地址。
### 九、定时任务指令crontab 配置 crontab是Unix和Linux用于设置定时任务的指令。通过crontab命令,可以在固定间隔时间,执行指定的系统指令或shell脚本。时间间隔的单位可以是分钟、小时、日、月、周及以上的任意组合。
crontab安装:
yum install crontabs
服务操作说明:
service crond start   ## 启动服务
service crond stop    ## 关闭服务
service crond restart ## 重启服务
#### 9.1 命令格式 crontab [-u user] file
crontab [-u user] [ -e | -l | -r ]
参数说明:
-u user:用来设定某个用户的crontab服务
file:file是命令文件的名字,表示将file做为crontab的任务列表文件
并载入crontab。
-e:编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前
用户的crontab文件。
-l:显示某个用户的crontab文件内容。如果不指定用户,则表示显示当前
用户的crontab文件内容。
-r:删除定时任务配置,从/var/spool/cron目录中删除某个用户的crontab
文件,如果不指定用户,则默认删除当前用户的crontab文件。
命令示例:
crontab file [-u user] ## 用指定的文件替代目前的crontab
crontab -l [-u user]  ## 列出用户目前的crontab
crontab -e [-u user]  ## 编辑用户目前的crontab
#### 9.2 配置说明、实例 命令:_   _    _   _   *   command
解释:分  时  日  月  周  命令
第1列表示分钟1~59 每分钟用_或者 _/1表示
第2列表示小时0~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令 配置实例:
先打开定时任务所在的文件:
crontab -e 每分钟执行一次date命令
_/1 _ _ _ * date >> /root/date.txt 每晚的21:30重启apache。
30 21 _ _ * service httpd restart 每月1、10、22日的4 : 45重启apache。
45 4 1,10,22 _ _ service httpd restart 每周六、周日的1 : 10重启apache。
10 1 _ _ 6,0 service httpd restart 每天18 : 00至23 : 00之间每隔30分钟重启nginx。
0,30   18-23    _   _   *   service nginx reload 晚上11点到早上7点之间,每隔一小时重启nginx
23-7/1    _   _   *   service nginx  reload
### 十、其他命令 #### 10.1 查看当前目录:pwd 命令:pwd     查看当前目录路径
#### 10.2 查看进程:ps -ef 命令:ps -ef | grep  进程名或进程ID   查看所有正在运行的进程
#### 10.3 结束进程:kill 命令:kill pid 或者 kill -9 pid(强制杀死进程)           pid:进程号
#### 10.4 网络通信命令 ifconfig:查看网卡信息 (window系统: ipconfig)
命令:ifconfig 或 ifconfig | more
或者:ip addr
ping:查看与某台机器的连接情况
命令:ping ip
telnet: 查看与某台机器IP和端口痛不痛
telnet  10.13.0.138  12580
netstat -an:查看当前系统端口
命令:netstat -an
或者:netstat -tulpn
搜索指定端口
命令:netstat -an | grep 8080
或者:netstat -an | grep 9013
#### 10.6 重启网络 命令:service network restart
#### 10.7 切换用户 命令:su - 用户名
#### 10.8 关闭防火墙 **iptables**
命令:chkconfig iptables off
或者:service iptables stop **firewall**  (centos7版本以后)
查看防火墙状态:firewall-cmd --state    (running代表防火墙正在运行)
停止firewall:systemctl stop firewalld.service
禁止firewall开机启动:systemctl disable firewalld.service
#### 10.9 修改文件权限 命令:chmod 777 要赋权限的文件
#### 10.10 清屏 命令:ctrl + l
或者:clear
#### 10.11 SSH远程登录 ssh [root@192.168.181.128](mailto:root@192.168.181.128)
#### 10.12 查看大日志文件 tail -n 30000  error.log |more -1000
从末尾返前30000  行的位置,往下找1000行 ctrl+f 快捷键翻页 .
tail -n 39000  error.log |more -1000 > nginx_err.log    查找结果写入日志
tail -f error.log   实时输出日志
#### 10.13 后台执行 **nohup**
/dev/null 表示空设备文件
0 表示stdin标准输入
1 表示stdout标准输出
2 表示stderr标准错误
> file 表示将标准输出输出到file中,也就相当于 1>file
2> error 表示将错误输出到error文件中
2>&1 也就表示将错误重定向到标准输出上
2>&1 >file :错误输出到终端,标准输出重定向到文件file,等于 > file 2>&1(标准输出重定向到文件,错误重定向到标准输出)。
& 放在命令到结尾,表示后台运行,防止终端一直被某个进程占用,这样终端可以执行别到任务,配合 >file 2>&1可以将log保存到某个文件中,但如果终端关闭,则进程也停止运行。如command > file.log 2>&1 & 。
nohup放在命令的开头,表示不挂起(no hang up),也即,关闭终端或者退出某个账号,进程也继续保持运行状态,一般配合&符号一起使用。如nohup command &。
nohup command > out.log2>&1 &   (&是指在后台运行)
nohup /apps/scada2.1/drivers/MC3E_CPJ_MC_B_1/MC3E_CPJ_MC_B_1  >/dev/null 2>&1 & #### 10.14 查看历史操作命令 history
### 十一、Linux项目部署 #### 11.1 安装jdk1.8 mkdir /usr/local/src/java
rz 上传jdk tar包
tar -zxvf jdk-8u181-linux-x64.tar.gz
配置环境变量:
vi /etc/profile
在末尾行添加
#set java environment
export JAVA_HOME=/usr/local/java/jdk1.8.0_181
export JRE_HOME=/usr/local/java/jdk1.8.0_181/jre
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
export PATH=$JAVA_HOME/bin:$PATH
保存退出
source /etc/profile  使更改的配置立即生效
java -version  查看JDK版本信息,如果显示出1.8证明成功
#### 11.2 安装nginx **11.2.1 源码编译安装**
Nginx官网下载链接:[https://nginx.org/en/download.html](https://nginx.org/en/download.html) 选择自己合适的版本号,选择.tar.gz文件下载。
wget [https://nginx.org/download/nginx-1.18.0.tar.gz](https://nginx.org/download/nginx-1.18.0.tar.gz) 下载 nginx-1.18.0.tar.gz 安装 gcc,安装 Nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境
yum install -y gcc-c++ 安装 PCRE pcre-devel,PCRE(Perl Compatible Regular Expressions) 是一个Perl库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,pcre-devel 是使用 pcre 开发的一个二次开发库。nginx也需要此库。
yum install -y pcre pcre-devel 安装 zlib,zlib 库提供了很多种压缩和解压缩的方式, nginx 使用 zlib 对 http 包的内容进行 gzip ,所以需要在 linux 上安装 zlib 库。
yum install -y zlib zlib-devel 安装 OpenSSL,OpenSSL 是一个强大的安全套接字层密码库,包括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。nginx 不仅支持 http 协议,还支持 https(即在ssl协议上传输http),所以需要在 CentOS 安装 OpenSSL 库。
yum install -y openssl openssl-devel 安装nginx
创建一个资源目录把 Nginx安装包 上传到这个目录下
mkdir /usr/local/resource 解压安装包,解压后可以把安装包删除
tar -zxvf nginx1.18.0.tar.gz 进入解压好的目录
cd nginx-1.18.0 配置,这里笔者选择的是第二种自定义配置,指定安装路径
①默认配置
./configure ②自定义配置(这里配置了安装路径,配置文件路径,运行进程路径,进程锁路径)
./configure \ --prefix=/usr/local/nginx \ --conf-path=/usr/local/nginx/conf/nginx.conf \ --pid-path=/usr/local/nginx/conf/nginx.pid \ --lock-path=/usr/local/nginx/lock/nginx.lock 编译
make 编译安装
make install 启动
进入安装目录下的sbin目录
cd /usr/local/nginx/sbin/ 启动
./nginx 停止
./nginx  -s stop   快速关闭
./nginx -s quit     平稳关闭 重启
./nginx  -s reload
查看Nginx的运行进程
ps -ef | grep nginx **11.2.2 yum安装**
 yum -y install nginx 启动nginx:systemctl start nginx 加入开机启动:systemctl enable nginx 查看nginx的状态:systemctl status nginx 停止nginx:systemctl stop nginx 重启nginx:systemctl reload nginx