运维开发网

Linux 基础知识(三)

运维开发网 https://www.qedev.com 2020-06-13 15:07 出处:网络
1、定义一个对所有用户都生效的命令别名,例如:1ftps=‘1ftp 172.168.0.1/pub‘
1、定义一个对所有用户都生效的命令别名,例如:1ftps=‘1ftp 172.168.0.1/pub‘

alias(设置指令的别名)命令详解?

? ??语  法:alias[别名]=[指令名称]? 如: alias bb = ‘bbbbb -f‘

?说明:用户可利用alias,自定指令的别名。若仅输入alias,则可列出目前所有的别名设置。 alias的效力仅及于该次登入的操作。若要每次登入是即自动设好别名,可在/etc/profile或自己的~/.bashrc中设定指令的别名。

还有,如果你想给每一位用户都生效的别名,请把alias bbb =‘bbbb -f‘ 一行加在/etc/bashrc最后面,bashrc是环境变量的配置文件 /etc/bashrc和~/.bashrc 区别就在于一个是设置给全系统一个是设置给单用户使用?

参  数:若不加任何参数,则列出目前所有的别名设置。

[[email protected] ~]# echo alias "lfpts=‘lftp 172.168.0.1/pub‘" >>/etc/bashrc

[[email protected] ~]# source /etc/bashrc

[[email protected] ~]# alias

alias cp=‘cp -i‘

alias l.=‘ls -d . --color=auto‘*

alias lfpts=‘lftp 172.168.0.1/pub‘

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‘


2、显示/etc/passwd文件中不以/bin/bash结尾的行

[[email protected] ~]# grep -v "/bin/bash" /etc/passwd


3、找出/etc/passwd文件中,包含二位数字或者三位数的行。

[[email protected] ~]# grep "\<[0-9]{2,3}\>" /etc/passwd

or

[[email protected] ~]# grep "\<[0-9]{2,3}\>" /etc/passwd


4、显示/proc/meminfo文件中以大写或小写s开头的行;用三种方式实现。

[[email protected] ~]# grep -i "^s" /proc/meminfo

[[email protected] ~]# grep "^[sS]" /proc/meminfo

[[email protected] ~]# grep -E "^(s|S)" /proc/meminfo

[[email protected] ~]# grep -E "^[sS]" /proc/meminfo


5、使用echo输出一个绝对路径,使用egrep取出路径名,类型执行dirname/etc/passwd的结果。

[[email protected] ~]# echo /etc/passwd | egrep -o "^/.*/"


6、找出ifconfig中的ip地址。要求结果只显示IP地址。

[[email protected] ~]# ifconfig ens33 | grep "inet " | tr -s ‘ ‘ ‘:‘ | cut -d: -f3


7、vin定制自动缩进四个字符。

vim /etc/vimrc

set ts=4

8、编写脚本,实现自动添加三个用户,并计算这三个用户的uid之和。

#!/bin/bash

#author benny

#miaoshu 添加三个用户,并计算这三个用户的uid之和

useradd test1

useradd test2

useradd test3

test1uid=cat /etc/passwd | egrep ^test1 | cut -d‘:‘ -f3

test2uid=cat /etc/passwd | egrep ^test2 | cut -d‘:‘ -f3

test3uid=cat /etc/passwd | egrep ^test3 | cut -d‘:‘ -f3

totaluid=$(($test1uid+$test2uid+$test3uid))

echo "totaluid=$totaluid"


9、find用法以及常用用法的实例演示。

参数说明 :

find 根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部份为 path,之后的是 expression。如果 path 是空字串则使用目前路径,如果 expression 是空字串则使用 -print 为预设 expression。

expression 中可使用的选项有二三十个之多,在此只介绍最常用的部份。

-mount, -xdev : 只检查和指定目录在同一个文件系统下的文件,避免列出其它文件系统中的文件

-amin n : 在过去 n 分钟内被读取过

-anewer file : 比文件 file 更晚被读取过的文件

-atime n : 在过去n天内被读取过的文件

-cmin n : 在过去 n 分钟内被修改过

-cnewer file :比文件 file 更新的文件

-ctime n : 在过去n天内被修改过的文件

-empty : 空的文件-gid n or -group name : gid 是 n 或是 group 名称是 name

-ipath p, -path p : 路径名称符合 p 的文件,ipath 会忽略大小写

-name name, -iname name : 文件名称符合 name 的文件。iname 会忽略大小写

-size n : 文件大小 是 n 单位,b 代表 512 位元组的区块,c 表示字元数,k 表示 kilo bytes,w 是二个位元组。-type c : 文件类型是 c 的文件。

d: 目录

c: 字型装置文件

b: 区块装置文件

p: 具名贮列

f: 一般文件

l: 符号连结

s: socket

-pid n : process id 是 n 的文件

你可以使用 ( ) 将运算式分隔,并使用下列运算。

exp1 -and exp2

! expr

-not expr

exp1 -or exp2

exp1, exp2

将目前目录及其子目录下所有延伸档名是 c 的文件列出来。

? [[email protected] /]# find . -name "*.c"

将目前目录其其下子目录中所有一般文件列出

[[email protected] /]# find . -type f

将目前目录及其子目录下所有最近 20 天内更新过的文件列出

[[email protected] ~]# find . -ctime -20

查找/var/log目录中更改时间在7日以前的普通文件,并在删除之前询问它们:

[[email protected] ~]# ind /var/log -type f -mtime +7 -ok rm {} \;

查找前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件:

[[email protected] ~]# find . -type f -perm 644 -exec ls -l {} \;

为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径:

[[email protected] ~]# find / -type f -size 0 -exec ls -l {} \;

0

精彩评论

暂无评论...
验证码 换一张
取 消