-
vmware安装Linux虚拟机时需选择的三种网络连接方式:
- 桥接:与宿主机在同一网段,可以与局域网内设备进行通信,缺点是可能造成ip冲突,因为同一网段下除去网关x.x.x.1和广播地址x.x.x.255只有253个地址。
- nat(网络地址转换):Linux可以访问外网,但局域网中的设备无法访问到Linux,不会占用局域网内的路由表。(实际常用)
- 主机模式:Linux是一个独立的主机,不能访问外网。
-
centos分区创建
Linux一般都要三个分区:
1. /boot分区:200MB足矣
2. swap分区:物理内存不够充当虚拟内存。一般是物理内存的1.5倍到2倍(严谨请百度)。但redis,mysql这类服务器就不推荐分配swap分区。
3. /(根分区):除/boot和swap分区都可用于数据存储。 -
Linux目录结构:
目录结构详解:
/bin [重点] (/usr/bin、/usr/local/bin)
• 是Binary的缩写, 这个目录存放着最经常使用的命令
/sbin(/usr/sbin、/usr/local/sbin)
•s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。
/home [重点]
•存放普通用户的主目录,在Linux中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
/root [重点]
•该目录为系统管理员,也称作超级权限者的用户主目录。
/lib
•系统开机所需要最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。
/lost+found
•这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
/etc [重点]
•所有的系统管理所需要的配置文件和子目录my.conf
/usr [重点]
•这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似与windows下的program files目录。
/boot [重点]
•存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件
/proc
•这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息。
/srv
•service缩写,该目录存放一些服务启动之后需要提取的数据。
/sys
•这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统sysfs
/tmp
•这个目录是用来存放一些临时文件的。
/dev
•类似于windows的设备管理器,把所有的硬件用文件的形式存储。
/media [重点]
•linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
/mnt [重点]
•系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将外部的存储挂载在/mnt/上,然后进入该目录就可以查看里的内容了。d:/myshare
/opt
•这是给主机额外安装软件(安装包)所摆放的目录。如安装ORACLE数据库就可放到该目录下。默认为空。
/usr/local [重点]
•这是一个给主机额外安装软件所安装的目录。一般是通过编译源码方式安装的程序。
/var [重点]
•这个目录中存放着在不断扩充着的东西,习惯将经常被修改的目录放在这个目录下。包括各种日志文件。
/selinux [security-enhanced linux] 360
•SELinux是一种安全子系统,它能控制程序只能访问特定文件。
常用vim快捷键
- 拷贝当前行yy , 拷贝当前行向下的5行5yy,并粘贴。
- 删除当前行dd , 删除当前行向下的5行5dd
- 在文件中查找某个单词[命令行下/关键字,回车查找, 输入n 就是查找下一个]
- 设置文件的行号,取消文件的行号.[命令行下: set nu 和:set nonu]
- 编辑/etc/profile 文件,使用快捷键到底文档的最末行[G]和最首行[gg]
- 在一个文件中输入"hello" ,然后又撤销这个动作u
- 编辑/etc/profile 文件,并将光标移动到20行shift+g (或直接 :20,回车)
1. 显示行号 :set nu
2. 键入20(不显示)
3. shift+g
编辑vim默认配置:
vim .vimrc
set nu #显示行号
syntax on #显示语法高亮
set ts=4 #更改默认制表符为4
set expandtab #制表符替换空格(python开发)
set autoindent #换行自动缩进
set ruler #显示光标位置
set nohls #搜索高亮关闭
Linux用户管理常用命令
useradd x 创建新用户x,并在/home/中创建对应的x文件夹
useradd -d /home/dog/ x 创建用户x并指定目录到/home/dog/
passwd x 给用户x指定密码
userdel x 删除用户,但不删除/home/文件夹对应的文件夹
userdel -r x 删除用户,同时删除/home/文件夹对应用户(一般并不删除)
id x 查看用户信息
su - x 切换用户到x
exit 退回原来用户
groupadd x 添加组
groupdel x 删除组
useradd -g 组名 用户名 新增用户时直接分组
usermod -g 组名 用户名 修改用户的组
- 强制某用户下线
Linux系统root用户可强制踢制其它登录用户,首先可用w命令查看登录用户信息
[root@VM-0-12-centos ~]# w
21:53:22 up 56 days, 11:06, 1 user, load average: 0.14, 0.07, 0.16
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
root pts/1 192.168.1.200 14:18 21.00s 0.01s 0.01s -bash
root pts/2 222.85.110.19 21:46 2.00s 0.03s 0.00s w
强制踢人
命令格式:
pkill -kill -t tty
解释:
pkill -kill -t tty
tty 所踢用户的tty
比如: pkill -kill -t pts/1
说明:
1.只有root用户才能踢人,但任何用户都可以踢掉自己
2.如果同时有二个人用root用户登录,任何其中一个可以踢掉另一个
3.pts/0就是自己开的桌面环境现的第一个终端
用户和组的相关文件
/etc/passwd 文件
用户(user)的配置文件,记录用户的各种信息
每行的含义:用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录Shell
/etc/shadow 文件
口令的配置文件
每行的含义:登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警
告时间:不活动时间:失效时间:标志
/etc/group 文件
组(group)的配置文件,记录Linux包含的组的信息
每行含义:组名:口令:组标识号:组内用户列表
Linux基础实用指令
- 指定运行级别
运行级别说明:
0 :关机
1 :单用户【找回丢失密码】
2:多用户状态没有网络服务
3:多用户状态有网络服务
4:系统未使用保留给用户
5:图形界面
6:系统重启
常用运行级别是3和5 ,要修改默认的运行级别可改文件/etc/inittab的id:5:initdefault:这一行中的数字命令:init [012356]
eg:init 0 即可关机
面试题:忘记root密码怎么办?
进入单用户模式,就不用输入root密码登陆系统,即可使用passwd root修改密码。
man ls 查看ls命令的帮助信息
help ls 获得shell内置命令的帮助信息
pwd 显示当前工作目录的绝对路径
ls [选项] [目录或是文件]
ls -a 显示当前目录所有的文件和目录,包括隐藏的。
ls -l 以列表的方式显示信息
文件目录类
cd ~ 回到当前用户的家目录
cd … 回到当前目录的上一级目录
mkdir [选项] 要创建的目录
mkdir -p /home/dog 创建多级目录
rmdir [选项] 要删除的空目录
rm -rf 要删除的目录 删除非空目录
touch hello.txt 创建空文件
cp [选项] source dest
cp -r 递归复制整个文件夹 source dest
rm [选项] 要删除的文件或目录
-r :递归删除整个文件夹
-f : 强制删除不提示
mv oldNameFile newNameFile 重命名
mv /temp/movefile /targetFolder 移动文件
cat [选项] 要查看的文件
-n :显示行号
more 指令是一个基于VI编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容
more指令中内置了若干快捷键,详见操作说明:
空白键 (space) 代表向下翻一页;
Enter 代表向下翻『一行』;
q 代表立刻离开 more ,不再显示该文件内容。
Ctrl+F 向下滚动一屏
Ctrl+B 返回上一屏
= 输出当前行的行号
:f 输出文件名和当前行的行号
less指令用来分屏查看文件内容,它的功能与more指令类似,但是比more指令更加强大,支
持各种显示终端。less指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是
根据显示需要加载内容,对于显示大型文件具有较高的效率。
空白键 向下翻动一页;
[pagedown] 向下翻动一页
[pageup] 向上翻动一页;
/字串 向下搜寻『字串』的功能;n:向下查找;N:向上查找;
?字串 向上搜寻『字串』的功能;n:向上查找;N:向下查找;
q 离开 less 这个程序;
echo [选项] [输出内容] 输出内容到控制台。
head 文件 (功能描述:查看文件头10行内容)
head -n 5 文件 (功能描述:查看文件头5行内容,5可以是任意行数)
tail用于输出文件中尾部的内容,默认情况下tail指令显示文件的前10行内容
tail 文件 (功能描述:查看文件头10行内容)
tail -n 5 文件 (功能描述:查看文件头5行内容,5可以是任意行数)
tail -f 文件 (功能描述:实时追踪该文档的所有更新)
-> 输出重定向和 >> 追加 及 2>错误输出重定向 2>>错误追加重定向
ls -l >a.txt (功能描述:列表的内容写入文件a.txt中(覆盖写))
ls -al >>a.txt (功能描述:列表的内容追加到文件a.txt的末尾)
cat 文件1 > 文件2 (功能描述:将文件1的内容覆盖到文件2)
echo “内容”>> 文件
ln 软链接也成为符号链接,类似于windows里的快捷方式,主要存放了链接其他文件的路径
ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)
history 查看已经执行过历史命令,也可以执行历史指令
history n 查看已经执行过历史n个命令
!11执行第11个历史命令
date指令-显示当前日期
date (功能描述:显示当前时间)
date +%Y (功能描述:显示当前年份)
date +%m (功能描述:显示当前月份)
date +%d (功能描述:显示当前是哪一天)
date “+%Y-%m-%d %H:%M:%S”(功能描述:显示年月日时分秒)
date -s “2020-11-11 11:22:22” 设置日期
cal 显示本月日历
cal 2020 显示2020年日历
find-指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件或者目录显示在终
端。
find -name<查询方式> 按照指定的文件名查找模式查找文件
find -user<用户名> 查找属于指定用户名所有文件
find -size<文件大小> 按照指定的文件大小查找文件。
locaate指令可以快速定位文件路径。由于locate指令基于数据库进行查询,所以第一次运行前,必须使用updatedb指令创建locate数据库。
locate 文件名
grep 过滤查找 , 管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理。
grep -n 显示匹配行及行号。
grep -i 忽略字母大小写
gzip 用于压缩文件, gunzip 用于解压的
gzip 文件
gunzip 文件.gz
- gzip 压缩文件不会保留源文件
zip 用于压缩文件, unzip 用于解压的,这个在项目打包发布中很有用的
zip -r:递归压缩,即压缩目录
zip -d<目录> :指定解压后文件的存放目录
tar 指令 是打包指令,最后打包后的文件是 .tar.gz 的文件。
-c 产生.tar打包文件
-v 显示详细信息
-f 指定压缩后的文件名
-z 打包同时压缩
-x 解包.tar文件
组管理和权限管理
ls –ahl 查看文件的所有者
chown 用户名 文件名 修改文件所有者
groupadd monster 创建一个组
创建一个用户 fox ,并放入到 monster组中:
useradd -g monster fox
chgrp 组名 文件名 修改文件所在的组.
改变用户所在组:
usermod –g 组名 用户名
usermod –d 目录名 用户名 改变该用户登陆的初始目录。
- 权限的基本介绍
ls -l 中显示的内容如下:
-rwxrw-r-- 1 root root 1213 Feb 2 09:39 abc
0-9位说明
- 第0位确定文件类型(d, - , l , c , b)
- 第1-3位确定所有者(该文件的所有者)拥有该文件的权限。—User
- 第4-6位确定所属组(同用户组的)拥有该文件的权限,—Group
- 第7-9位确定其他用户拥有该文件的权限 —Other
- rwx权限详解
rwx作用到文件
- [ r ]代表可读(read): 可以读取,查看
- [ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是
对该文件所在的目录有写权限,才能删除该文件. - [ x ]代表可执行(execute):可以被执行
rwx作用到目录
- [ r ]代表可读(read): 可以读取,ls查看目录内容
- [ w ]代表可写(write): 可以修改,目录内创建+删除+重命名目录
- [ x ]代表可执行(execute):可以进入该目录
ls -l 中显示的内容如下:
-rwxrw-r-- 1 root root 1213 Feb 2 09:39 abc
10个字符确定不同用户能对文件干什么
第一个字符代表文件类型: 文件 (-),目录(d),链接(l)
其余字符每3个一组(rwx) 读® 写(w) 执行(x)
第一组rwx : 文件拥有者的权限是读、写和执行
第二组rw- : 与文件拥有者同一组的用户的权限是读、写但不能执行
第三组r-- : 不与文件拥有者同组的其他用户的权限是读不能写和执行
可用数字表示为: r=4,w=2,x=1 因此rwx=4+2+1=7
1 文件:硬连接数或 目录:子目录数
root 用户
root 组
1213 文件大小(字节),如果是文件夹,显示 4096字节
Feb 2 09:39 最后修改日期
abc 文件名
- chmod
通过chmod指令,可以修改文件或者目录的权限。
第一种方式:+ 、-、= 变更权限
u:所有者 g:所有组 o:其他人 a:所有人(u、g、o的总和)
- chmod u=rwx,g=rx,o=x 文件目录名
- chmod o+w 文件目录名
- chmod a-x 文件目录名
第二种方式:通过数字变更权限
r=4 w=2 x=1 rwx=4+2+1=7
chmod u=rwx,g=rx,o=x 文件目录名
相当于 chmod 751 文件目录名
- 修改文件所有者-chown
chown newowner file 改变文件的所有者
chown newowner:newgroup file 改变用户的所有者和所有组
-R 如果是目录 则使其下所有子文件或目录递归生效
chgrp newgroup file 改变文件的所有组
定时任务调度
快速入门
设置任务调度文件:/etc/crontab
设置个人任务调度。执行crontab –e命令。
接着输入任务到调度文件
如:*/1 * * * * ls –l /etc/ > /tmp/to.txt
意思说每小时的每分钟执行ls –l /etc/ > /tmp/to.txt命令
5个占位符的说明
第一个“” 一小时当中的第几分钟 0-59
第二个“” 一天当中的第几小时 0-23
第三个“” 一个月当中的第几天 1-31
第四个“” 一年当中的第几月 1-12
第五个“*” 一周当中的星期几 0-7(0和7都代表星期日)
特殊符号的说明
- 代表任何时间。比如第一个“*”就代表一小时中每分钟都执行一
次的意思。
, 代表不连续的时间。比如“0 8,12,16 * * * 命令”,就代表在每天
的8点0分,12点0分,16点0分都执行一次命令
- 代表连续的时间范围。比如“0 5 * * 1-6命令”,代表在周一到周
六的凌晨5点0分执行命令
/n 代表每隔多久执行一次。比如“/10 * * * * 命令”,代表每隔
10分钟就执行一遍命令
特定时间执行任务案例
45 22 * * * 命令 在22点45分执行命令
0 17 * * 1 命令 每周1 的17点0分执行命令
0 5 1,15 * * 命令 每月1号和15号的凌晨5点0分执行命令
40 4 * * 1-5 命令 每周一到周五的凌晨4点40分执行命令
*/10 4 * * * 命令 每天的凌晨4点,每隔10分钟执行一次命令
0 0 1,15 * 1 命令 每月1号和15号,每周1的0点0分都会执行命令。注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易让管理员混乱。
防火墙开放端口
查看当前已经开放的端口:
firewall-cmd --list-ports
开启端口,以8888为例:
firewall-cmd --zone=public --add-port=8888/tcp --permanent
重启防火墙:
firewall-cmd --reload
硬盘挂载
增加一块硬盘:
- 虚拟机添加硬盘
- 分区
- 格式化
- 挂载
- 设置可以自动挂载 。
-
插入硬盘,重启系统,键入lsblk -f 会多出一个sdb,将sdb分区:
-
分区命令 fdisk /dev/sdb
开始对/sdb分区
• m 显示命令列表
• p 显示磁盘分区 同 fdisk –l
• n 新增分区
• d 删除分区
• w 写入并退出
说明: 开始分区后输入n,新增分区,然后选择p ,分区类型为主分区。两次回车默认剩
余全部空间。最后输入w写入分区并退出,若不保存退出输入q。 -
格式化磁盘
分区命令:mkfs -t ext4 /dev/sdb1
其中ext4是分区类型 -
挂载: 将一个分区与一个目录联系起来,
• mount 设备名称 挂载目录
• 例如: mount /dev/sdb1 /newdisk
• umount 设备名称 或者 挂载目录
• 例如: umount /dev/sdb1 或者 umount /newdisk
• 用命令行挂载重启后会失效 -
虚拟机增加硬盘
永久挂载: 通过修改/etc/fstab实现挂载
添加完成后 执行mount –a 即刻生效
df -h 查询系统整体磁盘使用情况
du -h /目录 查询指定目录的磁盘占用情况
-s 指定目录占用大小汇总
-h 带计量单位
-a 含文件
–max-depth=1 子目录深度
-c 列出明细的同时,增加汇总值
工作实用指令
- 统计/home文件夹下文件的个数
ls -l /code | grep “^-” | wc -l - 统计/home文件夹下目录的个数
ls -l /code | grep “^d” | wc -l - 统计/home文件夹下文件的个数,包括子文件夹里的
ls -lR /code | grep “^-” | wc -l - 统计文件夹下目录的个数,包括子文件夹里的
ls -lR /code | grep “^d” | wc -l - 以树状显示目录结构
tree
网络配置
固定ip:vim /etc/sysconfig/network-scripts/ifcfg-eth0
进程
ps详解
ps -aux | more
指令说明
• System V展示风格
• USER:用户名称
• PID:进程号
• %CPU:进程占用CPU的百分比
• %MEM:进程占用物理内存的百分比
• VSZ:进程占用的虚拟内存大小(单位:KB)
• RSS:进程占用的物理内存大小(单位:KB)
• TT:终端名称,缩写 .
• STAT:进程状态,其中S-睡眠,s-表示该进程是会话的先导进程,N-表示进程拥有比普通
优先级更低的优先级,R-正在运行,D-短期等待,Z-僵死进程,T-被跟踪或者被停止等等
• STARTED:进程的启动时间
• TIME:CPU时间,即进程使用CPU的总时间
• COMMAND:启动进程所用的命令和参数,如果过长会被截断显示
ps -ef是以全格式显示当前所有的进程
• -e 显示所有进程。-f 全格式。
• ps -ef|grep xxx
• 是BSD风格
• UID:用户ID
• PID:进程ID
• PPID:父进程ID
• C:CPU用于计算执行优先级的因子。数值越大,表明进程是CPU密集型运算,
执行优先级会降低;数值越小,表明进程是I/O密集型运算,执行优先级会提高
• STIME:进程启动的时间
• TTY:完整的终端名称
• TIME:CPU时间
• CMD:启动进程所用的命令和参数
终止进程kill和killall
介绍:
若是某个进程执行一半需要停止时,或是已消了很大的系统资源时,此时可以考虑停止该进程。使用kill命令来完成此项任务。
基本语法:
kill [选项] 进程号(功能描述:通过进程号杀死进程)
killall 进程名称 (功能描述:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用)
常用选项:
-9 :表示强迫进程立即停止
最佳实践:
案例1:踢掉某个非法登录用户
案例2: 终止远程登录服务sshd, 在适当时候再次重启sshd服务
案例3: 终止多个gedit 编辑器
案例4:强制杀掉一个终端
查看进程树pstree
基本语法:
pstree [选项] ,可以更加直观的来看进程信息
常用选项:
-p :显示进程的PID
-u :显示进程的所属用户
服务(service)管理
介绍:
服务(service) 本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程
序的请求,比如(mysql , sshd 防火墙等),因此我们又称为守护进程,是Linux中非常重要的
知识点。【原理图】
service管理指令:
service 服务名 [start | stop | restart | reload | status]
在CentOS7.0后 不再使用service ,而是 systemctl
查看服务名:
方式1:使用setup -> 系统服务 就可以看到。
方式2: ls -l /etc/init.d/服务名称
通过chkconfig 命令可以给每个服务的各个运行级别设置自启动/关闭
• 基本语法
- 查看服务 chkconfig --list|grep xxx
- chkconfig 服务名 --list
- chkconfig --level 5 服务名 on/off
chkconfig重新设置服务后自启动或关闭,需要重启机器reboot才能生效.
动态监控进程
top与ps命令很相似。它们都用来显示正在执行的进程。Top与ps最大的不同之处,在于top在执行一段时间可以更新正在运行的的进程。
-d 秒数 指定top命令每隔几秒更新。默认是3秒在top命令的交互模式当中可以执行的
命令:
-i 使top不显示任何闲置或者僵死进程。
-p 通过指定监控进程ID来仅仅监控某个进程的状态
交互操作
P 以CPU使用率排序,默认就是此项
M 以内存的使用率排序
N 以PID排序
q 退出top
- 监控网络状态
查看系统网络情况netstat
• 基本语法
netstat [选项]
• 选项说明
-an 按一定顺序排列输出
-p 显示哪个进程在调用
• 应用案例
请查看服务名为 sshd 的服务的信息。
RPM 与 YUM
rpm包的管理
介绍:
一种用于互联网下载包的打包及安装工具,它包含在某些Linux分发版中。它生成具有.RPM扩展名的文件。RPM是RedHat Package Manager(RedHat软件包管理工具)的缩写,类似windows的setup.exe这一文件格式名称虽然打上了RedHat的标志,但理念是通用的。
rpm包的简单查询指令:
查询已安装的rpm列表 rpm –qa|grep xx
rpm包名基本格式:
一个rpm包名:firefox-45.0.1-1.el6.centos.x86_64.rpm
名称:firefox
版本号:45.0.1-1
适用操作系统: el6.centos.x86_64
表示centos6.x的64位系统
如果是i686、i386表示32位系统,noarch表示通用。
rpm包的其它查询指令:
rpm -qa :查询所安装的所有rpm软件包
rpm -qa | more
rpm -qa | grep X [rpm -qa | grep firefox ]
rpm -q 软件包名 :查询软件包是否安装
rpm -q firefox
rpm -qi 软件包名 :查询软件包信息
rpm -qi file
rpm -ql 软件包名 :查询软件包中的文件
rpm -ql firefox
rpm -qf 文件全路径名 查询文件所属的软件包
rpm -qf /etc/passwd
rpm -qf /root/install.log
卸载rpm包:
• 基本语法
rpm -e RPM包的名称
• 应用案例
- 删除firefox 软件包
• 细节讨论 - 如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误信息。
如: $ rpm -e foo
removing these packages would break dependencies:foo is needed by bar-1.0-1 - 如果我们就是要删除 foo这个rpm 包,可以增加参数 --nodeps ,就可以强制删除,但是一
般不推荐这样做,因为依赖于该软件包的程序可能无法运行
如:$ rpm -e --nodeps foo
安装rpm包:
• 基本语法
rpm -ivh RPM包全路径名称
• 参数说明
i=install 安装
v=verbose 提示
h=hash 进度条
yum
介绍:
Yum 是一个Shell前端软件包管理器。基于RPM包管理,能够从指定
的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并
且一次安装所有依赖的软件包。
yum的基本指令
• 查询yum服务器是否有需要安装的软件
yum list|grep xx软件列表
• 安装指定的yum包
yum install xxx 下载安装
Shell
脚本格式要求
- 脚本以#!/bin/bash开头
- 脚本需要有可执行权限
脚本的常用执行方式
• 方式1(输入脚本的绝对路径或相对路径)
1)首先要赋予helloworld.sh 脚本的+x权限
2)执行脚本
• 方式2(sh+脚本)
说明:不用赋予脚本+x权限,直接执行即可。
Shell的变量的介绍
1)Linux Shell中的变量分为,系统变量和用户自定义变量。
2)系统变量:$ HOME、$ PWD、$ SHELL、$ USER等等
比如: echo $HOME 等等…
3)显示当前shell中所有变量:set
shell变量的定义
• 基本语法
1)定义变量:变量=值
2)撤销变量:unset 变量
3) 声明静态变量:readonly变量,注意:不能unset
• 定义变量的规则
- 变量名称可以由字母、数字和下划线组成,但是不能以数字开头。
- 等号两侧不能有空格
- 变量名称一般习惯为大写
• 将命令的返回值赋给变量
1)A=ls -la
反引号,运行里面的命令,并把结果返回给变量A
2)A=$(ls -la) 等价于反引号
设置环境变量
基本语法
- export 变量名=变量值 (功能描述:将shell变量输出为环境变量)
- source 配置文件 (功能描述:让修改后的配置信息立即生效)
- echo $变量名 (功能描述:查询环境变量的值)
位置参数变量
介绍
当我们执行一个shell脚本时,如果希望获取到命令行的参数信息,就可以使用到位置参数变量
比如 : ./myshell.sh 100 200 , 这个就是一个执行shell的命令行,可以在myshell 脚本中获取到参数信息
基本语法
$n (功能描述:n为数字,$0代表命令本身,$1-
9
代
表
第
一
到
第
九
个
参
数
,
十
以
上
的
参
数
,
十
以
上
的
参
数
需
要
用
大
括
号
包
含
,
如
9代表第一到第九个参数,十以上的参数,十以上的参 数需要用大括号包含,如
9代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如{10})
$ * (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
$ @(功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
$ #(功能描述:这个变量代表命令行中所有参数的个数)
预定义变量
基本介绍
就是shell设计者事先已经定义好的变量,可以直接在shell脚本中使用
基本语法
$$ (功能描述:当前进程的进程号(PID))
$! (功能描述:后台运行的最后一个进程的进程号(PID))
$? (功能描述:最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。)
运算符
基本介绍
学习如何在shell中进行各种运算操作。
基本语法
- “$ ((运算式))”或“$ [运算式]”
- expr m + n
注意expr运算符间要有空格 - expr m - n
- expr *, /, % 乘,除,取余
条件判断
判断语句
• 基本语法
[ condition ](注意condition前后要有空格)
#非空返回true,可使用$?验证(0为true,>1为false)
• 常用判断条件
- 两个整数的比较
= 字符串比较
-lt 小于
-le 小于等于
-eq 等于
-gt 大于
-ge 大于等于
-ne 不等于 - 按照文件权限进行判断
-r 有读的权限
-w 有写的权限
-x 有执行的权限
3)按照文件类型进行判断
-f 文件存在并且是一个常规的文件
-e 文件存在
-d 文件存在并是一个目录
流程控制
if 判断
• 基本语法
if [ 条件判断式 ];then
程序
fi
或者
if [ 条件判断式 ]
then
程序
elif [条件判断式]
then
程序
fi
注意事项:(1)[ 条件判断式 ],中括号和条件判断式之间必须有空格 (2) 推荐使用第二种方式
case语句
• 基本语法
case $变量名 in
“值1”)
如果变量的值等于值1,则执行程序1
;;
“值2”)
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
流程控制
for循环
• 基本语法1
for 变量 in 值1 值2 值3…
do
程序
done
• 基本语法2
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
流程控制
while循环
• 基本语法1
while [ 条件判断式 ]
do
程序
done
read读取控制台输入
基本语法
read(选项)(参数)
选项:
-p:指定读取值时的提示符;
-t:指定读取值时等待的时间(秒),如果没有在指定的时间内输入,就不再等待了。。
参数
变量:指定读取值的变量名
函数
系统函数
• basename基本语法
功能:返回完整路径最后 / 的部分,常用于获取文件名
basename [pathname] [suffix]
basename [string] [suffix] (功能描述:basename命令会删掉所有的前缀包括最后一个(‘/’)
字符,然后将字符串显示出来。
选项:
suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉
• dirname基本语法
功能:返回完整路径最后 / 的前面的部分,常用于返回路径部分
dirname 文件绝对路径 (功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),
然后返回剩下的路径(目录的部分))
• 基本语法
[ function ] funname[()]
{
Action;
[return int;]
}
调用直接写函数名:funname [值]