【Hadoop离线基础总结】linux的shell编程
linux的shell编程
基本了解
概述
Shell是一个用C语言编写的程序,通过shell用户可以访问操作系统内核服务,它类似于DOS下的command和后来的cmd.exe。Shell既是一种命令,也是一种程序设计语言
Shell Scripts是一种为Shell编写的脚本程序。Shell编程一般指Shell脚本编程,不是指开发Shell自身
Shell编程跟Java、PHP编程一样,只要有一个能编写代码的文本编辑器,和一个能解释执行的脚本编辑器就可以了
Linux的Shell种类众多,一个系统可以存在多个Shell,可以通过cat /etc/shells命令查看系统安装的Shell
Bash由于易用和免费,在日常工作中被广泛使用。同时,Bash也是大多数Linux系统默认的Shell格式
Shell脚本第一行约定俗成写 #!/bin/bash 或者 #!/bin/sh,用来解释所用的Shell内核执行方式
第一种方式:权限不足时,可以用 sh xxx.sh 或者 bash xxx.sh 来执行Shell脚本
第二种方式:用chmod命令给Shell脚本添加执行权限,再用./xxx.sh执行Shell脚本
Shell变量
- 格式
变量=值 比如:your_name="itcash.cn"
注意事项
变量名、等号和值之间不能有空格,同时,变量名的命名必须遵循如下原则:
1.首个字符必须为字母( a-z,A-Z )
2.中间不能有空格,可以使用下划线 “_”
3.不能使用标点符号
4.不能使用bash里的关键字(可以用help命令查看保留关键字)
ps. vi编辑模式显示行号 “:set nu”变量的使用
使用一个定义过的变量,在变量名前面加 $ 即可
your_name="itcash.cn"
echo $your_name
echo ${your_name}
#花括号是可加可不加的,加花括号是为了帮助解释器识别变量的边界
#已定义的变量可以被重新定义
#使用readonly命令可以将变量定义为只读变量,只读变量的值不能被改变
#使用unset命令可以删除变量,不能删除只读变量
readonly variable_name
unset variable_name
变量类型
局部变量:仅仅在当前的Shell交互窗口当中有效,其他的窗口无效
环境变量:所有的Shell窗口共享,都可以使用,范围最大,所有用户都可以共享
Shell变量:Shell程序设置的特殊变量,只在当前脚本中有效,其他脚本中无效Shell运算符
Shell和其他编程语言一样,支持包括:算数、关系、布尔、字符串等运算符
原生 bash 不支持简单的数学运算,但是可以通过其他命令来实现。
例如:expr -> 一款表达式计算工具,使用它能完成表达式的求值操作
表达式和运算符之间要有空格,完整的表达式要被``包含,不是单引号
#!/bin/bash
a=4
b=20
#加法运算
echo `expr $a + $b`
#减法运算
echo `expr $a - $b`
#乘法运算 注意*号前面要加反斜杠\
echo `expr $a \* $b`
#除法运算
echo `expr $a / $b`
#运算的另外两种写法
c=$((1 + 2))
echo ${c}
d=$[2 - 1]
echo ${d}
流程控制
- 语法补充
关于if语句、for循环和while循环这里已经写过:【Linux基础总结】Shell 基础编程
这里只做一个case语句的补充
#!/bin/bash
#case语句案例
##根据输入的数字给予对应的回复
echo "请您输入一个1-4之间的整型数字"
echo "您输入的数字为:"
read aNum
case $aNum in
1)
echo "您输入的数字为1"
;;
2)
echo "您输入的数字为2"
;;
3)
echo "您输入的数字为3"
;;
4)
echo "您输入的数字为4"
;;
*)
echo "您输入的数字有误"
;;
esac
函数使用
概述:
所有函数在使用前必须定义,这意味着必须将函数放在脚本开始处,直到Shell解释器首次发现它时才可以使用格式:
[ function ] funname [()]{
action;
[return int;]
}
- 函数参数
#!/bin/bash
#定义我们自己的函数,并在Shell脚本中调用
function hello(){
echo "传入给我的第一个参数为"$1
echo "abc"
echo "给我传点参数"
}
#调用函数
hello $1
【Hadoop离线基础总结】linux的shell编程的更多相关文章
- 【Hadoop离线基础总结】oozie的安装部署与使用
目录 简单介绍 概述 架构 安装部署 1.修改core-site.xml 2.上传oozie的安装包并解压 3.解压hadooplibs到与oozie平行的目录 4.创建libext目录,并拷贝依赖包 ...
- Linux 下shell 编程学习脚手架
linux body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-t ...
- 【Hadoop离线基础总结】Hue的简单介绍和安装部署
目录 Hue的简单介绍 概述 核心功能 安装部署 下载Hue的压缩包并上传到linux解压 编译安装启动 启动Hue进程 hue与其他框架的集成 Hue与Hadoop集成 Hue与Hive集成 Hue ...
- 【Hadoop离线基础总结】impala简单介绍及安装部署
目录 impala的简单介绍 概述 优点 缺点 impala和Hive的关系 impala如何和CDH一起工作 impala的架构及查询计划 impala/hive/spark 对比 impala的安 ...
- 【Hadoop离线基础总结】Hive调优手段
Hive调优手段 最常用的调优手段 Fetch抓取 MapJoin 分区裁剪 列裁剪 控制map个数以及reduce个数 JVM重用 数据压缩 Fetch的抓取 出现原因 Hive中对某些情况的查询不 ...
- Linux下Shell编程
Linux的shell编程 1.什么是shell? 当一个用户登录Linux系统之后,系统初始化程序init就为每个用户执行一个称为shell(外壳)的程序. shell就是一个命令行解释器,它为用户 ...
- 【Hadoop离线基础总结】流量日志分析网站整体架构模块开发
目录 数据仓库设计 维度建模概述 维度建模的三种模式 本项目中数据仓库的设计 ETL开发 创建ODS层数据表 导入ODS层数据 生成ODS层明细宽表 统计分析开发 流量分析 受访分析 访客visit分 ...
- 【Hadoop离线基础总结】Sqoop常用命令及参数
目录 常用命令 常用公用参数 公用参数:数据库连接 公用参数:import 公用参数:export 公用参数:hive 常用命令&参数 从关系表导入--import 导出到关系表--expor ...
- 【Hadoop离线基础总结】MapReduce增强(下)
MapReduce增强(下) MapTask运行机制详解以及MapTask的并行度 MapTask运行流程 第一步:读取数据组件InputFormat(默认TextInputFormat)会通过get ...
随机推荐
- Linux/UNIX 下 “command not found” 原因分析及解决
在使用 Linux/UNIX 时,会经常遇到 "command not found" 的错误,就如提示的信息,Linux /UNIX 没有找到该命令.原因无外乎你命令拼写错误或 L ...
- D3平移和缩放后的点击坐标(D3 click coordinates after pan and zoom)
我使用D3库来创建绘图应用程序. 我需要在用户单击的坐标上绘制对象(为了简单起见).问题是当用户使用平移&缩放和移动视口.然后对象是错误的位置的地方(我想问题是事件坐标是相对于svg元素而不是 ...
- 最后の冲刺 for Alpha release 12/15/2015
好开心啊,又吃成长快乐了~ 据说release前一天,团队的工作效率会达到顶峰.亲证无效!!! release当天才是团队智力效力能力的巅峰好不好?!因为,今天,plan B:福昕pdf reader ...
- Eclipse Hadoop源码阅读环境
一.解压hadoop src包到workspace目录.为加快下载jar包的速度,在eclipse的maven设置里将配置文件的路径设置正确,然后配置maven的settings.xml: <m ...
- 数据结构与算法--堆(heap)与栈(stack)的区别
堆和栈的区别 在C.C++编程中,经常需要操作的内存可分为以下几个类别: 栈区(stack):由编译器自动分配和释放,存放函数的参数值,局部变量的值等,其操作方式类似于数据结构中的栈. 堆区(heap ...
- webpack之Loader
我们知道webpack的优点之一就是专注于处理模块化的项目,能做到开箱即用,但同时这也是webpack的缺点,只能用于模块化开发的项目,例如:Vue,React,Angular.Webpack在进行打 ...
- Java IO 流--FileUtils 工具类封装
IO流的操作写多了,会发现都已一样的套路,为了使用方便我们可以模拟commosIo 封装一下自己的FileUtils 工具类: 1.封装文件拷贝: 文件拷贝需要输入输出流对接,通过输入流读取数据,然后 ...
- (转)如何学好C++语言
原文:http://coolshell.cn/articles/4119.html 作者:陈皓 昨天写了一篇如何学好C语言,就有人回复问我如何学好C++,所以,我把我个人的一些学习经验写在这里,希 ...
- Iterator to list的三种方法
目录 简介 使用while 使用ForEachRemaining 使用stream 总结 Iterator to list的三种方法 简介 集合的变量少不了使用Iterator,从集合Iterator ...
- Java高效开发IntelliJ IDEA 2019.1 新特性
1. 重构类.文件.符号,Action 搜索 IntelliJ IDEA(以下简称 IDEA) 中的搜索可以分为以下几类 类搜索,比如 Java,Groovy,Scala 等类文件 文件搜索,类文件之 ...