大数据学习第四天

Posted lkoooox

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了大数据学习第四天相关的知识,希望对你有一定的参考价值。

大数据学习第四天

pstree 查看当前进程结构

source 加载文件 在当前bash

. 在当前bash运行脚本

bash 相当于浏览器加cmd

chomd +x 把文件变为可执行文件

#! /路径 在文件首行指定运行编译/解释器 不写时默认bash

#! 注释的行会在第一次读取时直接运行

yum serch 查询yum情况

文件输出类型

0 标准输入

1 标准输出

2 错误输出

可以用于多种结果的不同输出 正常结果 1>/路径

错误结果 2>/路径

配置service服务文件

/etc/init.d/

chkconfig nn 运行模式 1-6 nn 运行优先级 nn 关机级别

 

vi 模式下 末行 set ts设置缩进距离

在脚本中‘命令行‘ 变量名=‘cat 文件名‘赋值 获取文件内容赋值变量

bash -x debug运行

ps -aux 查看所有进程

 

chkconfig 所有服务的配置情况

--list 查看所有服务的配置启用情况

$(变量名)字符串 变量字符串拼接

子bash执行指令时直接继承父bash环境(变量 运行环境...)

子bash执行文件时不会继承父bash的值

& 后台运行

| 管道创建子进程时会全部继承父bash的值

‘ ‘ 强引用 完全引用

"" 弱引用

while 后面必须跟一个命令 比如test

du -h 查看文件夹下文件大小

$IFS 输出默认换行符

IFS=$‘\n‘ 强制写法

改值之后需要回滚值

IFS = oldIFS(自定义变量)

bash的变量类型:

环境变量 :export

本地变量:shell脚本在运行时启动一个子bash来解释的。

局部变量

位置变量

特殊变量:bash内置的用来保存某些特殊数据的变量。(也叫系统变量)

本地变量:只属于某一个shellscript的变量。

var_name=值

作用域:整个bash进程

局部变量:

local var_name =值,

作用域:当前代码段。

环境变量:

export 名字=值

作用域:当前的shell和其子shell。

注意:脚本在执行时都会启动一个子shell进程:

命令行中启动的脚本会继承当前shell环境变量。

系统自动启动脚本(非命令行启动):则需要自我定义环境变量。

位置变量: 用于 脚本执行的参数,$1 表示第一个参数,以此类推

$0,$1,$2….

$0:表示脚本本身的文件名

特殊变量:

$? :上一个命令的执行状态返回值。

$# 传递到脚本的参数个数

$* 传递到脚本的参数,与位置变量不同,此选项参数可超过9个

$$ 脚本运行时当前进程的ID号,常用作临时变量的后缀,如 haison.$$

$! 后台运行的(&)最后一个进程的ID号

[email protected] 与$#相同,使用时加引号,并在引号中返回参数个数

$- 上一个命令的最后一个参数

$? 最后命令的退出状态,0表示没有错误,其他任何值表明有错误

 

程序有两类返回值:

1、 执行结果 :标准,错误 :标准输出,错误输出

2、 执行状态,$? : 0:表示正确,1-255:错误

输出重定向:

>覆盖重定向

>> 追加重定向

2> 错误覆盖重定向

2>>错误追加重定向

&> 全部重定向

&>> 全部信息追加重定向

撤销变量:

unset 变量名

 

查看shell中变量:

set 命令

查看shell中的环境变量

printenv

env

export

引用变量:$变量名,一般可以省略?

单引号:强引用,不作变量替换

双引号:弱引用,做变量替换

反引号:``命令替换

脚本:命令的堆砌。

 

练习:写一个脚本,完成以下任务。

1、 添加5个用户,user1,,,,user5

2、 每个用户的密码同用户名,要求:添加密码完成后不显示passwd执行结果。

3、 显示添加成功信息

练习2:写一个脚本,完成以下任务。

1、 使用一个变量保存一个用户名

2、 删除此变量中的用户,且一并删除其家目录

3、 显示“用户删除成功”信息。

 

 

 

条件判断:

条件表达式:

1、 [ expression ]

2、 test expression

3、 任何一个命令都可以作为条件表达式

整数比较:

-eq : 比如:[ $A –eq $B ]

-ne , -gt ,-lt,-ge,-le

命令的逻辑关系:

在linux 中 命令执行状态:0 为真,其他为假

 

逻辑与: &&

第一个条件为假时,第二条件不用再判断,最终结果已经有;

第一个条件为真时,第二条件必须得判断;

逻辑或: ||

逻辑非: !

命令执行的状态 的逻辑关系

1、如果用户user6不存在则添加用户6

! id user6 && useradd user6

Id user6 || useradd user6

 

2、如果用户不存在,添加用户并显示添加成功,否则显示其已存在

 

3、如果/etc/inittab文件的行数大于50,就显示好大的文件;

练习:

