用户、yum

用户

  • 超级管理员用户,id是0。

.bashrc :系统存放内置别名目录,设置别名一般放在/etc/bashrc/文件中。

.bash_profile:系统设置环境变量的文件,设置环境变量一般放在/etc/profile.d中的某一个.sh文件中。

  • 系统用户: 用来启动系统的一些服务和进程的用户,不可以登陆,id:1-999(centos7)1-499 (centos6) ,相关文件夹:/etc/passwd ——>bin…nologin

  • 可登陆用户:能登录系统的用户,id:1000-65535(centos7)500-65535(centos6)

普通用户的id是递增,创建用户是从最多的id增加的;系统用户的id是递减的。

新建的用户家目录有一些隐藏文件ll -a进行查看。如.bashrc,是设置命令别名的文件。

useradd

Usage: useradd [options] LOGIN_NAME
       useradd -D
       useradd -D [options]

-d 用来指定用户的家目录
useradd -d /test/test_user test_user1

-g 指定用户组的id
useradd -d /test/test_user -g test_user1 test_user2

-u 指定用户的id
useradd -u 2000 test_user8

-G 指定用户的附加,多个用","相隔,新建的用户拥有所有附加组的权限
useradd -G root,test_user1 test_user3

-k 指定复制哪个文件夹下的内容到新建用户的家目录,需要和-m一起使用
-m 创建用户的家目录
useradd -k /etc/sysconfig/network-scripts -m test_user4

-c "message" 指定用户的描述信息
useradd -c "haha" test_user5
查看描述信息:vim /etc/passwd  末尾

-N 不创建同名的组,以users为组
useradd -N test_user6

-r 创建一个系统用户

-s 指定用户登录后使用的shell,查看可以shell cat /ect/shells
useradd -s /sbin/nologin test_user7

—D 显示系统的默认配置   
useradd -D

