Linux 基础知识
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux 基础知识相关的知识,希望对你有一定的参考价值。
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 \;
以上是关于Linux 基础知识的主要内容,如果未能解决你的问题,请参考以下文章