# 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