linux学习19 shell脚本基础-bash脚本编程基础及配置文件
一、shell脚本编程
1、编程语言的分类,根据运行方式
a、编译运行:源代码 --> 编译器(编译) --> 程序文件
C语言:
b、解释运行:源代码 --> 运行时启动解释器,由解释器边解释边运行;即源代码本身并不能运行,而是启动一个解释器的进程,把整个源代码的内容当做解释器的参数。因为其是边解释边运行因此运行过程中比起编译运行速度会差一些。
c、无论是编译器还是解释器中间总需要另外一个程序,即在运行过程中全程参与,这就是我们说的翻译官,他需要将我们人能识别的代码转换成机器所能识别的机器码。
2、根据其编程过程中功能的实现是调用库还是调用外部的程序文件:
a、shell脚本编程:
利用系统上的命令及编程组件进行编程
b、完整编程:
利用库或编程组件进行编程
3、根据编程模型进行分类:过程式编程语言,面向对象的编程语言
程序=指令+数据
过程式:以指令为中心来组织代码,数据是服务于代码的。
顺序执行。
选择执行
循环执行
C,bash
对象式:以数据为中心来组织代码,围绕数据来组织指令。
类(class):实例化对象,method;
代表:java,C++,Python
4、shell脚本编程:过程式编程,解释运行,依赖于外部程序文件运行;
二、如何写shell脚本
1、脚本文件的第一行,顶格:给出shebang,解释器途径,用于指明解释执行当前脚本的解释器程序文件。
a、常见的解释器
#!/bin/bash
#!/usr/bin/python
#!/usr/bin/perl
b、常见的文本编辑器:nano
行编辑器:sed
全屏幕编辑器:nano,vi,vim
[root@node1 ~]# nano myfirst.sh
[root@node1 ~]# cat myfirst.sh
#!/bin/bash
useradd user3
echo "user3"|passwd --stdin user3
mktemp -d /tmp/test.xxxx [root@node1 ~]# chmod +x myfirst.sh
[root@node1 ~]# ./myfirst.sh
Changing password for user user3.
passwd: all authentication tokens updated successfully.
mktemp: too few X's in template ‘/tmp/test.xxxx’
2、shell脚本是什么?
命令的堆积
但很多命令不具有幂等性,需要用程序逻辑来判断运行条件是否满足,以避免其运行中发生错误。
3、运行脚本
a、赋予执行权限,并直接运行此程序文件即可
chmod +x /PATH/TO/SCRIPT_FILE
/PATH/TO/SCRIPT_FILE
b、直接运行解释器,将脚本以命令行参数传递给解释器程序
bash /PATH/TO/SCRIPT_FILE
注意:
脚本中的空白行会被解释器忽略
脚本中,除了shebang,余下所有以#开头的行,都会被视作注释行而被忽略;此即为注释行。
c、练习1:写一个脚本,实现如下功能:
(1)、显示/etc目录下所有以大写p或小写p开头的文件或目录本身
[root@node1 ~]# ls -d /etc/[pP]*
/etc/pam.d /etc/passwd- /etc/pkcs11 /etc/plymouth /etc/polkit- /etc/postfix /etc/prelink.conf.d /etc/profile /etc/protocols
/etc/passwd /etc/pinforc /etc/pki /etc/pm /etc/popt.d /etc/ppp /etc/printcap /etc/profile.d /etc/python
(2)、显示/var目录下的所有文件或目录本身,并将显示结果中的小写字母转换为大写后显示;
[root@node1 var]# ls -d /var/* |tr 'a-z' "A-Z"
/VAR/ACCOUNT
/VAR/ADM
/VAR/CACHE
/VAR/CRASH
/VAR/DB
/VAR/EMPTY
/VAR/GAMES
/VAR/GOPHER
/VAR/KERBEROS
/VAR/LIB
/VAR/LOCAL
/VAR/LOCK
/VAR/LOG
/VAR/MAIL
/VAR/NIS
/VAR/OPT
/VAR/PRESERVE
/VAR/RUN
/VAR/SPOOL
/VAR/TMP
/VAR/WWW
/VAR/YP
(3)、创建临时文件/tmp/myfile.XXXX
[root@node1 var]# mktemp -d /tmp/myfile.XXXX
/tmp/myfile.Z19s
三、bash的配置文件
1、分为两类
a、profile类:为交互式登陆的shell进程提供配置
b、bashrc类:为非交互式登陆的shell进程提供配置
2、登陆类型
a、交互式登陆shell进程:
直接通过某终端输入账号和密码后登陆打开的shell进程
使用su 命令:su - USERNAME,或者使用su -l USERNAME执行的登陆切换
b、非交互式登陆shell进程
su USERNAME执行的登陆切换
在图形界面下打开的终端
运行脚本
3、profile类
a、全局:对所有用户都生效
/etc/profile
/etc/profil.d/*.sh
b、用户个人:仅对当前用户有效
~/.bash_profile
c、功用:
(1)、用于定义环境变量
(2)、运行命令或脚本
4、bashrc类:
a、全局:
/etc/bashrc
b、用户个人
~/.bashrc
c、功用
(1)、定义本地变量
(2)、定义命令别名
d、注意:仅管理员可修改全局配置文件
5、配置文件的读取次序
a、交互式登陆shell进程: /etc/profile --> /etc/profile.d --> ~/.bash_profile --> ~/.bashrc -->/etc/bashrc
b、非交互式登陆shell进程:
~/.bashrc --> /etc/bashrc --> /etc/profile.d/*
6、配置文件生效特性
a、命令行中定义的特性,例如变量和别名作用域为当前shell进程的生命周期
b、配置文件定义的特性,只对随后新启动的shell进程有效
c、让通过配置文件定义的特性立即生效
(1)、通过命令行重复定义一次
(2)、让shell进程重读配置文件
source /PATH/FROM/CONF_FILE
.(小点) /PATH/FROM/CONF_FILE
[root@node1 ~]# alias
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
[root@node1 ~]# nano /root/.bashrc
[root@node1 ~]# cat /root/.bashrc
# .bashrc # User specific aliases and functions alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'
alias cls='clear'
# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
[root@node1 ~]# source /root/.bashrc
[root@node1 ~]# alias
alias cls='clear'
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
四、问题
1、定义对所有用户都生效的命令别名,例如:"lftps"="lftp 172.16.0.1/pub"
2、让centos用户登录时,提供其已经登录,并显示当前系统时间
linux学习19 shell脚本基础-bash脚本编程基础及配置文件的更多相关文章
- Linux学习(1)- TCP/IP网络协议基础
Linux学习(1)- TCP/IP网络协议基础 一.TCP/IP 简介 学习内容 TCP/IP(Transmission Control Protocol/Internet Protocol)是传输 ...
- linux学习18 shell脚本基础-bash变量和逻辑运行
一.回顾 1.用户管理,权限管理,install,mktemp 2.用户管理: 3.权限管理: mode,ownership mode: user group other r w x 4.命令:ins ...
- Linux之19——Shell编程基础详解
第一部分:Linux Shell 简介 Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁.Shell 既是一种命令语言,又是一种程序设计语言. Shell 是指一种应用程序, ...
- linux 学习10 shell 基础
10.1 Shell概述 .Shell是什么 Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用Shell来启动.挂起.停止甚至是编写一 ...
- Linux学习之Shell编程基础
转自:http://my.oschina.net/itblog/blog/204410 1 语法基本介绍1.1 开头 程序必须以下面的行开始(必须方在文件的第一行): #!/bin/sh 符号#!用来 ...
- 在ubuntu linux 中编写一个自己的bash脚本
在ubuntu linux 中编写一个自己的简单的bash脚本. 实现功能:终端中输入简单的命令(以pm为例(play music)),来实现音乐的播放.注:本人ununut中安装了audacious ...
- Linux 学习 (八) Shell
Linux达人养成计划 I 学习笔记 Shell 是什么: Shell 是一个命令解释器 Shell 还是一个功能相当强大的编程语言,易编写,易调试,灵活性较强 Shell 的分类: Bourne S ...
- (原创)鸟哥linux学习script shell相关笔记
在使用鸟哥linux进行script shell学习的过程中碰到一些不太明白的知识点,在这里进行一些记录 1. [root@www scripts]# vi sh03.sh #!/bin/bash # ...
- (零)linux 学习 -- 从 shell 开始
The Linux Command Line 读书笔记 - 部分内容来自 http://billie66.github.io/TLCL/book/chap02.html 文章目录 前言 什么是 she ...
随机推荐
- CentOS 7.5在线安装Docker 18.09.3
1.安装依赖包 yum -y install yum-utils device-mapper-persistent-data lvm2 2.安装docker yum-config-manager -- ...
- POJ 3274/洛谷 1360:Gold Balanced Lineup 黄金阵容平衡
题目描述 Farmer John's N cows (1 ≤ N ≤ 100,000) share many similarities. In fact, FJ has been able to na ...
- 怎么才能记住java线程的start()和run()谁是启动方法
start()和run()开始的时候总是记不住那个是线程的启动方法,现在是记得很真切了! 如果用run()启动线程就跟不用线程效果是一样的,因为是run是顺序执行的.start()才是线程的启动方法. ...
- Kubernetes---网络通讯模式笔记
⒈kubernetes网络通讯模式 Kubernetes的网络模型假定了所有Pod都在一个可以直接连通的扁平的网络空间中,这在GCE(Google Compute Engine)里面是现成的网 ...
- centos8自定义目录安装nginx
1.安装工具和库 # PCRE是一个Perl库,包括 perl 兼容的正则表达式库.nginx 的 http 模块使用 pcre 来解析正则表达式 # zlib库提供了很多种压缩和解压缩的方式, ng ...
- 学习扩展kmp
参考博客:https://blog.csdn.net/s_999999/article/details/89104957
- ideaIU-2019.2.exe-安装目录和设置目录结构的说明
一.查看安装目录结构 bin: 容器,执行文件和启动参数等 help:快捷键文档和其他帮助文档 jbr: 含有java运行环境 lib:idea 依赖的类库 license:各个插件许可 plugin ...
- MySQL 设置密码和允许远程登录
mysqladmin -u root password "newpass" GRANT ALL PRIVILEGES ON *.* TO root' WITH GRANT OPTI ...
- arcgis js之点击获取featureLayer中的点
arcgis js之点击获取featureLayer中的点 代码: this.view.on('click', (evt) => { let layer = this.map.findLayer ...
- 行级安全(Row
通过授予和拒绝(Grant/Deny)命令控制用户的权限,只能控制用户对数据库对象的访问权限,这意味着,用户访问的粒度是对象整体,可以是一个数据表,或视图等,用户要么能够访问数据库对象,要么没有权限访 ...