shell编程(一)

5 篇文章 0 订阅

shell编程(一)

如今,不会Linux的程序员都不意思说自己是程序员,而不会shell编程就不能说自己会Linux。说起来似乎shell编程很屌啊,然而不用担心,其实shell编程真的很简单。

背景

什么是shell编程

高大上的解释,往往让人摸不住头脑。一句话概括就是:shell编程就是对一堆Linux命令的逻辑化处理。

为什么要会shell编程

举个简单的例子,我们做javaweb开发的,在以前,如果要在本地将程序打包,然后部署到远程服务器(抛开现在的ci, 原始的方法), 我们以前的做法通常会经历如下几个步骤:

  • 拉取最新代码(git pull)
  • 编译打包
  • 上传并部署到远程服务器

每次打包都要经历这一个阶段,效率低又烦躁。而此时,我们可以编写一个shell脚本,然后每次只需要运行一下这个shell脚本,即可实现打包部署这一系列动作,彻底解放双手,多好

入门

第一个shell程序

#!/bin/bash
#第一个shell小程序
echo hello world!

以上,我们的第一个shell小程序就完成了,结果当然是输出我们熟悉的hello world。

第一行表示我们选择使用bash shell。

shell中#符号表示注释。shell的第一行比较特殊,一般都会以#!开始来指定使用的shell类型。在linux中,除了bash shell以外,还有很多版本的shell, 例如zsh、dash等等...不过bash shell还是我们使用最多的。

第二行以#符号开始,表示本行是注释,运行的时候是不会运行本行的。

第三行中的echo是linux中的输出命令,该行的意思很明显的就是输出hello world!

运行第一个shell程序

新创建一个文件(hello_world.sh), 然后将以上代码复制到此文件中,然后需要赋予此文件的可执行权限。

chmod +x hello_world.sh

最后执行:

./hello_world.sh

在linux中,后缀名几乎是可以任意的或者没有后缀名,一般将shell保存为xxx.sh是为了看起来更直观。

如果直接执行hello_world.sh,这时会默认从$PATH环境变量中去寻找,这时,由于我们没有将此文件配置在环境变量中,因此会找不到。所以,我们用了"."这个符号,表示从当前目录找。
除了以上执行方法,我们还可以直接指定shell来运行:

/bin/sh hello_world.sh

这儿我们指定用了/bin/sh来执行,这时hello_world.sh中指定的/bin/bash将不会生效。

变量

编程岂能没有变量?对吧?

shell编程中分为两种变量,第一种是我们自己定义的变量(自定义变量),第二种是Linux已定义的环境变量(环境变量, 例如:$PATH, $HOME 等..., 这类变量我们可以直接使用)。

#!/bin/bash
#使用环境变量
echo $PATH
#自定义变量hello
hello="hello world"
echo $hello

以上演示了自定义变量和系统环境变量的用法,使用很简单,就是使用$符号加上变量名就行了。记住:定义变量不用$符号,使用变量要加$就行了。

在第5行中,我们在自定义变量时,使用了双引号,在shell编程中, 如果变量出现空格或者引号,那么也必须加引号, 否则就可以省略。

还有一点需要注意,定义变量的时候,“=”左右千万不要有空格啊

将linux命令执行结果赋值给变量

#!/bin/bash
path=$(pwd)
files=`ls -al`
echo current path: $path
echo files: $files

以上2行和第3行分别演示了两种方式来将Linux命令执行结果保存到变量。

第2行将pwd执行结果(当前所在目录)赋值给path变量。

第3行将ls -al命令执行结果(列出当前目录下所有的文件及文件夹)赋值给变量

注意:第三行的符号不是单引号,是键盘上“~”这个按键

好啦,到此,对shell编程已经有初步认识了,也会使用变量了。到此,看起来shell编程是不是很的简单。没错,其实真的就这么一回事。

总结:

1)echo $(pwd)  :即:将pwd命令的执行结果输出打印  (获取当前路径)

等同于 echo $`pwd`   Note: ``符号的使用。

2)echo $`ls -al` :即:获取当前路径下的所有的文件或者目录。

 等同于 echo  $(ls -al) 


[hadoop@netcloud01 hive]$ echo $(pwd)
/opt/hive
[hadoop@netcloud01 hive]$  echo $`pwd`
$/opt/hive
[hadoop@netcloud01 hive]$ echo $(ls -al)
total 140 drwxrwxr-x 9 hadoop hadoop 4096 Feb 6 18:58 . drwxr-xr-x. 19 hadoop root 4096 Feb 18 10:36 .. drwxrwxr-x 3 hadoop hadoop 4096 Feb 6 18:58 bin drwxrwxr-x 2 hadoop hadoop 4096 Feb 6 19:00 conf drwxrwxr-x 4 hadoop hadoop 4096 Feb 6 18:58 examples drwxrwxr-x 7 hadoop hadoop 4096 Feb 6 18:58 hcatalog drwxrwxr-x 2 hadoop hadoop 4096 Feb 6 18:58 jdbc drwxrwxr-x 4 hadoop hadoop 12288 Feb 6 19:13 lib -rw-r--r-- 1 hadoop hadoop 29003 Jun 3 2016 LICENSE -rw-r--r-- 1 hadoop hadoop 513 Jun 3 2016 NOTICE -rw-r--r-- 1 hadoop hadoop 4122 Jun 3 2016 README.txt -rw-r--r-- 1 hadoop hadoop 50294 Jun 17 2016 RELEASE_NOTES.txt drwxrwxr-x 4 hadoop hadoop 4096 Feb 6 18:58 scripts
[hadoop@netcloud01 hive]$ echo $`ls -al`
$total 140 drwxrwxr-x 9 hadoop hadoop 4096 Feb 6 18:58 . drwxr-xr-x. 19 hadoop root 4096 Feb 18 10:36 .. drwxrwxr-x 3 hadoop hadoop 4096 Feb 6 18:58 bin drwxrwxr-x 2 hadoop hadoop 4096 Feb 6 19:00 conf drwxrwxr-x 4 hadoop hadoop 4096 Feb 6 18:58 examples drwxrwxr-x 7 hadoop hadoop 4096 Feb 6 18:58 hcatalog drwxrwxr-x 2 hadoop hadoop 4096 Feb 6 18:58 jdbc drwxrwxr-x 4 hadoop hadoop 12288 Feb 6 19:13 lib -rw-r--r-- 1 hadoop hadoop 29003 Jun 3 2016 LICENSE -rw-r--r-- 1 hadoop hadoop 513 Jun 3 2016 NOTICE -rw-r--r-- 1 hadoop hadoop 4122 Jun 3 2016 README.txt -rw-r--r-- 1 hadoop hadoop 50294 Jun 17 2016 RELEASE_NOTES.txt drwxrwxr-x 4 hadoop hadoop 4096 Feb 6 18:58 scripts

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值