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

Bash、Source、“.”和“./”执行的区别

nanshan 2024-11-10 10:13 23 浏览 0 评论

每日分享最新,最流行的软件开发知识与最新行业趋势,希望大家能够一键三连,多多支持,跪求关注,点赞,留言。

本文探讨了在 Linux 上运行 shell 命令的各种方法。

在Linux 上工作时,您可能会遇到一些未按您预期的方式执行的文件——例如,您可能在当前目录中有一个文件,但是当您输入它的名称时它没有运行。你得到file_name.sh command not found了,但实际上,文件在那里。该文件不起作用,即使具有执行权限,因为当你在 shell 上写一些东西并运行它时,你的$PATH变量会被检查。如果目录内有任何匹配的命令$PATH,例如/usr/bin,它将执行。除非有匹配的命令,否则您将收到错误消息。

因此,您需要解决文件的路径。让我们创建一个简单的Linux shell 脚本并对该脚本具有执行权限。以下示例是用Bash Shell编写的。

mkdir test && cd test
echo 'echo "hello world PID:$ ParentPID:$PPID"' > test.sh
chmod 755 test.sh

创建脚本后,让我们按顺序执行它们。

壳1测试.sh2#test.sh:找不到命令34. 测试.sh5#hello world PID:19245 ParentPID:1924367. ./test.sh # 同上。它只是明确指定当前目录。8#hello world PID:19245 ParentPID:19243910./test.sh #hello world PID:23044 ParentPID:1924511bash test.sh #hello world PID:23045 ParentPID:19245

$PATH除非当前目录在环境变量中,否则直接给出文件名不起作用。当您使用POSIX标准 shell(如 ksh)时,第二个命令也会失败,因为在运行命令 shell 时检查/命令内部是否存在。如果有,那么它会查找您处理的当前工作目录或绝对路径。与此相反,然后它查看里面的命令$PATH。我当前正在处理的目录不在 PATH 内,因此会出现错误。

test.sh
#test.sh: command not found

. test.sh
#hello world PID:19245 ParentPID:19243

. ./test.sh # this is same with above. it is just specifies current directory explicitly.
#hello world PID:19245 ParentPID:19243

./test.sh #hello world PID:23044 ParentPID:19245
bash test.sh #hello world PID:23045 ParentPID:19245

假设您正在使用Bash。通过执行两者. file.sh或. ./file.sh结果来运行文件将是相同的,但不是./test.sh. source和bash命令呢?

如果您使用任何 shell 命令,例如 Bash 或 ksh,您将生成一个新的 shell 来运行该命令。因此,您设置的每个变量在新 shell 中都不可用。另一方面,source使用当前的 shell 并且不产生新的 shell 进程。因此,您在文件中所做的任何更改都会影响您当前的 shell。上面,正如您从输出中看到的那样,当您执行./或bash因为它们正在产生新进程时,PID 会发生变化。如上所示,命令的父进程 ID (PPID)bash test.sh等于命令的进程 ID (PID) . ./test.sh。

让我们设置一个变量并在test.sh脚本中打印它。

bash -posix
test.sh

#bash: test.sh: command not found
. test.sh

#bash: .: test.sh: file not found
. ./test.sh
#hello world PID:23493 ParentPID:19245

./test.sh
#hello world PID:23539 ParentPID:23493

bash test.sh
#hello world PID:23540 ParentPID:23493

exit

显然,该bash test.sh命令没有给出$STR变量输出,因为新的 shell 不知道。它没有设置在新外壳中。让我们在脚本中设置一个变量。

echo 'NEWSTR="WORLD"' >> test.sh
echo 'echo "NEWSTR is $NEWSTR"' >> test.sh

bash test.sh
#hello world PID:25318 ParentPID:19245
#STR is #NEWSTR is WORLD

echo $NEWSTR #this will give empty output
#

. test.sh
#hello world PID:19245 ParentPID:19243
#STR is HELLO #NEWSTR is WORLD

echo $NEWSTR
# WORLD

source test.sh
#hello world PID:19245 ParentPID:19243
# STR is # NEWSTR is WORLD

echo $NEWSTR
# WORLD

.并source在当前 shell 中运行,因此我们可以看到新变量。这就是运行该bash .bashrc命令不会更新您的 PATH 变量的原因。您应该使用source命令运行或使用.. 因此,您必须使用 source 命令来更改 PATH 变量。

最后,让我们尝试使用此信息来更改和设置 PATH 变量。

mkdir directory && cd directory
echo 'echo "FILE"' > file.sh && chmod 755 file.sh
echo 'echo "COMMAND"' > echocommand && chmod 755 echocommand
pwd
# /home/ofk/test/directory
cd
# change PATH variable inside your .profile (or where ever you set PATH) file and add above path
# PATH="$PATH:/home/ofk/test/directory"
bash .profile
# try to run echocommand or file.sh

