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 {<+-=>...} 待授权的文件
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)