5.5 Linux的权限命令
    操作系统中每个文件都拥有特定的权限、所属用户和所属组。权限是操作系统用来限制资源访问的机制,在Linux中权限一般分为读(readable)、写(writable)和执行(excutable),分为三组。分别对应文件的属主(owner),属组(group)和其他用户(other),通过这样的机制来限制哪些用户、哪些组可以对特定的文件进行什么样的操作。通过 ls -l 命令我们可以 查看某个目录下的文件或目录的权限
    示例:在随意某个目录下ls -l
    image.png
    第一列的内容的信息解释如下:
    image.png
    下面将详细讲解文件的类型、Linux中权限以及文件有所有者、所在组、其它组具体是什么?
    文件的类型:
    · d: 代表目录
    · -: 代表文件
    · l: 代表链接(可以认为是window中的快捷方式)
    Linux中权限分为以下几种:
    · r:代表权限是可读,r也可以用数字4表示
    · w:代表权限是可写,w也可以用数字2表示
    · x:代表权限是可执行,x也可以用数字1表示
    文件和目录权限的区别:
    对文件和目录而言,读写执行表示不同的意义。
    对于文件:

    权限名称 可执行操作
    r 可以使用cat查看文件的内容
    w 可以修改文件的内容
    x 可以将其运行为二进制文件

    对于目录:

    权限名称 可执行操作
    r 可以查看目录下列表
    w 可以创建和删除目录下文件
    x 可以使用cd进入目录

    在linux中的每个用户必须属于一个组,不能独立于组外。在linux中每个文件有所有者、所在组、其它组的概念。
    · 所有者
    一般为文件的创建者,谁创建了该文件,就天然的成为该文件的所有者,用ls ‐l命令可以看到文件的所有者 也可以使用chown 用户名 文件名来修改文件的所有者 。

    1. 1.chown修改文件夹所有者
    2. chown -R root zym/ 把文件夹zym改为属于root,-R代表所有,包含子文件夹
    3. chown -R sjc-ftp:sftp sjc-ftp 把文件夹sjc-ftp以及sjc-ftp下的所有文件夹全改为sjc-ftp所有者和sftp所属组
    4. chown root:sftp sjc-ftp 把文件夹sjc-ftp改为root所有者和sftp所属组
    5. 2.chgrp修改文件夹所属组
    6. chgrp root /zym/frame/ 把文件夹修改为属于某一组

    · 文件所在组
    当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组 用ls ‐l命令可以看到文件的所有组 也可以使用chgrp 组名 文件名来修改文件所在的组。
    · 其它组
    除开文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组
    我们再来看看如何修改文件/目录的权限。
    修改文件/目录的权限的命令:chmod
    示例:修改/test下的aaa.txt的权限为属主有全部权限,属主所在的组有读写权限, 其他用户只有读的权限
    chmod u=rwx,g=rw,o=r aaa.txt
    image.png
    上述示例还可以使用数字表示:
    chmod 764 aaa.txt
    补充一个比较常用的东西:
    假如我们装了一个zookeeper,我们每次开机到要求其自动启动该怎么办?
    1. 新建一个脚本zookeeper
    2. 为新建的脚本zookeeper添加可执行权限,命令是:chmod +x zookeeper
    3. 把zookeeper这个脚本添加到开机启动项里面,命令是:chkconfig —add zookeeper
    4. 如果想看看是否添加成功,命令是:chkconfig —list

    5.6 Linux 用户管理
    Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
    用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
    Linux用户管理相关命令:
    · useradd 选项 用户名:添加用户账号
    · userdel 选项 用户名:删除用户帐号
    · usermod 选项 用户名:修改帐号
    · passwd 用户名:更改或创建用户的密码
    · passwd -S 用户名 :显示用户账号密码信息
    · passwd -d 用户名: 清除用户密码
    · su - 用户名:切换登录用户
    useradd命令用于Linux中创建的新的系统用户。useradd可用来建立用户帐号。帐号建好之后,再用passwd设定帐号的密码.而可用userdel删除帐号。使用useradd指令所建立的帐号,实际上是保存在/etc/passwd文本文件中。该文件内容的解释:用户名:密码:用户id:组id:用户说明:用户的主目录:用户使用的shell环境(默认为bash)
    passwd命令用于设置用户的认证信息,包括用户密码、密码过期时间等。系统管理者则能用它管理系统用户的密码。只有管理者可以指定用户名称,一般用户只能变更自己的密码。
    5.7 Linux系统用户组的管理
    每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
    用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。
    Linux系统用户组的管理相关命令:
    · groupadd 选项 用户组 :增加一个新的用户组
    · groupdel 用户组:要删除一个已有的用户组
    · groupmod 选项 用户组 : 修改用户组的属性
    5.8 其他常用命令
    · pwd: 显示当前所在位置
    · grep 要搜索的字符串 要搜索的文件 —color: 搜索命令,—color代表高亮显示
    · ps -ef/ps aux: 这两个命令都是查看当前系统正在运行进程,两者的区别是展示格式不同。如果想要查看特定的进程可以使用这样的格式:ps aux|grep redis (查看包括redis字符串的进程)
    注意:如果直接用ps((Process Status))命令,会显示所有进程的状态,通常结合grep命令查看某进程的状态。
    · kill -9 进程的pid: 杀死进程(-9 表示强制终止。)
    先用ps查找进程,然后用kill杀掉
    · 网络通信命令:
    o 查看当前系统的网卡信息:ifconfig
    o 查看与某台机器的连接情况:ping
    o 查看当前系统的端口:netstat
    § an 所有的连接和端口
    § tuln 查看正在监听TCP(t)和UDP(u)的端口 ,例如:netstat -tuln | grep LISTEN
    § rn 查看网关 route -n
    · ln: 创建链接文件
    o 创建软链接文件:ln -s [源文件] [目标文件] (硬链接不需-s选项)
    § 软链接特点:权限是所有人都可以访问,并且软连接文件指向源文件。
    § 软链接就像windows系统中的快捷方式一样,特点也都类似。
    § 硬链接:类似copy,硬链接大小和源文件一样,并且是同步更新的。
    · shutdown: shutdown -h now: 指定现在立即关机;shutdown +5 “System will shutdown after 5 minutes”:指定5分钟后关机,同时送出警告信息给登入用户。
    · reboot: reboot: 重开机。reboot -w: 做个重开机的模拟(只有纪录并不会真的重开机)。