linux脚本初体验

时间:2023-11-25 17:49:14

前言

第一次写linux脚本,有点紧张。

1. 写一个寻找特定用户的脚本文件?

#! /bin/sh

who | grep $1

其中脚本第一行用来告诉kernel去使用/bin/sh来解释这个脚本;

而$1则是执行脚本命令时带入的命令行参数,例如sh-# find_user me

用来查看当前的系统中是否有me这个用户登入。

2. 当脚本写好后,是无法直接运行的,为什么?

直接运行,就会出现如下的错误信息:

sh-# ./find_user me
sh: ./find_user: Permission denied

从错误信息来看,应该是find_user这个文件不具备可执行的权限。

使用ls -l进行检查,果不其然这个文件的权限为644,不具有可执行权限。

sh-# ls -l find_user
-rw-r--r-- 1 root root 9 Jan  1 00:15 find_user

3. 那我们要怎样让其可执行呢?

chmod可以用来改变文件的权限:

sh-# chmod 755 find_user

sh-# ls -l find_user

-rwxr-xr-x 1 root root 9 Jan  1 00:15 find_user

你可以发现文件权限变成755了,./find_user执行这个脚本果然没问题。

4. 为什么文件的默认权限是644?

这跟umask的设定有关,

sh-# umask
0022
umask的值是可更改的。

关于umask相关的部分,在后续可能会做更深入的学习和分析。

5. 脚本写好了要怎么管理?

假设你写了好多脚本工具,那你该如何管理它们呢?

如果每次执行一个脚本命令都需要靠绝对路径来执行,那会不会很麻烦呢?

所以建议用户将自己编写的工具都放在同一个地方,比如/usr/bin或者用户喜欢的某个目录下,

然后再使用 export PATH=$PATH:/usr/bin将/usr/bin加到PATH中。

试一下你可以在任何路径下都可以执行find_user了,是不是很酷?