Linux
一、简介
Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
每个用户账号都拥有一个唯一的用户名和各自的口令。
用户在登录时键入正确的用户名和口令后,就能够进入系统和自己的主目录。
实现用户账号的管理,要完成的工作主要有如下几个方面:
● 用户账号的添加、删除与修改。
● 用户口令的管理。
● 用户组的管理。
二、用户账号的管理
用户账号的管理工作主要涉及到用户账号的添加、修改和删除。
添加用户账号就是在系统中创建一个新账号,然后为新账号分配用户号、用户组、主目录和登录Shell等资源。
1)添加账号 - useradd
useradd 选项 用户名
选项参数:
- c:comment 指定一段注释性描述。
- d:目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。
- g:用户组 指定用户所属的用户组。
- G:用户组,用户组 指定用户所属的附加组。
- m:使用者目录如不存在则自动建立。
- s:Shell文件 指定用户的登录Shell。
- u:用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。
示例:
# 此命令创建了一个用户newuser,其中 -m 选项用来为登录名newuser产生一个主目录 /home/newuser [root@linuxtest home]# useradd -m newuser
增加用户账号就是在/etc/passwd文件中为新用户增加一条记录,同时更新其他系统文件如/etc/shadow, /etc/group等。
2)切换用户 - su
① 切换用户的命令为:su username
② 从普通用户切换到 root 用户,还可以使用命令:sudo su
③ 在终端输入 exit 或 logout 或使用快捷方式 ctrl+d,可以退回到原来用户,其实 ctrl+d 也是执行的 exit 命令
④ 在切换用户时,如果想在切换用户之后使用新用户的工作环境,可以在 su 和 username 之间加-,例如:【su - root】
$ 表示普通用户
# 表示超级用户,也就是root用户
3)删除帐号 - userdel
如果一个用户的账号不再使用,可以从系统中删除。
删除用户账号就是要将/etc/passwd等系统文件中的该用户记录删除,必要时还删除用户的主目录。
userdel 选项 用户名
选项:
- r:它的作用是把用户的主目录一起删除。
示例:
# 此命令删除用户username在系统文件中(主要是/etc/passwd, /etc/shadow, /etc/group等)的记录,同时删除用户的主目录。 [root@linuxtest home]# userdel -r username
4)修改账户 - usermod
修改用户账号就是根据实际情况更改用户的有关属性,如用户号、主目录、用户组、登录Shell等。
usermod 选项 用户名
选项:[ - c, - d, - m, - g, - G, - s, - u,- o ] 等,这些选项的意义与useradd命令中的选项一样,可以为用户指定新的资源值。
示例:
# 此命令将用户username的登录Shell修改为ksh,主目录改为/home/z,用户组改为developer。 [root@linuxtest ~]# usermod -s /bin/ksh -d /home/z –g developer username
5)用户口令的管理 - passwd
用户管理的一项重要内容是用户口令的管理。用户账号刚创建时没有口令,但是被系统锁定,无法使用,必须为其指定口令后才可以使用,即使是指定空口令。
指定和修改用户口令的Shell命令是passwd。超级用户可以为自己和其他用户指定口令,普通用户只能用它修改自己的口令。
格式:
passwd 选项 用户名
选项:
- l:锁定口令,即禁用账号。
- u:口令解锁。
- d:使账号无口令。
- f:强迫用户下次登录时修改口令。
如果默认用户名,则修改当前用户的口令。
示例:
普通用户修改自己的口令时,passwd命令会先询问原口令,验证后再要求用户输入两遍新口令,如果两次输入的口令一致,则将这个口令指定给用户;而超级用户为用户指定口令时,就不需要知道原口令。
# 如果当前用户是cyan,则下面的命令修改登录用户cyan的口令 [cyan@linuxtest ~]$ passwd Old password:****** New password:******* Re-enter new password:******* # 如果是超级用户,可以用下列形式指定任何用户的口令 [root@linuxtest ~]# passwd cyan New password:******* Re-enter new password:*******
设置空口令:将用户 kuangshen的口令删除,这样用户 cyan下一次登录时,系统就不再允许该用户登录了
[root@linuxtest ~]# passwd -d cyan
锁定用户: -l(lock) 选项锁定某一用户,使其不能登录
[root@linuxtest ~]# passwd -l cyan
三、用户组管理
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。
1)创建用户组 - groupadd
groupadd 选项 用户组
选项:
- g:GID 指定新用户组的组标识号(GID)。
- o:一般与-g选项同时使用,表示新用户组的GID可以与系统已有用户组的GID相同。
示例:
# 在系统中增加了一个新组group1,新组的组标识号是在当前已有的最大组标识号的基础上加1。 [root@linuxtest ~]# groupadd group1 # 在系统中增加了一个新组group2,同时指定新组的组标识号是101 [root@linuxtest ~]# groupadd -g 101 group2
2)删除用户组 - groupdel
groupdel 用户组
示例:
# 此命令从系统中删除组group1。 [root@linuxtest ~]# groupdel group1
3)修改用户组的属性 - groupmod
groupmod 选项 用户组
选项有:
- g:GID 为用户组指定新的组标识号。
- o:与-g选项同时使用,用户组的新GID可以与系统已有用户组的GID相同。
- n:新用户组 将用户组的名字改为新名字
示例:
# 此命令将组group2的组标识号修改为102 [root@linuxtest ~]# groupmod -g 102 group2 # 将组group2的标识号改为10000,组名修改为group3 [root@linuxtest ~]# groupmod –g 10000 -n group3 group2
4)切换组 - newgrp
如果一个用户同时属于多个用户组,那么用户可以在用户组之间切换,以便具有其他用户组的权限。
用户可以在登录后,使用命令newgrp切换到其他用户组,这个命令的参数就是目的用户组。例如:
# 将当前用户切换到root用户组,前提条件是root用户组确实是该用户的主组或附加组 [cyan@linuxtest ~]$ newgrp root
四、磁盘管理
Linux磁盘管理好坏直接关系到整个系统的性能问题。
Linux磁盘管理常用命令为 df、du。
● df :列出文件系统的整体磁盘使用量
● du:检查磁盘空间使用量
1)df
df命令参数功能:检查文件系统的磁盘空间占用情况。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。
语法:
df [-ahikHTm] [目录或文件名]
参数:
- a :列出所有的文件系统,包括系统特有的 /proc 等文件系统;
- k :以 KBytes 的容量显示各文件系统;
- m :以 MBytes 的容量显示各文件系统;
h :以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
- H :以 M=1000K 取代 M=1024K 的进位方式;
- T :显示文件系统类型, 连同该 partition 的 filesystem 名称 (例如 ext3) 也列出;
- i :不用硬盘容量,而以 inode 的数量来显示
示例:
# 将系统内所有的文件系统列出来! # 在 Linux 底下如果 df 没有加任何选项 # 那么默认会将系统内所有的 (不含特殊内存内的文件系统与 swap) 都以 1 Kbytes 的容量来列出来! [root@linuxtest /]# df Filesystem 1K-blocks Used Available Use% Mounted on devtmpfs 889100 0 889100 0% /dev tmpfs 899460 704 898756 1% /dev/shm tmpfs 899460 496 898964 1% /run tmpfs 899460 0 899460 0% /sys/fs/cgroup /dev/vda1 41152812 6586736 32662368 17% / tmpfs 179896 0 179896 0% /run/user/0
# 将容量结果以易读的容量格式显示出来 [root@linuxtest /]# df -h Filesystem Size Used Avail Use% Mounted on devtmpfs 869M 0 869M 0% /dev tmpfs 879M 708K 878M 1% /dev/shm tmpfs 879M 496K 878M 1% /run tmpfs 879M 0 879M 0% /sys/fs/cgroup /dev/vda1 40G 6.3G 32G 17% / tmpfs 176M 0 176M 0% /run/user/0
# 将系统内的所有特殊文件格式及名称都列出来 [root@linuxtest /]# df -aT Filesystem Type 1K-blocks Used Available Use% Mounted on sysfs sysfs 0 0 0 - /sys proc proc 0 0 0 - /proc devtmpfs devtmpfs 889100 0 889100 0% /dev securityfs securityfs 0 0 0 - /sys/kernel/security tmpfs tmpfs 899460 708 898752 1% /dev/shm devpts devpts 0 0 0 - /dev/pts tmpfs tmpfs 899460 496 898964 1% /run tmpfs tmpfs 899460 0 899460 0% /sys/fs/cgroup cgroup cgroup 0 0 0 - /sys/fs/cgroup/systemd pstore pstore 0 0 0 - /sys/fs/pstore cgroup cgroup 0 0 0 - /sys/fs/cgroup/freezer cgroup cgroup 0 0 0 - /sys/fs/cgroup/cpuset cgroup cgroup 0 0 0 - /sys/fs/cgroup/hugetlb cgroup cgroup 0 0 0 - /sys/fs/cgroup/blkio cgroup cgroup 0 0 0 - /sys/fs/cgroup/net_cls,net_prio cgroup cgroup 0 0 0 - /sys/fs/cgroup/memory cgroup cgroup 0 0 0 - /sys/fs/cgroup/pids cgroup cgroup 0 0 0 - /sys/fs/cgroup/cpu,cpuacct cgroup cgroup 0 0 0 - /sys/fs/cgroup/devices cgroup cgroup 0 0 0 - /sys/fs/cgroup/perf_event configfs configfs 0 0 0 - /sys/kernel/config /dev/vda1 ext4 41152812 6586748 32662356 17% / systemd-1 - - - - - /proc/sys/fs/binfmt_misc mqueue mqueue 0 0 0 - /dev/mqueue debugfs debugfs 0 0 0 - /sys/kernel/debug hugetlbfs hugetlbfs 0 0 0 - /dev/hugepages tmpfs tmpfs 179896 0 179896 0% /run/user/0 binfmt_misc binfmt_misc 0 0 0 - /proc/sys/fs/binfmt_misc
# 将 /etc 底下的可用的磁盘容量以易读的容量格式显示 [root@linuxtest /]# df -h /etc Filesystem Size Used Avail Use% Mounted on /dev/vda1 40G 6.3G 32G 17% /
2)du
Linux du命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的,这里介绍Linux du命令。
语法:
du [-ahskm] 文件或目录名称
参数:
- a :列出所有的文件与目录容量,因为默认仅统计目录底下的文件量而已。
- h :以人们较易读的容量格式 (G/M) 显示;
- s :列出总量而已,而不列出每个各别的目录占用容量;
- S :不包括子目录下的总计,与 -s 有点差别。
- k :以 KBytes 列出容量显示;
- m :以 MBytes 列出容量显示;
示例:
# 只列出当前目录下的所有文件夹容量(包括隐藏文件夹): # 直接输入 du 没有加任何选项时,则 du 会分析当前所在目录的文件与目录所占用的硬盘空间。 [root@linuxtest home]# du 16./redis 8./www/.oracle_jre_usage # 包括隐藏文件的目录 24./www 48. # 这个目录(.)所占用的总量
# 将文件的容量也列出来 [root@linuxtest home]# du -a 4./redis/.bash_profile 4./redis/.bash_logout ....中间省略.... 4./cyantest.txt # 有文件的列表了 48.
# 检查根目录底下每个目录所占用的容量 [root@linuxtest home]# du -sm /* 0/bin 146/boot .....中间省略.... 0/proc .....中间省略.... 1/tmp 3026/usr # 系统初期最大就是他了啦! 513/var 2666/www
通配符 * 来代表每个目录。
与 df 不一样的是,du 这个命令其实会直接到文件系统内去搜寻所有的文件数据。
五、磁盘挂载与卸除
根文件系统之外的其他文件要想能够被访问,都必须通过“关联”至根文件系统上的某个目录来实现,此关联操作即为“挂载”,此目录即为“挂载点”,解除此关联关系的过程称之为“卸载”
Linux 的磁盘挂载使用mount命令,卸载使用umount命令。
1)磁盘挂载
mount [-t 文件系统] [-L Label名] [-o 额外选项] [-n] 装置文件名 挂载点
示例:
# 将 /dev/hdc6 挂载到 /mnt/hdc6 上面! [root@linuxtest ~]# mkdir /mnt/hdc6 [root@linuxtest ~]# mount /dev/hdc6 /mnt/hdc6 [root@linuxtest ~]# df Filesystem 1K-blocks Used Available Use% Mounted on /dev/hdc6 1976312 42072 1833836 3% /mnt/hdc6
2)磁盘卸载
umount [-fn] 装置文件名或挂载点
选项与参数:
- f :强制卸除!可用在类似网络文件系统 (NFS) 无法读取到的情况下;
- n :不升级 /etc/mtab 情况下卸除。
卸载 /dev/hdc6
[root@linuxtest ~]# umount /dev/hdc6