【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 ...
随机推荐
- SQL Server 2005 sa登录失败。已成功与服务器建立连接 但是在登录过程中发生错误。 provider 共享内存提供程序 error 0 管道的另一端上无任何进程。
SQL Server 2005 Express版 用户 'sa' 登录失败.该用户与可信 SQL Server 连接无关联.提示错误:已成功与服务器建立连接 但是在登录过程中发生错误. provide ...
- Python-气象-大气科学-可视化绘图系列(二)——利用basemap叠加地图,并添加白化效果(代码+示例)
本文为原创链接: https:////www.cnblogs.com/zhanling/p/12193031.html 白化单图代码: import numpy as np import xarray ...
- D - Three Integers CodeForces - 1311D
题意: a<=b<=c 输出A,B,C要求B是A的倍数,C是B的倍数,并且输出a,b,c变成A,B,C需要的最小次数. 题解:写了半天的二分,后来发现思路错了,,,暴力就能过.. 三层fo ...
- D. 蚂蚁平面
D. 蚂蚁平面 单点时限: 2.0 sec 内存限制: 512 MB 平面上有 n只蚂蚁,它走过的路径可以看作一条直线 由这n 条直线定义的某些区域是无界的,而另一些区域则是有界的. 有界区域的最大个 ...
- 4. js
1.) ~ 操作符 console.log(~-2) // 1 console.log(~-1) // 0 console.log(~0) // -1 console.log(~1) // ...
- cgi、fastCGI、php-fpm、 php-CGI的区别
cgi.fastCGI.php-fpm. php-CGI的区别 作为面试的高频热点问题,必须来一波记录: 我们发送一个请求到收到响应之间的一个过程是什么? 如果客户端请求的是 index.html,那 ...
- 2019-2020-1 20199328《Linux内核原理与分析》第四周作业
<Linux内核原理与分析>第四周作业 步骤一 首先我们指定一个内核并指定内存根文件系统,这里的bzImage是vmLinux经过gzip压缩的内核,"b"表示&quo ...
- Libra教程之:来了,你最爱的Move语言
文章目录 Move语言 Move的核心概念 Move交易脚本 Move modules Move resources 写一个Move程序 编写交易脚本 编写自己的Modules Move语言 Move ...
- HTML模版组件
1.介绍 BootStrap (最好看的) css js [x] 学习 BootStrap 规则 jQueryUI (美观一般,偏后台.*) css js [x] 学习 jQueryUI 规则 Eas ...
- ES6特性之:参数默认值
作为一个开发者,跟进行业步伐是非常需要的,不能躺在现有的知识和经验温床上做美梦.JavaScript的ES2015标准(即我们说的ES6)在2016年已经被广泛应用了,还没开始使用的朋友,赶紧来磨一下 ...