echocommand
# echocommand: command not found
file.sh
# file.sh: command not found

source .profile
echocommand
# COMMAND
file.sh
# FILE

结论

./或shell命令(bash、ksh)启动新的 shell 并运行命令。

. file_name或source命令在当前 shell 上运行。

相关推荐

如何为MySQL服务器和客户机启用SSL?

用户想要与MySQL服务器建立一条安全连接时,常常依赖VPN隧道或SSH隧道。不过,获得MySQL连接的另一个办法是,启用MySQL服务器上的SSL封装器(SSLwrapper)。这每一种方法各有其...

Mysql5.7 出现大量 unauthenticated user

线上环境mysql5.7突然出现大量unauthenticateduser,进mysql,showprocesslist;解决办法有:在/etc/hosts中添加客户端ip,如192.16...

MySQL 在 Windows 系统下的安装(mysql安装教程windows)

更多技术文章MySQL在Windows系统下的安装1.下载mysql和Framework链接链接:百度网盘请输入提取码提取码:6w3p双击mysql-installer-communit...

MySql5.7.21.zip绿色版安装(mysql数据库绿色版安装)

1、去网上下载满足系统要求的版本(mysql-5.7.21-winx64.zip)2、直接解压3、mysql的初始化(1)以管理员身份运行cmd,在mysql中的bin目录下shift+右键-在...

MySQL(8.0)中文全文检索 (亲测有效)

在一堆文字中找到含有关键字的应用。当然也可以用以下语句实现:SELECT*FROM<表名>WHERE<字段名>like‘%ABC%’但是它的效率太低,是全盘扫描。...

新手教程,Linux系统下MySQL的安装

看了两三个教程。终于在哔哩哔哩找到一个简单高效的教程,成功安装,up主名叫bili逍遥bili,感兴趣可以去看看。下面这个是我总结的安装方法环境:CentOS764位1.下载安装包,个人觉得在...

麒麟服务器操作系统安装 MySQL 8 实战指南

原文连接:「链接」Hello,大家好啊,今天给大家带来一篇麒麟服务器操作系统上安装MySQL8的文章,欢迎大家分享点赞,点个在看和关注吧!MySQL作为主流开源数据库之一,被广泛应用于各种业务...

用Python玩转MySQL的全攻略,从环境搭建到项目实战全解析

这是一篇关于“MySQL数据库入门实战-Python版”的教程,结合了案例实战分析,帮助初学者快速掌握如何使用Python操作MySQL数据库。一、环境准备1.安装Python访问Pytho...

安装MySQL(中标麒麟 安装mysql)

安装MySQL注意:一定要用root用户操作如下步骤;先卸载MySQL再安装1.安装包准备(1)查看MySQL是否安装rpm-qa|grepmysql(2)如果安装了MySQL,就先卸载rpm-...

Mysql最全笔记,快速入门,干货满满,爆肝

目录一、MySQL的重要性二、MySQL介绍三、软件的服务架构四、MySQL的安装五、SQL语句六、数据库相关(DDL)七、表相关八、DML相关(表中数据)九、DQL(重点)十、数据完...

MAC电脑安装MySQL操作步骤(mac安装mysqldb)

1、在官网下载MySQL:https://dev.mysql.com/downloads/mysql/根据自己的macOS版本,选择适配的MySQL版本根据自己需求选择相应的安装包,我这里选择macO...

mysql主从(mysql主从切换)

1、本章面试题什么是mysql主从,主从有什么好处什么是读写分离,有什么好处,使用mycat如何实现2、知识点2.1、课程回顾dubboORM->MVC->RPC->SOApro...

【linux学习】以MySQL为例,带你了解数据库

做运维的小伙伴在日常工作中难免需要接触到数据库,不管是MySQL,mariadb,达梦还是瀚高等其实命令都差不多,下面我就以MySQL为例带大家一起来了解下数据库。有兴趣的小伙伴不妨评论区一起交流下...

玩玩WordPress - 环境简介(0)(玩玩网络科技有限公司)

简介提到开源博客系统,一般都会直接想到WordPress!WordPress是使用PHP开发的,数据库使用的是MySQL,一般会在Linux上运行,Nginx作为前端。这时候就需要有一套LNMP(Li...

服务器常用端口都有哪些?(服务器端使用的端口号范围)

下面为大家介绍一下,服务器常用的一些默认端口,以及他们的作用:  21:FTP服务所开放的端口,用于上传、下载文件。  22:SSH端口,用于通过命令行模式远程连接Linux服务器或vps。  23:...

取消回复欢迎 发表评论: