用户管理,目录权限,定时任务及软件包管理工具

linux用户管理

linux有几种用户身份,好比qq群

1.QQ群主,想干嘛就干嘛,想踢人就踢人------等于linux的root用户,权利最大
2.QQ群管理员,群主给与他的比较大的权限--------等于linux命令加上sudo,默认以root去执行命令
3.渣渣用户,QQ群里的小白,权利特别低--------等于linux的普通用户,用于保证服务器安全,防止删除等危险操作

UID,GID

UID 用户的id号,root是0,普通用户从1000开始

GID,是用户组的ID号

linux下存放用户账户信息的文件是/etc/passwd

useradd

只有root有权限才能创建普通用户,默认uid从1000开始递进

useradd zhoushen

su命令

su命令用于用户切换,root切换普通用户不要密码,普通切root要密码

普通用户之间切换需要密码~~~~

su   -   zhoushen  #切换到zhoushen用户,中间的减号代表完全的环境变量切换,一定要加上

id命令

id命令用于查看用户的uid等信息

id root
id zhoushen

sudo命令

当普通用户执行命令权限不够的时候,使用sudo,强大自己的权限

root ---------皇帝------/root  这里是皇宫,其他用户无法查看
sudo --------黄马褂,圣旨----默认是拥有root的超级权限的
普通用户-----老百姓---- /home/caixukun  /home/haohao 

sudo命令需要配置一下,步骤如下

1.打开sudo的配置文件
执行visudo,会编辑sudoers这个配置文件,在/etc/sudoers,这个命令提供语法检测,更专业
visudo /etc/sudoers

2.找到如下配置行,添加你允许使用sudo的用户名字
## Allow root to run any commands anywhere
root    ALL=(ALL)       ALL
caixukun        ALL=(ALL)       ALL
haohao        ALL=(ALL)       ALL
laowang        ALL=(ALL)       ALL

3.使用sudo命令,在你敲的命令前,加上sudo即可
sudo ls /root

linux的文件和目录权限

这一串信息,如何解读
#解读
happy.txt是一个普通文件
他的user属主是root,user属主的权限是 rw-  (可以读,可写,不可执行)
他的属组group,是root,group属组的权限,是只读的,代表在root组里的用户都可以读这个happy.txt
此时caixukun这个普通用户登录了机器,对于happy.txt来说,caixukun就是一个other其他用户,只读权限

- rw-(uesr) r--(group) r--(other). 1 root root  0 2月   5 16:14 happy.txt

drwxr-xr-x. 3 root root 37 2月   5 15:32 kuaile

文件的权限解读,第一列
-     rw-   r--    r--
代表文件的属性
    - 是普通文本
    d 是一个文件夹

r read 有可读的权限
w write 可以写
x  可执行
-  没有权限
###################
对于文件来说,
r   cat  more   读取
w   vim vi  echo  写入
x   可以用解释器执行的意思

#对于文件夹来说
r    ls  读取
w    可以进入文件夹,在里面创建文件  touch  mkdir
x    cd 可以进入文件夹  

linux的用户身份分3类

-当前这个文件属于谁-------user---属主

-当前在这个文件属于哪个组----group---属组

-其他人---这个文件和当前登录的系统用户没有任何关系-----other

这3类角色都有不同的读、写、执行权限

chmod

change mode,更改文件权限的命令

chmod u+x file  #给user用户添加一个x可执行权限

用zhoushen普通用户给文件的other添加一个w写的权限

[[email protected] s26linux]$ sudo chmod o+w happy.txt
-rw-r--rw-. 1 root root 78 2月   5 16:31 happy.txt

修改这个文件,只有属主可写,其他人都没有权限,用数字权限转化

chmod  200   happy.txt   #这个代表 user是 2 只写的,group和other都没有权限

#给文件,user可读可写,group可读可写,其他人只能写
chmod  662  happy.txt

#解读如下权限
chmod 235  happy.txt
user只有2的权限,只写
group 是3的权限  2+1 ,可写,可执行的
other是5的权限 4+1  ,可读,可执行的

ln命令

创建软连接的命令,创建快捷方式

ln  -s  源文件绝对路径  快捷方式绝对路径
ln -s  /s26linux/happy.txt  /tmp/hp.txt    

tar命令

打包、压缩、解压缩的命令(用户后缀为.tgz)

常用参数如下

-z  调用gzip压缩资源,节省磁盘空间
-x  解压缩
-v 显示过程
-f 这个参数必须写在结尾,指定压缩文件名字
-c  打包参数

案例

把/tmp下所有的内容,进行压缩打包,节省磁盘空间

tar  -zcvf  /opt/alltmp.tgz    ./*  #打包且压缩/tmp下所有内容,生成一个压缩文件,放到opt下

#演示解压缩,吧/opt下alltmp.tgz解压缩
tar -zxvf   /opt/alltmp.tgz  ./

unzip命令

当你是后缀.zip的压缩文件时就用unzip
下载unzip
yum install unzip -y

zip 压缩
(1)将当前文件夹下的所有文件打包成一个 new1.zip 文件
zip new1.zip *
(2)把当前文件夹下所有 my1*.doc 的文件打包成一个 new1.zip 文件
zip new1.zip my1*.doc
(3)把一个文件 abc.txt 和一个目录 dir1 压缩成为 yasuo.zip
zip -r yasuo.zip abc.txt dir1

unzip 解压缩
(1)把文件解压到当前目录下
unzip test.zip
(2)如果要把文件解压到指定的目录下,需要用到-d参数。
unzip -d /temp test.zip
(3)解压的时候,有时候不想覆盖已经存在的文件,那么可以加上 -n 参数
unzip -n test.zip
unzip -n -d /temp test.zip

crontab定时任务

语法如下
分 时  日 月 周     你要执行的命令绝对路径
*  *   *   *   *     绝对路径的命令

例子:
#每分钟执行一次命令
*  *  *  *  *   命令  #每分钟执行命令 

#每小时的整点,执行命令
0 * *  *  *    #每小时的整点执行

#每小时的3,15分组执行命令
3,15  *  *  *  *    命令绝对路径

#在上午8-11点的第3和第15分钟执行
3,15   8-11   *  *  *   命令绝对路径

#每晚6点半执行命令
30  18  *  * *  command

#没周六、日的凌晨1:30执行命令
30  1   *  *  6,7  command

#每周一到周五的凌晨1点,清空/tmp目录的所有文件
0 1  * *  1-5     /usr/bin/rm  -rf /tmp/*

#每晚的21:30重启nginx
30  21  * *  *    /usr/bin/systemctl restart nginx

#每月的 1,10,22日的下午4:45重启nginx
45  16  1,10,22   *  *    /usr/bin/systemctl restart nginx

#每个星期一的上午8点和11点的第3到15分钟执行命令
3-15    8,11  *  *  1   command

如何用crontab

1.输入命令,打开定时任务配置文件
crontab -e
2.写入定时任务语句即可
3.crontab -l 查看定时任务语句

linux的软件包管理工具

linux安装软件有几种方式

  1. 源代码编译安装(最好的安装形式,可以自由定义安装路径,第三方功能扩展,以及获取官网最新的代码进行编译安装,缺点是对新手不友好)
  2. yum工具(新手最好的工具,自动化解决程序安装所需的依赖关系,自动下载且安装依赖,要求得配置yum仓库源,软件版本可能较低)
  3. rpm软件包手动安装(弃用,需要手动解决依赖关系,贼难受,不用)

不同系统的软件包安装格式

windows  exe
macos   dmg
linux   rpm 格式

软件的依赖关系

如何安装django的?
下载django源码进行python3  setup.py  build  

#相比我们都是用的pip安装,为什么呢?
能够自动的解决django模块的依赖关系

#pip3是安装python模块的工具,自动搜索依赖,解决依赖关系

#yum工具是linux系统安装软件的工具,例如安装redis数据库,安装mysql数据库等等

yum工具

对于redhat,centos系列的操作系统,90%的软件都可以yum自动安装,前提是要配置好软件仓库(yum源)

安装,卸载nginx
yum install nginx -y
yum remove nginx -y   #自动解决所有依赖关系,很nice,好用

配置阿里的yum源

1.找到阿里的开源镜像站
https://developer.aliyun.com/mirror/

2.备份linux本地现有的yum仓库文件,
/etc/yum.repos.d/  这个文件夹,默认yum仓库地址,注意!只有在这个目录第一层的以*.repo结尾的文件
才会被识别为是一个yum仓库文件

3.备份以前的yum仓库文件
[[email protected] yum.repos.d]# pwd
/etc/yum.repos.d
[[email protected] yum.repos.d]# mv ./*  allrepoBak/   #备份repo仓库文件

4.下载新的仓库文件,下载阿里的
# 参数解释 -O  将下载的文件,指定一个路径存放,且改名
# 这是第一个仓库
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
# 下载第二个epel仓库
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

5.清空之前的yum缓存
yum clean all

6.可以测试用yum安装nginx软件,或是redis数据库软件
yum install nginx -y
yum install redis -y  

7.只要是通过yum安装的软件,都可以用systemctl  系统服务管理命令,进行启停管理
systemctl start/stop/restart/status nginx  #分别是 启动,停止,重启,查看状态
systemctl start nginx
systemctl stop nginx

systemctl start/stop/restart  redis

8.验证redis和nginx软件是否正常
[[email protected] yum.repos.d]# redis-cli
127.0.0.1:6379> ping
PONG

退出redis,可以直接ctrl + c 

验证nginx,直接浏览器访问网站的80端口即可
192.168.xxx.xxx:80

9.此时可以修改一下nginx的首页内容,一分钟做一个dnf官网   ~~~~~逗乐
nginx首页页面默认在
vim /usr/share/nginx/html/index.html  #自行去复制dnf官网的源码,修改即可

10.如果没法连接nginx  别忘了关闭防火墙
iptables -F   

原文地址:https://www.cnblogs.com/zzsy/p/12299955.html

时间: 2024-10-05 04:58:05

用户管理,目录权限,定时任务及软件包管理工具的相关文章

Linux学习之CentOS(二十三)--Linux软件管理之源代码以及RPM软件包管理

在Linux系统下,对于软件包的管理有多种机制,有源代码方式.RPM软件包管理方式以及YUM软件管理方式,本篇随笔将详细讲解CentOS下源代码形式安装软件以及RPM软件包管理机制 一.源代码形式 首 先我们先来看一下源代码的方式.我们知道,在开源的环境下,大多数的开源软件都是以源代码的形式来发布,通常将源代码打包成tar.gz的归档压缩文件发 布到网上供我们下载使用.但是我们下载下来的源代码方式我们还不能够直接使用,不像在windows系统上直接下载下来可执行的二进制文件,我们需要将下 载好的

CentOS软件管理之源代码以及RPM软件包管理

在Linux系统下,对于软件包的管理有多种机制,有源代码方式.RPM软件包管理方式以及YUM软件管理方式,本篇随笔将详细讲解CentOS下源代码形式安装软件以及RPM软件包管理机制 一.源代码形式 首先我们先来看一下源代码的方式.我们知道,在开源的环境下,大多数的开源软件都是以源代码的形式来发布,通常将源代码打包成tar.gz的归档压缩文件发布到网上供我们下载使用.但是我们下载下来的源代码方式我们还不能够直接使用,不像在windows系统上直接下载下来可执行的二进制文件,我们需要将下载好的源码编

Linux软件管理之源代码以及RPM软件包管理与YUM软件包管理

在Linux系统下,对于软件包的管理有多种机制,有源代码方式.RPM软件包管理方式以及YUM软件管理方式 一.源代码形式 首先我们先来看一下源代码的方式.我们知道,在开源的环境下,大多数的开源软件都是以源代码的形式来发布,通常将源代码打包成tar.gz的归档压缩文件发布到网上供我们下载使用.但是我们下载下来的源代码方式我们还不能够直接使用,不像在windows系统上直接下载下来可执行的二进制文件,我们需要将下载好的源码编译成可执行的二进制文件才能运行使用,源代码形式安装流程一般如下: ①./co

vsftpd 的三种用户和目录权限

vsftpd 有三种登录方式 匿名用户 本地用户 虚拟用户 下面分别介绍这三种用户的配置 1.匿名用户 当用yum安装好vsftpd之后修改一下配置文件,并重启就可以使用匿名用户访问了 # yum  -y install vsftpd # vi /etc/vsftpd/vsftpd.conf anonymous_enable=YES               开启匿名用户登录 anon_upload_enable=YES             允许匿名用户上传权限 anon_mkdir_wr

Linux下设置SFTP用户访问目录权限

一.创建新用户,并且设置目录,禁止shell登录 useradd -m -d /home/wwwroot/licnlt -s /usr/sbin/nologin licnlt nologin要事先确认位置,通常在/usr/sbin或/sbin下(可在/etc/passwd中查看sshd的nologin配置) 二.设置用户密码 passwd licnlt 三.将该用户目录所有者设置成root chown root:root /home/wwwroot/licnlt/ #目录只能由root所有 ch

【one day one linux】linux下的软件包管理工具

Linux 下的软件包管理工具 linux下的软件安装可以通过两种方式,一种是直接使用自带的软件包管理工具安装,另外一种通过编译源码安装. 1.软件包的种类 Red Hat和Fedora:redhat最早发行的个人版本的Linux,自从Red Hat 9.0版本发布后,RedHat 公司就不再开发桌面版的 Linux发行套件,Red Hat Linux停止了开发,而将全部力量集中在服务器版的开发上,也就是 Red Hat Enterprise Linux 版.2004年4月30日,Red Hat

BZOJ 4196: [Noi2015]软件包管理器

二次联通门 : BZOJ 4196: [Noi2015]软件包管理器 /* BZOJ 4196: [Noi2015]软件包管理器 树链剖分 树链剖分 , 用线段树维护链上的和与子树的和 对于1操作, 每次预先查询待修改点x点的深度 后查询1到x这条链上有多少已安装的, 然后上面的值减下面的值 对于2操作,每次查询以x为根的子树的大小 修改整颗子树即可.. 说白了其实就是板子题 */ #include <cstdio> #define Max 500090 inline int min (int

用户命令、权限、IO重定向、grep

/etc/passwd:用户名:密码:UID:GID:注释:家目录:默认SHELL/etc/group:组名:密码:GID:以此组为其附加组的用户列表/etc/shadow:用户名:密码:最近一次修改密码的时间:最短使用期限:最长使用期限:警告时间:非活动时间:过期时间:用户管理:useradd, userdel, usermod, passwd, chsh, chfn, finger, id, chage创建用户:useradd [options] USERNAME-u UID:手动给用户指定

Linux用户群组权限恢复

/etc/passwd:该文件用于存放用户详细信息:例如 root:x:0:0:root:/root:/bin/bash 用户id 0:就表示root用户 bin下的bash:表示可以登入操作系统 sbin下的nologin:不能登入系统 用户名:密码:用户id:组id:用户描述信息:用户目录的家目录:可执行文件 /etc/shadow :该文件用于存放用户名密码. /etc/group:用于存放组ID root:X:0 组名:组密码:组id /etc/gshadow:用于存放组密码 创建一个用