编脚本Linux文件分类,初识shell脚本编程

shell脚本编程三种分类方式:

1、编译语言的分类:

目前常见的编程有两种一种是编译运行,将源代码通过编译器编译成系统可读的语言。由于此种方式,出现错误不便于修复处理,后来便出现了第二种带有项目管理程序的解释运行方式,他能够将一个完整的程序的所有代码放置在多个可执行文件中,方便了以后的修复和编译。

编辑运行: 源代码需要用编译器转换成系统可执行的二进制程序文件,运行程序时可直接运行无需编译器。(例如C语言是通过调用函数库中或类库中的函数进行编译,运行时无需调用外部程序)

解释运行: 源代码运行时启动一个(解释器程序)由解释器检查通篇检查完代码以后,边解释边运行。(例如脚本编程是完全借助于外部程序进行编程的。)

区别:

[x] 编译运行:运行时效率更高,尤其是早起电脑性能底下式。

[x] 解释运行:有项目管理程序,能够将完整的程序代码放置在多个文件中,方便程序的出错时进行编译。

2、编程过程中功能分类:

shell脚本编程: 利用系统的命令及编程组件进行编程。

完整编程: 并不需要系统中事先存在的某种编译语言。而是根据自己库中的编程组件进行编译。

区别:

[x] shell脚本编程:需要调用外部的系统中的命令及编程组件进行编程。

[x] 完整编程:无需调用系统中的某种编译语言。二审根据自己裤子的

3、编程模型分类:

过程编译语言。面向对象的编译语言。 程序=指令+数据

过程式: 以指令为中心来组织代码,数据是服务于代码

顺序执行:按命令行至上而下逐行运行。

选着执行:只执行一个程序中某一段代码其中的一部分。

循环执行:把循环体中的代码,反复执行多遍。

对象式: 以数据为中心来组织代码,围绕数据来组织指令。

区别:

[x] 过程式:代表C,bash是面向过程的。

[x] 对象式:要事先生成数个对象,每一个对象就相当于是一种特性的数据类型。(或特定的数据模式)编程前要实现编程许多的class(类:被可实例化的对象组成) 代表有 java,C++,pythom。

shell脚本编程:过程式编程,解释运行是依赖于外部程序文件来运行。

如何编写shell脚本:

脚本的第一行,需要顶格写出shebang(解释器的路径),用于指明需要调用的解释执行当前脚本的解释器程序文件。

常见的解释器:

bash:—路径位置 #!/bin/bash

python:路径位置 #!/usr/bin/python

perl:— 路径位置 #!/usr/bin/perl

linux按编译界面可分为两类:

行编译器:sed

全屏幕编译器:nano、vi、vim

编译器注意:

[x] 命令行运行时如果出错可以直观查看。

[x] 在脚本中,一旦出现一个命令错误便会终止异常退出。现实中很多命令都不是幂等性的,以免运行中不幂等性程序终止。这里就需要选着执行、循环执行、顺序执行。

[x] 并不是每个shell脚本执行出错都会退出除非exit命令或者写入的某种判断机制退出。(语法错误也会退出的)

不幂等性:就是命令不可重复执行,如果重复执行便会报错。例如useradd、mkdir、

幂等性:命令可以重复执行,例如echo、ls、mktemp、date、

编写shell命令:nano

如果编写对象存在会直接打开,如果存在便创建然后打开。

写脚本示例:

1、创建一个/tmp/fstab

3c8ce6380daa33c267ccb0e2e66a02de.png

2、编辑内容 创建用户centos显示系统时间 按ctrl+o(保存) ,ctrl+x(退出)

3c8ce6380daa33c267ccb0e2e66a02de.png

3、执行2遍查看返回值

useradd是非幂等性–多次执行报错

date则是幂等性–可执行多次

3c8ce6380daa33c267ccb0e2e66a02de.png

shell脚本是什么?

:是由多个执行单一操作的命令组合堆积在一起。由于很多命令不具有幂等性,需要用程序逻辑来判断运行条件是否满足,以免其运行中发生错误。

运行脚本:

(1) 赋权执行权限,并直接运行此程序文件。 * chmod +x /PATH/TO/SCRIPT_FILE

/PATH/TO/SCRIP_FILE

(2) 直接运行解释器,将脚本命令参数传递给解释器。 * bash /PATH/TO/SCRIPT_FILE

区别:

[x] 赋权执行需要在脚本中首行顶头位几个字节来判断文本类型。由标准格式#!后面指定的解释器执行每行代码。需要事前给与文本指定执行用户的权限。

[x] 直接运行解释器无需在脚本中首行输入指定的解释器,是将编写的脚本当作bash的参数来运行。也无需运行文本权限。

注意:

[x] shell脚本中的一行的空格会被忽略,如果想要加入空格可在空格的上一行键入echo即可。

[x] #号开头的文字都会被认定为注视行被忽略。

[x] shell脚本的运行是通过一个bash的子shell进程来实现的。

示例 :直接运行解释

打开一个脚本文件 Notes. sh

3c8ce6380daa33c267ccb0e2e66a02de.png

编辑界面注意首行没有指定外部的解释器。每句下面一行都留有空格行还有最后一句的#号

3c8ce6380daa33c267ccb0e2e66a02de.png

验证了# 、于空白行都被忽略了

3c8ce6380daa33c267ccb0e2e66a02de.png

示例 : 赋权执行权限

创建文件Ga. sh

3c8ce6380daa33c267ccb0e2e66a02de.png

编辑命令首行输入标准格式

3c8ce6380daa33c267ccb0e2e66a02de.png

授权给文件执行权限并退出系统

3c8ce6380daa33c267ccb0e2e66a02de.png

重新登陆查看效果

3c8ce6380daa33c267ccb0e2e66a02de.png

bash的配置文件:

由于bash的特性避免bash的声明周期结束时,配置文件也同时随之结束。可以通过将bash写入配置文件中来突破生命周期。bash的配置文件分为量两类:

profile类:为交互式登录的shell的进程提供配置。

bashrc 类:非交互式登录的shell的进程提供配置。

登录类型:

交互式登录的shell进程:

直接登录console、pst、tty、ttys、任意一种终端输入账号和密码后登录打开的shell进程,

使用su命令:su USERNAME 或 su – USERNAME(登录式)执行切换。

非交互式登录shell进程:

su SUERNAME执行的用户登录切换。

图形界面下打开的终端

运行脚本。

profile类文件:

Cento 系统把很多的配置文件切割成主配置文件和配置文件放置在.d 或者.sh文件中,

全局配置: 对所有用户有效。 /etc/profile/etc/profile.d/*.sh

用户个人: 仅对当前用户有效 * ~/.bans_profile

~:表示家目录

功用:

1、用来定义环境变量,【将配置文件定义到profile下,每次运行时都打开】

2、运行命令或脚本,【也是通过profile】

bashrc类型:

用于定义本地变量和命令别名

全局: * /etc/bansrc

用户个人: * ~/.bashrc

~:表示家目录

功用:

1、定义本地变量。在bansrc内,

2、定义别名。

shell进程加载配置流程图:

3c8ce6380daa33c267ccb0e2e66a02de.png

3c8ce6380daa33c267ccb0e2e66a02de.png

注意:

仅有管理员有权限修改全局配置文件。

当前用户编写的脚本不会立即生效需,只有在下次用户登陆进程才有效。

为了方便日后对脚本的管理,可以在文件特定的文件内新建一个以sh结尾的配置文件。

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/90078

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值