linux学习总结----shell编程
## 环境变量
## 全局变量
```
常见的全局环境变量
PATH 指令的搜索路径
HOME 用户的家目录
LOGNAME 登录名
SHELL 脚本的类型
使用全局环境变量
echo $PATH
自定义全局变量
name='kangbazi'
echo $name;
配置系统环境变量
vim /etc/profile
export name=1804
source /etc/profile
echo $name
```
### 设置path环境变量
```
echo $PATH
1.对所有的用户生效
sudo vim /etc/profile
export PATH=$PATH:/usr/local/mysql/bin 给 mysql 添加 path环境变量 类似于windows 中
此电脑->右键属性->高级系统设置->环境变量 ->系统环境变量->path
source /etc/profile 让配置文件立即生效
2.对登录的用户有效
sudo vim /root/.bashrc
export PATH=$PATH:/usr/local/mysql/bin
sudo source /root/.bashrc
```
## shell编程
> 命令解释器 将用户输入的命令 解释给 操作系统内核
### 执行命令的方式
1.交互式 用户输入一条命令 比如 rm -rf /*
2.批处理式的
将多个命令汇集成一个脚本 一次将这次命令执行完毕
```
#!/bin/bash
which ls
cd /usr/local/nginx
mv test.txt /tmp/
```
### 脚本批处理式
需求: 如果实线某个需求 同时2个或者三个服务启动
nginx
mysql
apache2
test start 实线下面三个全部启动 重启 停止
service nginx restart|start|stop
service mysql start|restart|stop
service apahce2 start|restart|stop
```shell
#!/bin/bash
if [ $1 == "start" ]
then
service nginx start
service mysql start
service apache2 start
fi
if [ $1 == "stop" ]
then
service nginx stop
service mysql stop
service apache2 stop
fi
if [ $1 == "restart" ]
then
service nginx restart
service mysql restart
service apache2 restart
fi
```
> 开头必须是 #!/bin/bash
>
> 后缀名 一般 是以 .sh
>
> 脚本要有执行权限 chmod +x 脚本.sh
>
> ./脚本.sh 运行 ./
>
> /etc/init.d/test.sh 绝对执行
```shell
#是shell脚本中的注释 第一行比较特殊
#!/bin/bash
cd /
ls -al
:wq!
chmod +x 1.sh
./1.sh
/tmp/1.sh
```
## shell 变量
> 局部变量 只能在当前shell中运行
>
> 全局变量 应用于整个系统 一般大写
```
#!/bin/bash
设置局部变量
a=10 等号两边不能留空格
b=$a
显示局部变量
echo $a 10
echo ${b} 10
echo "a=$a" a=10 双引号解析变量
销毁变量
unset a #这时候不要加$
b=`date` 将系统命令结果赋值给一个变量 命令用`` 包起来
```
位置变量
```
$0 表示的是脚本的名称
$1~$9 传递给脚本的参数
```
## 特殊变量
```
$# 表示传递给脚本的参数个数
$* 传递给脚本的所有参数
$? 表示命令的返回值 0表示成功
```
### 常量
```
readonly a=10
echo $a
a='66'
echo $a #报错 表示 a 是常量 不能修改
```
### 引号
>双引号解析变量
>
>单引号不解析变量 不解析转移字符
>
>`` 能够输出命令的结果
>
>特殊字符 反斜线转义
>
>& * ?^
>
>
>
>\ 转义字符
### 字符串
```
计算字符串的长度
#!/bin/bash
test='123456abc' ${#字符串的名字}
echo ${#test}
提取字符串
${字符串的名字:开始的位置:截取的长度}
echo ${test:3:5} 456ab
```
### 数组
```
a=(1 2 3) #声明一个数组 元素之间 用空格隔开
获取数组的元素 #{a[0]} 1
获取数组的长度 echo ${#a[@]} echo ${#a[*]}
```
## seq
```
seq 5-10 生成5-10之间的连续整数
```
## 运算
#### 数学运算
```
a=100
echo $[$a+10]
echo $[$a-5]
echo $[$a/2]
echo $[$a*2]
echo $[$a%2]
~
echo $((5+10))
echo $((10/2))
echo $((10/3)) 3 整除 余数忽略掉了
```
## 逻辑运算
&&
```
if [ $a != 100 && $b ==100 ]
```
||
```
if [ $a != 100 || $b ==100 ]
```
## 关系运算符
| 运算符 | 说明 |
| ---------- | ------------- |
| -eq == | a -eq b 相等 |
| -ne != | a -ne b |
| -gt > | a -gt b |
| -lt < | a -lt b |
| -ge >= | |
| -le <= | |
| | |
| | |
## 字符串判断
| 运算符 | 说明 |
| ------ | ---------------------------------- |
| = | 字符串是否相等 |
| != | 不等 |
| -z | 字符串的长度是否为0 为0返回true |
| -n | 字符串的长度是否为0 不为0返回true |
| str | 检测字符串是否为空 不为空返回true |
| | |
| | |
## 文件的判断
| 运算符 | 说明 |
| -------- | ------------------------------------------ |
| -d 文件 | 检测是否是目录 是返回true |
| -f 文件 | 检测是否是普通文件 (不是目录不是设备 ) |
| -r 文件 | 检测文件是否只读 |
| -w 文件 | 检测文件是否可写 |
| -x 文件 | 是否可执行 |
| -s 文件 | 检测文件是否为空 也就是说文件的大小是否为0 |
| -e 文件 | 检测文件是否存在 存在返回true |
### 分支语句
#### if-else
```
#!/bin/bash
read -p '请输入您的分数:' score
if [ $score -gt 80 ] 中括号前后有空格
then
echo '优秀'
else
echo '一般'
fi
if [ $score -gt 80 ];then
echo '优秀'
else
echo '一般'
fi
```
#### case
```
case $变量名 in
模式1)
命令1
;;
模式2)
命令2
;;
默认执行的命令
;;
esac
switch(){
case 1:
default
}
```
```
#!/bin/bash
case $1 in
start| begin)
echo 'start'
;;
stop | end)
echo 'stop'
;;
*)
echo 'i dont know'
esac
./2.sh start
```
## 循环语句
```
for 变量 in 列表
do
命令1
命令2
done
for i in 1 2 3 4 5;do
echo $i
done
//从命令中读取值
for j in `cat 1.txt`;do
echo $j
done
读取目录列表
for file in /home/*;do
echo $file
done
求1-100的和
for x in `seq 1 100`;do
let sum+=$x
done
echo $sum
遍历数组
a=(1 2 3 4 5 6)
for i in ${a[*]};do
echo $i
done
```
## while
```
while 条件
do
命令
done
sum=0
i=0
while [ $i -lt 100 ];
do
let sum+=$i
let i+=1
done
echo $sum
```
## 函数
```
先定义 后使用
test(){
echo 'hello world'
}
test
```
切换yum 源头
```
1.cd /etc/apt
准备 两个source.list 一个是公司的 一个是阿里云
```
```shell
#!/bin/bash
rm -rf /etc/apt/source.list
read -p '请选择内网还是阿里云(1 内网 2 阿里云):' network
if [ $newwork -eq 1 ];then
echo '你选择了内网'
cp -r /tmp/source.list /etc/apt/
else
echo '你选择了阿里云'
cp -r /tmp/aliyun/source.list /etc/apt/
fi
sudo apt-get update
sudo apt-get upgrade
```
```
chmod +x 脚本名称.sh
```
### 远程登录 公钥加密 私钥解密
```
ssh 用户名@ip地址
exit 退出远程登录
建立两台主机之间的信任关系
1.10.8.152.117
2.10.8.152.95
第一步: 在 95上
ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_j_rsa 可以自己起名字防止覆盖掉原来的密钥 英文状态下写
Enter passphrase (empty for no passphrase): 回车
Enter same passphrase again: 回车
cat id_j_rsa.pub
复制内容 注意 别复制多 也别复制少
第二步 :
在 117 上
mkdir -p /root/.ssh
cd /root/.ssh
vim authorized_keys
粘贴第一步复制的内容
保存
chmod 600 /root/.ssh/authorized_keys 这一步相当重要
第三步: 在95上 [email protected] 这个时候就不需要输入密码
```
## 远程复制
```
scp -r 源地址 目标地址
scp text.txt [email protected]:/tmp 将本机的文件 复制到 目标主机的tmp目录下面
scp [email protected]:/root/text.txt /tmp
scp -r [email protected]:/root/www /tmp 将远程
```
### screen
```
sudo apt-get install screen
screen -S 自己命名
执行任务
ctrl+a+d 退出会话 回到主窗口
screen -r 窗口名字 进入指定的子窗口
screen -X -S 窗口名 quit 结束指定的 子窗口 任务
```
### 磁盘管理
```
HDD 机械硬盘
HHD 混合硬盘
SDD 固态硬盘
文件系统类型
windows ntfs fat32 fat16 exfat
Linux ext4 ext3 ext2
```
### 查看磁盘的使用情况 df
```
第一块磁盘 sda
第二块就是 sdb
第三块 sdc
df -h 以最佳阅读体验阅读磁盘的使用情况
df -k 以k为单位
df -m 以m为单位
df -h /dev/sda2
```
## 查看文件 及目录对空间的使用情况 du
```
du -a 显示所有文件目录大小 包括隐藏文件
du -h 最佳阅读体验阅读
du -s 只显示目录大小 不显示子目录和文件的大小
du -c 显示目录及文件的大小 并显示总大小
```
## 磁盘分区 fdisk 先分区 再格式化 然后挂载
```
fdisk -l 查看磁盘的分区情况
发现多了一个 /dev/sdb
fdisk /dev/sdb
m 帮助
n 新建一个分区
d 删除一个分区
w 保存
q 退出
新建一个分区
新建主分区 primary 然后 extends 扩展分区
n -p-默认回车-默认回车-+8G-w
格式化
fdisk -l 发现多了一个 /dev/sdb1
mke2fs -t ext4 /dev/sdb1
-t表示 制定文件系统类型
挂载
mkdir -p /python1804
mount -t ext4 /dev/sdb1 /python1804 临时挂载 注销 重启 这个磁盘就没了
df -h
发现 多了一个/dev/sdb1
取消挂载
umount /python1804/
df -h
/dev/sdb1 就没了
永久挂载
vim /etc/fstab
/dev/sdb1 /python1804 ext4 defaults 0 0
新磁盘 挂载点 文件系统类型 默认参数 0 是否需要备份 0不备份 0 是否开机检查磁盘 0 不检查
mount -a 让挂载立即生效
```
### 别名
```
有的命令 加参数 很繁琐 可以根据团队的要求 重新命名 为了提高效率
vim /root/.bashrc
alias 新名字='命令 参数'
alias c='cd'
source /root/.bashrc #让配置未见立即生效
```
posted on
2018-09-12 09:28 liangzhiwen 阅读(
...) 评论(
...) 编辑 收藏