目录
用户和群组管理
#创建一个新用户
useradd web
#删除一个用户 ( '-r' 排除主目录)
userdel -r user1
#修改用户属性
usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1
#修改口令
passwd
#修改一个用户的口令 (只允许root执行)
passwd user1
#创建一个新用户组
groupadd group_name
#删除一个用户组
groupdel group_name
#重命名一个用户组
groupmod -n new_group_name old_group_name
#创建一个属于 "admin" 用户组的用户
useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1
#设置用户口令的失效期限
chage -E 2005-12-31 user1
#检查 '/etc/passwd'的文件格式和语法修正以及存在的用户
pwck
#检查 '/etc/passwd'的文件格式和语法修正以及存在的群组
grpck
#登陆进一个新的群组以改变新创建文件的预设群组
newgrp group_name
为用户或群组设置root权限
#设置文件读写权限
chmod u+w /etc/sudoers
#修改文件
vi /etc/sudoers
编辑内容在 root ALL=(ALL) ALL 下面一行增加,
web ALL=(ALL) ALL
保存文件即可。
以下为其它方式配置参考:增加NOPASSWD是为了省去使用sudo功能时需要你输入当前账号的密码
web ALL=(ALL) NOPASSWD: ALL
#为某一用户组增加sudo功能
在 %wheel ALL=(ALL) ALL 下面一行增加
%web ALL=(ALL) ALL
#或
%web ALL=(ALL) NOPASSWD: ALL
授权用户指定目录权限
#显示目录及文件
ls
#显示目录及文件权限
ll
#将终端划分成5栏显示
ls /tmp | pr -T5 -W$COLUMNS
#设置目录的所有人(u)、群组(g)以及其他人(o)以读(r )、写(w)和执行(x)的权限
chmod ugo+rwx [目录名/文件名]
#删除群组(g)与其他人(o)对目录的读写执行权限
chmod go-rwx [目录名/文件名]
#改变一个文件的所有人属性
chown [用户名] [目录名/文件名]
# 改变一个文件的所有人和群组属性
chown [用户名]:[组名] [文件名]
#改变一个目录的所有人属性并同时改变改目录下所有文件的属性
chown -R [用户名] [目录名]
#改变文件的群组
chgrp [组名] [文件名]
#罗列一个系统中所有使用了SUID控制的文件
find / -perm -u+s
#设置一个二进制文件的 SUID 位 - 运行该文件的用户也被赋予和所有者同样的权限
chmod u+s /bin/file1
#禁用一个二进制文件的 SUID位
chmod u-s /bin/file1
#设置一个目录的SGID 位 - 类似SUID ,不过这是针对目录的
chmod g+s /home/public
#禁用一个目录的 SGID 位
chmod g-s /home/public
#设置一个文件的 STIKY 位 - 只允许合法所有人删除文件
chmod o+t /home/public
#禁用一个目录的 STIKY 位
chmod o-t /home/public
# 将目录/home/fileserver 及其下面的所有文件、子目录的文件 主 改成 web
chown -R web /home/fileserver
#给目录fileserver设置权限
chmod 777 /home/fileserver
文件和目录常用操作命令
#进入 '/ home' 目录'
cd /home
#返回上一级目录
cd ..
#返回上两级目录
cd ../..
#进入个人的主目录
cd
#进入个人的主目录
cd ~user1
#返回上次所在的目录
cd -
#显示工作路径
pwd
#查看目录中的文件
ls
#查看目录中的文件
ls -F
#显示文件和目录的详细资料
ls -l
ll
#显示隐藏文件
ls -a
#显示包含数字的文件名和目录名
ls *[0-9]*
#显示文件和目录由根目录开始的树形结构(1)
tree
#显示文件和目录由根目录开始的树形结构(2)
lstree
#创建一个叫做 'dir1' 的目录'
mkdir dir1
#同时创建两个目录
mkdir dir1 dir2
#创建一个目录树
mkdir -p /tmp/dir1/dir2
#删除一个叫做 'file1' 的文件'
rm -f file1
#删除一个叫做 'dir1' 的目录'
rmdir dir1
#删除一个叫做 'dir1' 的目录并同时删除其内容
rm -rf dir1
#同时删除两个目录及它们的内容
rm -rf dir1 dir2
#重命名/移动 一个目录
mv dir1 new_dir
#复制一个文件
cp file1 file2
#递归复制目录及其子目录内的所有内容到当前工作目录
cp -R dir/* .
#复制一个目录到当前工作目录
cp -a /tmp/dir1 .
# 复制一个目录
cp -a dir1 dir2
# 创建一个指向文件或目录的软链接
ln -s file1 lnk1
#创建一个指向文件或目录的物理链接
ln file1 lnk1
#修改一个文件或目录的时间戳 - (YYMMDDhhmm)
touch -t 0712250000 file1
文件的特殊属性使用
"+" 设置权限,使用 "-" 用于取消
#文件的特殊属性 - 使用 "+" 设置权限,使用 "-" 用于取消
#只允许以追加方式读写文件
chattr +a file1
#允许这个文件能被内核自动压缩/解压
chattr +c file1
#在进行文件系统备份时,dump程序将忽略这个文件
chattr +d file1
#设置成不可变的文件,不能被删除、修改、重命名或者链接
chattr +i file1
#允许一个文件被安全地删除
chattr +s file1
#一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘
chattr +S file1
#若文件被删除,系统会允许你在以后恢复这个被删除的文件
chattr +u file1
#显示特殊的属性
lsattr
文件搜索
#从 '/' 开始进入根文件系统搜索文件和目录
find / -name file1
#搜索属于用户 'user1' 的文件和目录
find / -user user1
#在目录 '/ home/user1' 中搜索带有'.bin' 结尾的文件
find /home/user1 -name \*.bin
#搜索在过去100天内未被使用过的执行文件
find /usr/bin -type f -atime +100
#搜索在10天内被创建或者修改过的文件
find /usr/bin -type f -mtime -10
#搜索以 '.rpm' 结尾的文件并定义其权限
find / -name \*.rpm -exec chmod 755 '{}' \;
#搜索以 '.rpm' 结尾的文件,忽略光驱、捷盘等可移动设备
find / -xdev -name \*.rpm
#寻找以 '.ps' 结尾的文件 - 先运行 'updatedb' 命令
locate \*.ps
#显示一个二进制文件、源码或man的位置
whereis halt
#显示一个二进制文件或可执行文件的完整路径
which halt
打包和压缩文件
打包和压缩文件
#解压一个叫做 'file1.bz2'的文件
bunzip2 file1.bz2
#压缩一个叫做 'file1' 的文件
bzip2 file1
#解压一个叫做 'file1.gz'的文件
gunzip file1.gz
#压缩一个叫做 'file1'的文件
gzip file1
#最大程度压缩
gzip -9 file1
#创建一个叫做 'file1.rar' 的包
rar a file1.rar test_file
#同时压缩 'file1', 'file2' 以及目录 'dir1'
rar a file1.rar file1 file2 dir1
#解压rar包
rar x file1.rar
#解压rar包
unrar x file1.rar
#创建一个非压缩的 tarball
tar -cvf archive.tar file1
#创建一个包含了 'file1', 'file2' 以及 'dir1'的档案文件
tar -cvf archive.tar file1 file2 dir1
#显示一个包中的内容
tar -tf archive.tar
#释放一个包
tar -xvf archive.tar
#将压缩包释放到 /tmp目录下
tar -xvf archive.tar -C /tmp
#创建一个bzip2格式的压缩包
tar -cvfj archive.tar.bz2 dir1
#解压一个bzip2格式的压缩包
tar -jxvf archive.tar.bz2
#创建一个gzip格式的压缩包
tar -cvfz archive.tar.gz dir1
#解压一个gzip格式的压缩包
tar -zxvf archive.tar.gz
#创建一个zip格式的压缩包
zip file1.zip file1
#将几个文件和目录同时压缩成一个zip格式的压缩包
zip -r file1.zip file1 file2 dir1
#解压一个zip格式压缩包
unzip file1.zip