-D [options] 可以修改系统的默认配置
  • 相关文件
    • /etc/default/useradd 创建用户的默认配置文件
    • /etc/skel/* 默认复制的文件
    • /etc/login.defs id范围配置文件

用户修改usermode

-c 修改描述信息
-d 修改家目录,默认不会创建新目录,如果想移动家目录,则需要使用-m
-m 移到家目录,只能和-d使用
-g 修改用户组
-G 修改用户的附加组,默认情况下是替换
-a 追加附加组,和-G结合使用
-l newname 修改用户的登录名称,id不变
-L 锁定用户,不能登录系统,修改密码默认情况下会解锁
-U 解锁用户
-s 修改用户登录后的shell
-u 修改用户的uid
-e 年-月-日 修改用户的过期时间,过期以后不能登录

删除用户

userdel

默认删除用户不删除用户的家目录
-r 删除家目录
-f 强制删除
默认情况下,用户登录状态下是不能删除用户,强制删除用户以后,用户还是可以用的

查看用户相关信息id

-g 只显示组id
-G 只显示附加组id
-u 只显示用户id
-n 显示名称,需要和-g来配合使用
id -gn test_user

切换用户

su [options] [-] [USER [arg]...]

切换用户的方式

  • 完整切换:su - username 登录式切换,环境变量等都会切换
  • 不完整切换:su username 不会切换用户的环境变量家目录等
  • 退出:exit
  • root切换普通用户不需要密码,非root用户切换需要密码

切换用户执行命令,然后再切换回来

su - test_name -c whoami

执行本身不能执行的命令

sudo 配置文件为/etc/sudoers

进入文件后搜索root

test_user   ALL=(ALL)       NOPASSWD:ALL
其中的NOPASSWD 是执行命令不需要输入登录用户的密码,可以不设置:
test_user   ALL=(ALL)       ALL

用test_user执行root能执行的命令:
sudo command

更多配置请看文件中的解释

/etc/passwd文件

man 5

name:password:UID:GID:GECOS:directory:shell

  • 用户名称
  • 密码,使用x来占位
  • uid
  • gid
  • 描述信息
  • 家目录
  • 登录后使用的shell

设置密码passwd

passwd [OPTION...] <accountName>

-d 删除指定用户的密码,删除密码之后就不能登录
-l 锁定用户
-u 解锁用户
-e 在下次登录以后强制用户修改密码
-f 强制操作
-x maxday 密码的最长使用时间
-n minday 密码的最短使用时间,设置后多长时间才能修改
-w warnday 密码过期前多长时间提醒
-i inactiveday 密码过期多长时间以后禁用
--stdin 从标准输入读取密码 echo '123'|passwd --stdin test_user

存放文件/etc/shadow

  • 用户名
  • 密码 $加密方式(默认sha512)$盐$加密后的字符串$
  • 从1970年1月1日到最近一次修改密码经过的时间
  • 密码的最短使用时间(0表示随时可以修改)
  • 密码的最长使用时间(99999表示永不过期)
  • 密码过期多长时间提醒(默认是一周)
  • 密码过期多长时间锁定
  • 从1970年1月1日开始算起,多长时间后账号失效

密码的复杂性策略

  • 必须包括数字、大小写、特殊字符
  • 密码必须12位以上
  • 不能为弱口令
  • 必须为随机密码
  • 3个月或者半年修改一次

机器免密登录

ssh-keygen 一路回车
ssh-copy-id 要登录的机器  ssh-copy-id root@192.168.13.129

直接登录另一台机器:
ssh root@192.168.13.129

修改用户密码策略 chage

-E 
-I
-m
-M
-W
change test_user 可以使用交互式的修改密码策略

chfn 修改用户的个人信息

用户组

超级用户组 root 0

普通用户组:

  • 系统用户组 1-999(centos7) 1-499(centos6)
  • 可登陆用户组 1000-65535(centos7)500-65535 (centos6)
groupadd
-g 指定组id
-r 创建系统用户组

查看组的信息
cat /etc/group

组的文件

/etc/group

  • 组名
  • 密码占位
  • gid
  • 组成员

/etc/gshadow

  • 组名
  • 密码
  • 组管理员的密码
  • 组成员

修改组信息

groupmod

-g 修改gid
-n 修改组名

删除组

groupdel 删除组

软件

windows中后缀名为.exe

centos(redhat): .rpm (是radhat package manager的缩写)

包的管理工具:rpm、yum。使用rpm安装需要自己解决包的依赖关系,使用yum会自动帮助安装相关的依赖包。

包的命名规范

MySQL-python-1.2.5-1.el7.x86_64.rpm  
名字-版本(大版本.小版本.修订版)-打包版本.可用的系统.架构.rpm
架构:
    x86_64
    x86
    i386
    i486
    i686
    ppc
    noarch 表示通用

包的来源

  • 光盘
  • 第三方网站
  • 官方网站
  • 自己做
  • https://pkgs.org
  • epel 第三方包的结合地

使用国内源安装模块示例:

pip install openpyxl -i https://pypi.douban.com/simple

rpm 包的查询

rpm -q 查询指定的包是否安装
-a  all 表示当前系统安装的所有的包
-f filename 查询指定的文件由那个包安装生成
-c 查看指定的包生成了哪些配置文件
-d 查询指定的包生成了哪些文档
-i 查询指定包的详细信息
-l 查询指定的包生成到文件 
常用的选项:-qi、-qa、-ql、-qc、-qd

yum

仓库:存放的是 多个包和包的元数据信息(所在仓库,依赖关系)

仓库的位置:

  • http://
  • https: //
  • ftp: //
  • file: //(本地文件)
  • 配置文件存放在/etc/yum.repos.d

yum配置文件

[base] #名称
name=CentOS-$releasever - Base - mirrors.aliyun.com # 描述信息
failovermethod=priority # 定义挑选顺序 priority 按顺序 roundrobin 随机
baseurl=http://mirrors.aliyun.com/centos/$releasever/os/$basearch/
        http://mirrors.aliyuncs.com/centos/$releasever/os/$basearch/
        http://mirrors.cloud.aliyuncs.com/centos/$releasever/os/$basearch/
enabled ={0|1} # 是否启用,1启用,0是不启用
gpgcheck={0|1} # 使用校验
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7 # 校验文件
默认值
$releasever # 发行版
$basearch # 系统架构

yum 源

阿里、163、sohu、腾讯、北大、中科大学…

yum命令

  • yum repolist 查看仓库
  • yum list 列出仓库里面所有的包 安装的包前面带@
  • yum install 安装包
  • yum reinstall 重新安装
  • yum update 更新所有的包
  • yum update pkg 更新指定的包
  • yum downgrade 降级
  • yum check-update 检查包是否可以更新
  • yum remove 卸载包
  • yum info pkg 显示包的详细信息
  • yum clean all 删除元数据信息
  • yum makecache 重新构建元数据信息
  • yum search 搜索软件包(包名称、描述信息只要包含就可以搜索出来)
  • yum provides 搜索命令是由哪个包提供的

软件包组

需要加“”,因为包组名有空格

  • yum grouplist 查看包组
  • yum groupinstall 安装yum groupinstall “包组名”
  • yum groupinfo 获取包的信息,查看包组有哪些包组成
  • yum groupupdate 更新
  • yum groupremove 卸载包组

yum选项命令

-y 自动确认

-q 静默模式

源码安装

  • 下载,如: wget https://www.python.org/ftp/python/3.6.9/Python-3.6.9.tar.xz
  • 解压文件 tar xf
  • 切换目录 cd
  • 可以查看帮助信息 READM或INSTALL 文件
  • 安装所需文件
  • 编译(检查程序所需的文件)./configure
  • 构建安装程序 make
  • 安装程序 make install
  • 配置环境变量
posted @ 2020-08-09 15:14  虫萧  阅读(149)  评论(0编辑  收藏  举报