1、 添加3个用户user1.user3,并且设置密码和用户名相同,如果用户已经存在,显示:已存在

2、 添加完成之后计算系统一共有多个用户。

 

 

练习:给定一个用户,

1、 如果其UID=0,就显示其为管理员,否则显示其为普通用户

 

备注:

passwd默认是要用终端作为标准输入,加上--stdin表示可以用任意文件做标准输入 于是这里用管道作为标准输入

 

条件判断,控制结构:

 

If 条件 ;then

语句

elif 条件 ; then

语句

else

语句

fi

 

-a : 逻辑与,并且 : if [ $# -gt 1 –a $# -lt 3 –o $# -eq 2 ] ; then

-o :或者 比如:

练习:判断命令历史中历史命令的总条目大于500,如果大于,则显示“Some command is done.”,否则显示:“OR”。

练习:给定三个整数,判断其中的最大值和最小数。并显示出来

 

bash -n shell文件 :检查文件是否有语法错误。

bash –x shell 文件 :debug 执行文件

Shell 中如何算术运算

1、 let 算术运算表达式

let C=$A + $B

2、$[算术表达式]

C = $[$A+$B]

3、$((算术表达式))

C=$(($A+$B))

3、 expr 算术表达式 ,注意:表达式中各操作数及运算符之间要有空格。而且要使用命令引用

C=expr $A + $B

练习:给定一个用户,获取其密码警告期限,然后判断用户密码使用期限是否已经小于警告期限,如果小于,则是显示“WARN” ,否则显示密码还有多少天到期。

提示:date +%s :今天的秒数

Cat /etc/shadow 密码时间。

 

exit : 退出脚本

退出脚本可以指定脚本执行的状态:exit 0 。

复习:

测试方法:

[ 表达式 ]

[[ 表达式 ]]

test 表达式

INT1=33

INT2=32

[ $INT1 -eq $INT2 ]

[[ $INT1 -eq $INT2 ]]

test $INT1 -eq $INT2

文件测试: [ ] 需要中括号

-e FILE :测试文件是否存在

-f FILE :测试文件是否为普通文件

-d FILE :测试文件是否为目录

-r 权限

-w

-x

特殊变量:

$# [email protected]

字符串测试:

== 等号两端需要空格

!=

-n string : 判断字符串是否为空

-s string : 判断字符串是否不空

练习:指定一个用户名,判断此用户的用户名和它的基本组 组名是否相同.

#!/bin/bash

if ! id $1 &>/dev/null ; then

echo “No such user.”

exit 12

fi

if [ $1 == id –n –g $1 ] ;then

echo “xiangtong”

else

echo “bu xiangtong”

fi

 

练习: 判断当前主机的CPU生产商,(其信息保存在/proc/cupinfo文件中)。

如果是:AuthemticAMD ,就显示其为AMD公司

GenuineIntel ,就显示其为 Intel公司

否则,就显示其为非主流公司。

 

练习:将那些可以登录的用户查询出来,并且将用户的帐号信息提取出来,后放入/tmp/test.txt文件中,并给定行号。在行首。

 

循环:进入条件,退出条件

for 变量 in 列表 ; do

语句

done

比如: for I in 1 2 3 4 5 ;do

语句

done、

如何生成列表:

1、1..100

2、seq 起始数 结束数

3、ls /etc 文件列表

练习:依次向/etc/passwd中的每个用户问好:hello 用户名,并显示用户的shell:

Hello ,root ,your shell :/bin/bash。

2、 只向默认shell为bash的用户问好。

 

 

While 循环

格式一

while 条件;do

语句

[break]

done

格式二 死循环

while true

do

语句

done

格式三 死循环

while :

do

语句

done

格式四 死循环

while [ 1 ]

do

语句

done

格式五 死循环

while [ 0 ]

do

语句

done

练习:计算100以内所有能被3整除的整数的和

 

 

练习:使用echo输出10个随机数,并且一行显示。提示:$RANDOM

练习:传给脚本一个参数:目录,找到该目录中文件最大的,文件名和文件大小:

比如:1.txt 100KB

ls -l | awk ‘print $5,$9‘ | sort -nr

2、查看该目录下是否有大小为0的文件,如果有则删除。同时显示删除信息。

练习:查询当前192.168.10.x网段内,那些IP被使用了,输出这些IP到一个文件中。

练习:请根据一个关键字,杀掉系统进程中包含此关键字的进程。

echo –n $RANDOM

 

函数:

Function 名字()

 

case 语句

case 变量 in

value1)

语句

;;

value2)

语句

;;

*)

语句

;;

esac

以上是关于大数据学习第四天的主要内容,如果未能解决你的问题,请参考以下文章

大数据JAVA基础第十四天

Java学习第二十四天

大数据第四天

大数据第四天作业

莫烦scikit-learn学习自修第四天内置训练数据集

python 学习第四天