百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Shell简介 shell介绍

liuian 2024-12-16 14:48 35 浏览

一、Shell脚本建立

1. 什么是shell

????Shell是一个命令解释器,它在操作系统的最外层负责直接与用户对话,把用户的输入解释给操作系统,并且处理操作系统的输出结果,输出到屏幕给用户。这种对话方式可以是交互方式或者非交互式(脚本)的。

2. 什么是Shell脚本

????当Linux命令或者语句不在命令行下执行,而是通过一个程序文件执行时,该程序就被称为shell脚本。用户在shell脚本中写入一系列的命令语句组合,并且将这些命令、变量和流程控制语句有机的组合在一起就形成了一个功能强大shell脚本。

3. Shell脚本的建立

????在Linux中Shell脚本通常是在编辑器(vi/vim)中编写的,脚本的第一行会指出由哪一个解释器来执行脚本中的内容,比如:

#! /bin/bash
#
# network       Bring up/down networking
#
...

????脚本中开头的"#!"被称为幻数,在执行bash脚本时,内核会根据“#!”后的解释器来确定使用何种解释器来解释脚本的内容。值得注意的是这一行必须顶行来写。另外有时在脚本中会看到顶行的解释器写的是/bin/sh,这与/bin/bash有什么区别呢?

[root@localhost init.d]# ll /bin/sh
lrwxrwxrwx. 1 root root 4 Oct  1 14:27 /bin/sh -> bash

????可以看到/bin/sh是/bin/bash的软链接,没什么区别,不过一般系统自带的shell脚本使用/bin/bash,用户自定义的一般指定/bin/sh。假如脚本中不指定解释器的话(第一行省略)就会使用系统默认的解释器,也就是bash,不过最好还是自己写上,比较符合规范。 ????另外就是shell中使用"#"进行注释,"#"后面的内容不会被解释器执行,只是单纯的注释,方便开发人员与自己查看功能说明,注释内容可以单起一行,也可以写在脚本后面。

2. 规范

  • 开头指定脚本解释器
  • 脚本中尽量使用英文注释,避免乱码
  • 脚本以.sh作为扩展名
  • 对于()、[]等成对的一次写出来,并且[]中内容两侧有空格;
  • 流程控制与迭代语句一次将结构写完整,然后再写中间内容

二、Shell脚本执行

????当shell脚本以非交互式的方式运行时,它会先查找环境变量ENV,该变量指定了一个环境文件(比如.bashrc、.bash_profile、/etc/profile等),然后从该环境变量文件开始回字形,当读取了ENV文件后,shell才开始执行shell脚本中的内容。 shell脚本的执行通常有以下三种方式:

  • bash test.sh 或 sh test.sh
  • ./test.sh(当前路径执行脚本)
  • source test.sh 或. test.sh

????第一种方式是脚本文件本身没有可执行权限时常使用的方法,推荐使用bash执行;第二种方式需要将脚本文件的权限改为可执行(chmod u+x test.sh),然后通过脚本路径就可以执行脚本了;第三种方式是使用source或者"."点号加载sehll脚本文件,该方式可以将脚本中变量或者函数导出到当前环境中进行调用。

# 使用source或者"."可以将脚本中的变量获取,但是如果使用其它两种方式,
# 脚本一旦执行完毕后获取不到变量

[root@localhost project]# echo 'user=`whoami`' > test.sh
[root@localhost project]# . test.sh 
[root@localhost project]# echo $user
root

但是如果使用其它两种执行方式是没有这种效果的:

# 输出为空
[root@localhost project]# echo 'user=`whoami`' > test.sh
[root@localhost project]# /bin/sh test.sh 
[root@localhost project]# echo $user
...

相关推荐

10种常见的MySQL错误,你可中招?

【51CTO.com快译】如果未能对MySQL8进行恰当的配置,您非但可能遇到无法顺利访问、或调用MySQL的窘境,而且还可能给真实的应用生产环境带来巨大的影响。本文列举了十种MySQL...

MySQL主从如何保证数据一致性

MySQL主从(主备)搭建请点击基于Spring的数据库读写分离。MySQL主备基本原理假设主备切换前,我们的主库是节点A,节点B是节点A的备库,客户端的读写都是直接访问节点A,节点B只是将A的更新同...

MySQL低版本升级操作流程

(关注“数据库架构师”公众号,提升数据库技能,助力职业发展)0-升级背景MySQL5.5发布于2010年,至今已有十年历史,官方已经停止更新。2008年发布的MySQL5.1版本,在2018年...

MySQL数据库知识

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

Mysql 8.4数据库安装、新建用户和数据库、表单

1、下载MySQL数据库yuminstall-ywgetperlnet-toolslibtirpc#安装wget和perl、net-tools、libtirpcwgethtt...

mysql8.0新功能介绍

MySQL8.0新特性集锦一、默认字符集由latin1变为utf8mb4在8.0版本之前,默认字符集为latin1,utf8指向的是utf8mb3,8.0版本默认字符集为utf8mb4,utf8默...

全网最详细解决Windows下Mysql数据库安装后忘记初始root 密码方法

一、准备重置root的初始化密码Win+R键启动命令输入窗口;输入cmd打开命令执行窗口;##界面如下##输入命令:netstopmysqld#此操作会停止当前运行的...

互联网大厂面试:MySQL使用grant授权后必须flush privilege吗

从我上大学时,数据库概论老师就告诉我,MySQL使用grant对用户授权之后,一定记得要用flushprivilege命令刷新缓存,这样才能使赋权命令生效。毕业工作以后,在很多的技术文档上,仍然可以...

# mysql 8.0 版本无法使用 sqlyog 等图形界面 登录 的解决方法

30万以下的理想L6来了##mysql8.0版本无法使用sqlyog等图形界面登录的解决方法当我们在cmd下登录mysql时正常时,用sqlyog等图形界面连接数据库时却...

MySQL触发器介绍

前言:在学习MySQL的过程中,可能你了解过触发器的概念,不清楚各位是否有详细的去学习过触发器,最近看了几篇关于触发器的文档,分享下MySQL触发器相关知识。1.触发器简介触发器即trigg...

管理员常用的MySQL命令汇总(一)

以下是管理员常用的MySQL命令:以管理员身份连接到MySQL:mysql-uroot-p创建新的MySQL用户:CREATEUSER'username'@'...

Linux(CentOS) 在线安装MySQL8.0和其他版本,修改root密码

一:安装MySQL数据库1),下载并安装MySQL官方的YumRepositorymysql官方仓库地址:https://dev.mysql.com/downloads/repo/yum/选择自...

解决 MySQL 8.0 一直拒绝 root 登录问题

Accessdeniedforuser'root'@'localhost'(usingpassword:YES)这个错误在网上搜一下,能看到非常多的此类...

大模型MCP之MYSQL安装

前言学习大模型的时候需要一个mysql,原因还是在公司使用电脑的时候不允许按照Docker-Desktop,我的宿主机其实是MAC,我习惯上还是在centsos上面安装,就发现这件过去很简单的事情居然...

MySQL ERROR 1396

ERROR1396(HY000):OperationCREATEUSERfailedfor'usera'@'%'问题描述mysql>create...