美文网首页
Linux第二天

Linux第二天

作者: 空留灯半盏 | 来源:发表于2018-08-05 10:53 被阅读0次

    Linux第二天

    用户和用户组管理

    在Linux中通过配置文件来存储用户和用户组信息
    存储用户信息的目录 : /etc/passwd  可通过 cat /etc/passwd 查看
    存储用户组信息的目录 : /etc/group   cat /etc/group 查看
    

    用户管理

    • 用户添加 : useradd [ 参数 ] 用户名 (参数 :-d 家目录 , -g 所属组 ,-c 备注 ,-s 登陆执行的文件)
    • 用户修改: usermod 参数 用户名 (参数: 同上四个参数,-l 更改用户名)
    • 用户删除: userdel -r 用户名 (注: -r 表示同时删除家目录)
      例:

      添加 a 用户 (无参数)

      useradd a
      

      添加 b 用户 (备注: 神墨迹)

      useradd -c 神墨迹 b
      

      添加 c 用户 (备注: 221 指定目录: /home/c3)

      useradd -c 221 -d /home/c3
      

      添加 d 用户 (禁止登陆)

      useradd -s /sbin/nologin d
      

      修改 b 用户 备注为小bb 用户名:bb

      usermod -c 小bb -l bb b
      

      修改 d 用户(允许登录)

      usermod -s /bin/bash d
      

      创建用户 e 和 f

      useradd e(f)
      

      删除用户 e 不带-r 查看/home目录

      userdel e
      

      删除用户 f 带-r 查看 /home目录

      userdel -r f
      
    用户密码管理

    语法 passwd [ 参数 ] 用户名

    参数 : 
    -s : 查看用户状态 (status 或 state)
    -l : 冻结,不能登录 (lock)
    -u : 解冻 (unlock)
    

    创建 h 用户

    useradd h
    

    设置用户 h 密码为123

    passwd h
    输入密码123
    

    冻结 h用户

    passwd -l h
    

    解冻 h 用户

    passwd -u h
    

    查看 h 用户状态

    passwd -s h
    

    用户组管理

    用户组添加
    groupadd [参数] 组名 (参数 -g 设置组编号)
    
    用户组修改
    groupmod 参数 组名 (参数 -g 更改组编号 , -n 更改用户组名)
    
    用户组删除
    groupdel 组名 (注:用户组下面有用户则不能删除)
    

    ​ 添加用户组php1

       groupadd php1
    

    ​ 添加用户组php2 并制定用户组编号666

       groupadd  -g 666 php2
    

    将php2组更名为php_update 并且用户组编号为667

       groupmod -g 667 -n php_update php2
    

    添加用户组 php3后再删除php3用户组

      groupadd php3
    
    groupdel php3
    

    添加php4用户(注:会自动创建同名用户组)后,删除php4用户组

      useradd php4
      groupdel php4 (报错) 用户组下有用户不能被删除
    
    小结:
    > 用户添加:useradd [参数] 用户名
    -d  homedir   设置用户家目录
    -g  group     设置用户所属用户组
    -c  comment   设置备注
    -s  shell     设置用户登录后执行的shell文件
    注:创建用户自动创建同名家目录和同名用户组
    
    > 用户修改:usermod 参数 用户名
    -d  homedir   更改用户家目录
    -g  group     更改用户所属用户组
    -c  comment   更改备注
    -s  shell     更改用户登录后执行的shell文件
    -l  loginname 更改用户名
    
    > 用户删除:userdel  -r 用户名  (注:-r 表示同时删除家目录)
    
    > 用户组添加:groupadd [参数] 组名    
    -g group_number 设置用户组编号
    
    > 用户组修改:groupmod 参数 组名  
    -g group_number 更改用户组编号
    -n name        更改用户组名
    
    > 用户组删除:groupdel 组名(注:用户组下有用户则不能删除)
    
    

    权限操作

    概念:
    从文件本身来说,权限分为: 读 r(read 4)、写 w(write 2) 、执行 x(exec 1)
    
    从用户角度来说,权限分为: 文件拥有者 、同组用户 、其他用户组
    
    查看文件权限 ls -l
    -  表示文件
    d  表示目录
    l  表示链接(可以理解为window的快捷方式)
    

    [图片上传失败...(image-378afd-1533437627436)]

    红色  文件拥有者权限
    蓝色  同组用户权限
    绿色  其他组用户权限
    紫色  文件/文件夹拥有者
    黄色  文件初始化所属组
    灰色  文件/文件夹大小
    黑色  文件/文件夹时间
    a.php 文件/文件夹名称
    
    更改文件拥有者和所属组

    语法:

    更改文件拥有者 (change own) :   chown -R 新拥有者 待更改的文件
    更改文件所属组 (change group) : chgrp -R 新所属组 待更改的文件
    注: 只有文件所属者或超级管理员才可设置
    

    例如:

    创建user1.php文件 
    
    touch user1.php
    

    ​ 查看user1.php文件权限

    进入文件所属目录 ls -l   如上图
    

    ​ 更改user1.php文件拥有者 为a

    chown -R a user1.php
    

    ​ 更改user1.php所属组为php1

    chgrp -R php1 user1.php
    
    更改文件权限语法

    语法 : 1

    chmod -R ABC<用数字表示> 待授权文件
    ABC含义:分别表示A-文件拥有者、B-同组用户、C-其他组用户
    数字含义:4-读、2-写、1-执行
    0 -  没有权限
    1 -  可执行
    2 -  可写
    3 -  可写可执行    (2 + 1)
    4 -  可读
    5 -  可读可执行    (4 + 1)
    6 -  可读可写      (4 + 2)
    7 -  可读可写可执行(4 + 2 + 1)
    
    

    语法 : 2

    chmod -R {<augo><+-=><wrx>...} 待授权的文件
    r: 可读  w:可写  x:可执行  --对文件
    r: 可查看  w: 可添加/修改/删除  x: 可访问  -- 对文件夹
    表示用户:分别表示a-所有用户(all)、u-文件拥有者(user)、g-同组用户(group)、o-其他组用户(other)
    权限范围:
    用户+权限,给用户追加指定权限
    用户-权限,移除用户指定权限
    用户=权限,修改用户权限
    
    

    例如:

    创建 a.php文件 权限是7-主人 ,5-同组,5-其他组

    #创建文件  
       touch /a.php
    #修改权限
        chmod -R 755 /a.php
    #修改a.php,对其他组用户添加w权限
        chmod -R o+w /a.php
    $修改a.php,对其他组用户删除w权限
        chmod -R o-w /a.php
    

    [图片上传失败...(image-98b5f-1533437627437)]

    Linux的运行模式

    种类: 一共7种运行方式 0-6表示 分别为:
    0:关机模式          (禁用)
    1:单用户模式     (可以理解为window安全模式,主要用于系统维护,默认root权限登录)
    2:命令行模式     (不含NFS服务,也就是共享目录和文件功能)
    3:命令行模式     (推荐)   
    4:保留,未使用
    5:桌面模式            不推荐(后期开发服务器不需要)
    6:重启模式           (禁用)
    
    更改运行模式

    临时 , 通过命令 : init +数字

    init +number(0-6)
    

    永久,修改/etc/inittab运行模式文件 修改默认数字即可

    id:number(0-6):initdefault:
    

    软连接和硬连接

    概念

    软连接 - 相当于win创建快捷方式 (方便使用 , 注:删除源文件,则无法使用)

    硬连接 - 相当于将原文件拷贝一份 (防止误删,注: 删除源文件,可继续使用)

    语法

    软连接 - [ ln -s 源文件 新文件 ]

    硬连接 - [ ln 源文件 新文件 ]

    软连接
    rm -rf /test 
    mkdir -p /test  #创建文件夹
    echo 123 > /test/a.php  #将123写入到test/a.php中
    ln -s /test/a.php /test/b.php #软链接
    
    echo 4 >> /test/b.php  #将4追加到test/b.php中
    cat /test/a.php #1234
    
    rm -rf /test/a.php 
    cat /test/b.php #报错,无法使用
    
    
    硬连接
    rm -rf /test
    mkdir -p /test #创建文件
    echo 123 > /test/a.php  #将123写入(覆盖) 到test/a.php
    ln /test/a.php /test/b.php #硬链接
    
    echo 4 >> /test/b.php #将4追加到test/b.php中
    cat /test/a.php #1234
    
    rm -rf /test/a.php 
    cat /test/b.php #1234
    

    Linux安装卸载软件

    Linux系统:rpm命令安装、源代码编译安装、yum安装

    rpm包命令

    安装: rpm -ivh 软件名 说明:i - 安装,v - 显示详细信息,h - 显示进度

    卸载: rpm -e 软件名 --nodeps 说明:--nodeps 不检测依赖性

    &   查看所有rpm安装软件: rpm  -qa                  (说明:q查询query 、a所有all)
    &   查看指定软件是否安装: rpm  -qa | grep 包名       (举例:rpm -qa | grep mysql)
    
    源代码包命令 (tar)

    说明: win系统下有zip和rar格式文件,linux系统下有tar.gz和tat.gz2格式文件

    步骤 : 1- 使用tar命令解压文件 , 2-通过make和make install命令安装

    语法:
    【 .tar.gz】解压命令:tar  -zxvf  待解压的包名
    【 .tar.gz】压缩命令:tar  -zcvf  包名  文件路径
    【.tar.bz2】解压命令:tar  -jxvf  待解压的包名
    【.tar.bz2】压缩命令:tar  -jcvf  包名  文件路径
    -z 代表【.tar.gz】   -j代表【.tar.bz2】
    -x 代表【解压】        -c代表【压缩】
    -v 显示操作详细信息
    -f 后面必须跟包名
    
    yum 命令

    安装 : yum -y install 软件名

    卸载 : yum -y remove 软件名

    OpenSSH软件

    SSH是为网络数据安全传输提供的安全协议

    OpenSSH 是基于SSH协议开发的软件

    安装:
       安装客户端:yum -y install openssh-clients
       安装服务端:yum -y install openssh-server
    注: 系统默认已安装改服务
    

    管理SSH服务 : service sshd start/restart/stop

    注 在linux服务后面一般加d 
    
    SSH服务的作用
    开启Apache服务    -    让用户通过浏览器访问apache(httpd)指定目录下的文件
    开启MySQL服务     -    存储数据功能
                            1)MySQL安装目录/bin/mysqld.exe 服务端
                            2)MySQL安装目录/bin/mysql.exe  客户端
    开启SSH服务       -    提供如下管理系统功能
                                1)远程登录管理功能
                                 2)远程复制功能
                                 3)文件传输功能
    在Linux或mac系统下,默认已安装openssh-clients客户端,所以可直接通过ssh、scp、sftp指令管理开启sshd服务的系统.
    在widnow系统下,通过基于SSH协议的第三方软件putty、WinSCP管理开启sshd服务的系统
    
    

    在linux或mac下,管理开启SSH服务的系统

    SSH指令
    语法 1: ssh 账号@服务器IP地址
    语法 2 :ssh  -l 账号  服务器IP地址
    
    SETP命令
    登录命令: sftp 用户名@服务器ip地址
    上传命令: put 本地文件 远程文件
    获取命令: get 远程文件 本地文件
    退出命令: exit 或 quit
    
    SCP命令
    上传命令: scp 本地文件用户名@服务器IP地址:文件保存路径
    获取命令: scp 用户名@服务器IP地址:文件保存路径 本地文件
    
    在win下,开启SSH服务的系统
    1) putty
    2) WinSCP(sftp  scp)
    

    相关文章

      网友评论

          本文标题:Linux第二天

          本文链接:https://www.haomeiwen.com/subject/ohfbvftx.html