Linux用户管理、文本处理、安装包管理

2019-07-13 05:22发布

一、Linux用户管理

1、用户,组,权限

Authentication 认证 Authorization 授权 Adition 审计 认证:认证标识,口令 权限:不同用户,权限不同 用户 :username,UID     root:管理员,拥有全部权限,0     普通用户:权限由管理员授予,1-65535       系统用户:对守护进程获取资源进行权限分配,1-499(CentOS 6),1-999(centOS 7)       登陆用户:交互式登录,500+(centOS 6),999+(centOS 7) 组:groupname,GID     管理员组:root,0     普通组:       系统组:1-499, 1-999(CENTOS7)
          普通组:500+, 1000+(CENTOS7)   Linux组的类别
      用户的主要组(primary group)
      用户必须属于一个且只有一个主组
      组名同用户名,且仅包含一个用户,私有组
      用户的附加组(supplementary group)
      一个用户可以属于零个或多个辅助组     进程代表用户身份运行,进程的权限由启动的用户的权限决定。   Linux用户和组的主要配置文件: 
      /etc/passwd:用户及其属性信息(名称、UID、主组ID等)
      /etc/group:组及其属性信息
      /etc/shadow:用户密码及其相关属性
      /etc/gshadow:组密码及其相关属性 passwd文件格式     login name:登录用名(Tom)
    passwd:密码  (x)
    UID:用户身份编号 
    GID:登录默认所在组编号  
    GECOS:用户全名或注释
    home directory:用户主目录 (/home/Tom)
    shell:用户默认使用shell (/bin/bash) shadow文件格式     登录用名
    用户密码:一般用sha512加密(安全散列算法,能计算出一个数字消息所对应到的,长度固定的字符串(又称消息摘要)的算法。)
    从1970年1月1日起到密码最近一次被更改的时间
    密码再过几天可以被变更(0表示随时可被变更)
    密码再过几天必须被变更(99999表示永不过期)
    密码过期前几天系统提醒用户(默认为一周)
    密码过期几天后帐号会被锁定
    从1970年1月1日算起,多少天后帐号失效  group文件格式 群组名称:就是群组名称
群组密码:通常不需要设定,密码是被记录在 /etc/gshadow 
GID:就是群组的 ID 
以当前组为附加组的用户列表(分隔符为逗号) gshdow文件格式 群组名称:就是群组名称
群组密码:
组管理员列表:组管理员的列表,更改组密码和成员
以当前组为附加组的用户列表:(分隔符为逗号)

2、用户,组操作指令

useradd [options] LOGIN
    -u UID 
    -o 配合-u 选项,不检查UID的唯一性
    -g GID:指明用户所属基本组,可为组名,也可以GID
    -c "COMMENT":用户的注释信息
    -d HOME_DIR: 以指定的路径(不存在)为家目录
    -s SHELL: 指明用户的默认shell程序
         可用列表在/etc/shells文件中
    -G GROUP1[,GROUP2,...]:为用户指明附加组,组须事先存在
    -N 不创建私用组做主组,使用users组做主组
    -r: 创建系统用户 CentOS 6: ID<500,CentOS 7: ID<1000
    -m  创建家目录,用于系统用户
    -M  不创建家目录,用于非系统用户 usermod [OPTION] login 用户属性修改
    -u UID: 新UID
    -g GID: 新主组
    -G GROUP1[,GROUP2,...[,GROUPN]]]:新附加组,原来的附加组将会被覆盖;若保留原有,则要同时使用-a选项
    -s SHELL:新的默认SHELL
    -c 'COMMENT':新的注释信息
    -d HOME: 新家目录不会自动创建;若要创建新家目录并移动原家数据,同时使用-m选项
    -l login_name: 新的名字;
    -L: lock指定用户,在/etc/shadow 密码栏的增加 ! 
    -U: unlock指定用户,将 /etc/shadow 密码栏的 ! 拿掉
    -e YYYY-MM-DD: 指明用户账号过期日期
    -f INACTIVE: 设定非活动期限 userdel [OPTION]... login 删除用户
    -r: 删除用户家目录 id [OPTION]... [USER] 查看用户相关的ID信息
    -u: 显示UID
    -g: 显示GID
    -G: 显示用户所属的组的ID
    -n: 显示名称,需配合ugG使用 su [options...] [-] [user [args...]]
    su UserName:非登录式切换,即不会读取目标用户的配置文件,不改变当前工作目录
    su - UserName:登录式切换,会读取目标用户的配置文件,切换至家目录,完全切换
    root su至其他用户无须密码;非root用户切换时需要密码
    su [-] UserName -c 'COMMAND'换个身份执行命令
    -l  --login
    su -l UserName  相当于 su - UserName passwd [OPTIONS] UserName: 修改指定用户的密码
    -d:删除指定用户密码
    -l:锁定指定用户
    -u:解锁指定用户
    -e:强制用户下次登录修改密码
    -f: 强制操作
    -n mindays: 指定最短使用期限
    -x maxdays:最大使用期限
    -w warndays:提前多少天开始警告
    -i inactivedays:非活动期限
    --stdin:从标准输入接收用户密码
     echo "PASSWORD" | passwd --stdin USERNAME groupadd [OPTION]... group_name
    -g GID: 指明GID号;[GID_MIN, GID_MAX]
    -r: 创建系统组
        CentOS 6: ID<500
        CentOS 7: ID<1000 groupmod [OPTION]... group       -n group_name: 新名字       -g GID: 新的GID groupdel GROUP  组删除 gpasswd [OPTION] GROUP
    -a user  将user添加至指定组中
    -d user  从指定组中移除用户user
    -A user1,user2,...  设置有管理权限的用户列表 newgrp命令:临时切换主组 chown 修改文件的属主 chown [OPTION]... [OWNER][:[GROUP]] FILE...   -R: 递归
    chown [OPTION]... --reference=RFILE FILE...   user1:grp1 file    :将文件file的属主改为user1,属组改为grp1,用.也可以。 chgrp [OPTION]... GROUP FILE...
      chgrp [OPTION]... --reference=RFILE FILE...
      -R 递归 chmod :修改文件的权限 文件的权限修改要用到000-777的参数, rwx     --- 000 0 --x 001 1 -w- 010 2 -wx 011 3 r-- 100 4 r-x 101 5 rw- 110 6 rwx 111 7                   表中表示了一位的权限设置,三位表示属主、属组、其他权限。   chmod 777 file:表示给file文件所有的权限都开放   chmod 740 file: 表示给file文件属主所有权限,属组读权限,其他用户不给权限。   输入位数不足左侧补零,要补齐位数。   普通文件不要给任何执行权限,除非确定可以运行   目录一定要有执行权限,否则回无法cd进入   修改目录权限不会修改目录下的文件的权限。 chmod -R 递归    g= :组权限修改,u=用户权限修改,o=其他权限,a=所有用户权限。可组合使用。例如:   ug=rw,给与属主和属组读写权限,不给执行权限,不改其他用户权限。   o=  ,其他用户权限全部取消   u+w:表示给属主写权限,不改变其他位置   go-r:表示取消属组和其他用户的读权限   +x file :表示给所有用户操作权限   +w file:只给属主加写的权限   --reference filea=fileb :将文件a的权限设置的与b相同 更改访问控制列表 getfacl file 查看访问控制列表 setfacl   setfacl -m u:user1:rw file.txt  更改访问控制列表,使user1对文件file.txt能读能写。普通用户可改自己文件。root用户有所有权限。   setfacl -m  g:grp1:rw file   -x 减权限 例如:  setfacl -x g:grp1 file  删除访问控制列表,不用指定权限。   ACL:Access Control List,实现灵活的权限管理
  除了文件的所有者,所属组和其它人,可以对更多的用户设置权限 
  CentOS7 默认创建的xfs和ext4文件系统具有ACL功能
  CentOS7 之前版本,默认手工创建的ext4文件系统无ACL功能,需手动增加
  tune2fs –o acl /dev/sdb1
  mount –o acl /dev/sdb1  /mnt/test
  ACL生效顺序:所有者,自定义用户,自定义组,其他人 Linux文件系统上的特殊权限 SUID, SGID, Sticky 三种常用权限:r, w, x    user, group, other
安全上下��
  前提:进程有属主和属组;文件有属主和属组
     (1) 任何一个可执行程序文件能不能启动为进程,取决发起者对程序文件是否拥有执行权限
     (2) 启动为进程之后,其进程的属主为发起者,进程的属组为发起者所属的组
     (3) 进程访问文件时的权限,取决于进程的发起者
     (a) 进程的发起者,同文件的属主:则应用文件属主权限
     (b) 进程的发起者,属于文件属组;则应用文件属组权限
     (c) 应用文件“其它”权限 可执行文件上SUID权限   任何一个可执行程序文件能不能启动为进程:取决发起者对程序文件是否拥有执行权限
  启动为进程之后,其进程的属主为原程序文件的属主
  SUID只对二进制可执行程序有效
  SUID设置在目录上无意义
    权限设定:
     chmod u+s FILE...    -rwsr--r--  -rwSr--r--   小写原来有执行权限,大写原来没有。
     chmod u-s FILE... 可执行文件上SGID权限   任何一个可执行程序文件能不能启动为进程:取决发起者对程序文件是否拥有执行权限
  启动为进程之后,其进程的属组为原程序文件的属组
    权限设定:
     chmod g+s FILE...    -rwxrwsr--
     chmod g-s FILE... sticky位 粘滞位   具有写权限的目录通常用户可以删除该目录中的任何文件,无论该文件的权限或拥有权
  在目录设置Sticky 位,只有文件的所有者或root可以删除该文件
  sticky 设置在文件上无意义
  权限设定:
    chmod o+t file
    chmod o-t file
    例如:ls -ld /tmp        drwxrwxrwt  12 root  root  4096 Nov 2 15:44 /tmp   drwxrwxrwT t大写表示原来没有执行权限   sst可以设置在最左侧,用0-7表示。   chmod 5775 file 表示设置SUID和stick位,后边与之前相同。

二、文本处理

文本查看,分析,统计工具 正则表达式 扩展正则表达式 vim grep sed 文本查看,分析,统计工具 cat 查看文件,将文件内容全部输出到标准输出 more 按页查看,到尾部自动退出 less 按页查看,指令man使用的文本查看工具。 head 输出前十行  head -1: 输出第一行 tail 输出后十行 tail -1: 输出最后一行   tail -f 监视,持续输出文件尾部的追加的新内容 cut -d: -f7 file      以:为分割,显示第七个字段 cut -d‘ ’  以空格为分割 wc        word cut,字符统计    -l  只显示行   -w  只显示单词   -m 只显示字符数   -c  只显示字节  sort 排序   -r  逆序   -n  以大小排   -f  忽略大小写    -u 去重 unique uniq 去连续重复   -c 显示重复计数   -d 显示重复出现的行   -u 显示只出现一次的行 diff  比较 patch 打补丁  正则表达式 REGEXP:由一类特殊字符及文本字符所编写的模式,其中有些字符(元字符)不表示字符字面意义,而表示控制或通配的功能
  程序支持:grep,sed,awk,vim, less,nginx,varnish等
  分两类:
     基本正则表达式:BRE
     扩展正则表达式:ERE           grep -E, egrep
  正则表达式引擎:
     采用不同算法,检查处理正则表达式的软件模块
           PCRE(Perl Compatible Regular Expressions)
  元字符分类:字符匹配、匹配次数、位置锚定、分组
  man  7 regex 字符匹配   .    匹配任意单个字符
   []  匹配指定范围内的任意单个字符
   [^]  匹配指定范围外的任意单个字符
   [:alnum:] 字母和数字 
   [:alpha:] 代表任何英文大小写字符,亦即 A-Z, a-z
   [:lower:] 小写字母    [:upper:] 大写字母
   [:blank:] 空白字符(空格和制表符)
   [:space:] 水平和垂直的空白字符(比[:blank:]包含的范围广)
   [:cntrl:] 不可打印的控制字符(退格、删除、警铃...)
   [:digit:] 十进制数字 [:xdigit:]十六进制数字
   [:graph:] 可打印的非空白字符
   [:print:] 可打印字符
   [:punct:] 标点符号 匹配次数:用在要指定次数的字符后面,用于指定前面的字符要出现的次数
   * 匹配前面的字符任意次,包括0次
   贪婪模式:尽可能长的匹配
   .* 任意长度的任意字符
   ? 匹配其前面的字符0或1次
   + 匹配其前面的字符至少1次
   {n} 匹配前面的字符n次
   {m,n} 匹配前面的字符至少m次,至多n次
   {,n} 匹配前面的字符至多n次
   {n,} 匹配前面的字符至少n次 位置锚定:定位出现的位置
   ^ 行首锚定,用于模式的最左侧
   $ 行尾锚定,用于模式的最右侧
   ^PATTERN$  用于模式匹配整行
   ^$  空行
   ^[[:space:]]*$  空白行
   < 或  词首锚定,用于单词模式的左侧
   > 或  词尾锚定;用于单词模式的右侧
    匹配整个单词 分组:() 将一个或多个字符捆绑在一起,当作一个整体进行处理,如:(root)+
  分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: 1, 2, 3, ...
  1  表示从左侧起第一个左括号以及与之匹配右括号之间的模式所匹配到的字符
    示例:  (string1+(string2)*)
          1 :string1+(string2)*
          2 :string2
后向引用:引用前面的分组括号中的模式所匹配字符,而非模式本身
  或者:|
     示例:a|b: a或b  C|cat: C或cat  (C|c)at:Cat或cat 文本处理常用工具 grep 全局搜索正则表达式并打印   逐行处理,显示匹配到的   -v 显示未匹配到的   -i 忽略大小写   -n:显示匹配的行号
  -c: 统计匹配的行数
  -o: 仅显示匹配到的字符串
  -q: 静默模式,不输出任何信息
  -A #: after, 后#行
  -B #: before, 前#行
  -C #:context, 前后各#行
  -e:实现多个选项间的逻辑or关系
     grep –e ‘cat ’  -e ‘dog’  file
  -w:匹配整个单词
  -E:使用ERE
  -F:相当于fgrep,不支持正则表达式    (a|b)a或b sed  Stream EDitor, 行编辑器   sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。然后读入下行,执行下一个循环。如果没有使诸如‘D’的特殊命令,那会在两个循环之间清空模式空间,但不会清空保留空间。这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。
功能:主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等
参考: http://www.gnu.org/software/sed/manual/sed.html 地址定界:
   (1) 不给地址:对全文进行处理
   (2) 单地址:
      #: 指定的行,$:最后一行
      /pattern/:被此处模式所能够匹配到的每一行
   (3) 地址范围:
      #,#
      #,+#
      /pat1/,/pat2/
      #,/pat1/
   (4) ~:步进
      1~2 奇数行
      2~2 偶数行 sed [option]... 'script' inputfile...
  常用选项:
  -n:不输出模式空间内容到屏幕,即不自动打印
  -e: 多点编辑
  -f:/PATH/SCRIPT_FILE: 从指定文件中读取编辑脚本
  -r: 支持使用扩展正则表达式
  -i.bak: 备份文件并原处编辑   d: 删除模式空间匹配的行,并立即启用下一轮循环
  p:打印当前模式空间内容,追加到默认输出之后
  a []text:在指定行后面追加文本
       支持使用 实现多行追加
  i []text:在行前面插入文本
  c []text:替换行为单行或多行文本
  w /path/somefile: 保存模式匹配的行至指定文件
  r /path/somefile:读取指定文件的文本至模式空间中匹配到的行后
  =: 为模式空间中的行打印行号
  !:模式空间中匹配行取反处理    s///:查找替换,支持使用其它分隔符,s@@@,s###
    替换标记:
    g: 行内全局替换
    p: 显示替换成功的行
    w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中  awk  格式化文本并打印  gawk: GNU awk vim   vi: Visual Interface,文本编辑器
  文本:ASCII, Unicode
  文本编辑种类:
   行编辑器: sed
   全屏编辑器:nano, vi
   vim - Vi Improved
  其他编辑器:
     gedit  一个简单的图形编辑器
     gvim  一个Vim编辑器的图形版本 # vim [OPTION]... FILE...
  +#: 打开文件后,让光标处于第#行的行首,+默认行尾
  +/PATTERN:打开文件后,直接让光标处于第一个被PATTERN匹配到的行的行首
  –b file 二进制方式打开文件
  –d file1 file2…  比较多个文件
  -m file  只读打开文件
  ex  file 或 vim –e  直接进入ex模式
  如果该文件存在,文件被打开并显示内容
  如果该文件不存在,当编辑后第一次存盘时创建它   击键行为是依赖于 vim的 的“模式”
  三种主要模式:
    命令(Normal)模式:默认模式,移动光标,剪切/粘贴文本
    插入(Insert)或编辑模式: 修改文本
    扩展命令(extended command )模式: 保存,退出等
  Esc键 退出当前模式
  Esc键 Esc键 总是返回到命令模式   命令模式 --> 插入模式
  i: insert, 在光标所在处输入
  I:在当前光标所在行的行首输入
  a: append, 在光标所在处后面输入
  A:在当前光标所在行的行尾输入
  o: 在当前光标所在行的下方打开一个新行
  O:在当前光标所在行的上方打开一个新行 字符编辑:     x: 删除光标处的字符     #x: 删除光标处起始的#个字符     xp: 交换光标所在处的字符及其后面字符的位置     ~:转换大小写     J:删除当前行后的换行符 替换命令(r, replace)   r: 替换光标所在处的字符     R:切换成REPLACE模式 删除命令:
  d: 删除命令,可结合光标跳转字符,实现范围删除
  d$: 删除到行尾
  d^:删除到非空行首
  d0:删除到行首
  dw:
  de:
  db:
  #COMMAND
  dd: 删除光标所在的行
  #dd:多行删除
  D:从当前光标位置一直删除到行尾,留空行,等同于d$ 复制命令(y, yank):
  y: 复制,行为相似于d命令
  y$
  y0
  y^
  ye
  yw
  yb
  #COMMAND
  yy:复制行
  #yy: 复制多行
  Y: 复制整行 粘贴命令(p, paste):
  p:缓冲区存的如果为整行,则粘贴当前光标所在行的下方;否则,则粘贴至当前光标所在处的后面
  P:缓冲区存的如果为整行,则粘贴当前光标所在行的上方;否则,则粘贴至当前光标所在处的前面 改变命令(c, change)
  c: 修改后切换成插入模式 撤销命令   u 撤销   ctrl+r撤销之前的撤销,取消撤销   .  点表示重复之前的操作 光标跳转 命令模式字符间跳转:
  h: 左  l: 右 j: 下 k: 上
  #COMMAND:跳转由#指定的个数的字符
命令模式单词间跳转:
  w:下一个单词的词首
  e:当前或下一单词的词尾
  b:当前或前一个单词的词首
  #COMMAND:由#指定一次跳转的单词数
命令模式当前页跳转:
  H:页首  M:页中间行 L:页底 行首行尾跳转:
   ^: 跳转至行首的第一个非空白字符
   0: 跳转至行首
   $: 跳转至行尾
行间移动:
   #G、扩展模式:# :跳转至由#指定行
   G:最后一行
   1G, gg: 第一行
句间移动:
   ):下一句 (:上一句
段落间移动:
   }:下一段 {:上一段 扩展模式   按“:”进入Ex模式 
  创建一个命令提示符:  处于底部的屏幕左侧
  命令:
   w 写(存)磁盘文件
   wq 写入并退出
   x 写入并退出
   q  退出
   q! 不存盘退出,即使更改都将丢失 
   r filename 读文件内容到当前文件中
   w  filename 将当前文件内容写入另一个文件
   !command 执行命令
   r!command 读入命令的输出   c$
  c^
  c0
  cb
  ce
  cw
  #COMMAND
  cc:删除当前行并输入新内容,相当于S
  #cc: 
  C:删除当前光标到行尾,并切换成插入模式 地址定界
  :start_pos,end_pos
  # 具体第#行,例如2表示第2行
  #,# 从左侧#表示起始行,到右侧#表示结尾行 
  #,+#  从左侧#表示的起始行,加上右侧#表示的行数
  :2,+3  表示2到5行
  .  当前行
  $  最后一行
  .,$-1 当前行到倒数第二行
  %  全文, 相当于1,$   /pat1/,/pat2/
    从第一次被pat1模式匹配到的行开始,一直到第一次被pat2匹配到的行结束
  #,/pat/
  /pat/,$
使用方式:后跟一个编辑命令
  d
  y
  w file: 将范围内的行另存至指定文件中
  r  file:在指定位置插入指定文件中的所有内容 查找
  /PATTERN:从当前光标所在处向文件尾部查找
  ?PATTERN:从当前光标所在处向文件首部查找
  n:与命令同方向
  N:与命令反方向 s: 在扩展模式下完成查找替换操作
  格式:s/要查找的内容/替换为的内容/修饰符
  要查找的内容:可使用模式
  替换为的内容:不能使用模式,但可以使用1, 2, ...等后向引用符号;还可以使用“&”引用前面查找时查找到的整个内容
  修饰符:
    i: 忽略大小写
    g: 全局替换;默认情况下,每一行只替换第一次出现
    gc:全局替换,每次替换前询问
查找替换中的分隔符/可替换为其它字符,例如
  s@/etc@/var@g
  s#/boot#/#i 允许选择的文本块
  v 面向字符
  V 面向行
  ctrl-v 面向块
可视化键可用于与移动键结合使用:
  w  )   }  箭头等
突出显示的文字可被删除,复制,变更,过滤,搜索,替换等 插入模式 --------> 命令模式
    ESC
命令模式 --------> 扩展命令模式
      :
扩展命令模式 --------> 命令模式
      ESC,enter 退出:   扩展模式:
    :q 退出
    :q! 强制退出,丢弃做出的修改
    :wq 保存退出
    :x 保存退出
  命令模式
    ZZ: 保存退出
    ZQ:不保存退出 多文件分割
  vim -o|-O FILE1 FILE2 ...
  -o: 水平分割
  -O: 垂直分割
  在窗口间切换:Ctrl+w, Arrow
  单文件窗口分割:
  Ctrl+w,s: split, 水平分割
  Ctrl+w,v: vertical, 垂直分割
  ctrl+w,q:取消相邻窗口
  ctrl+w,o:取消全部窗口
  :wqall 退出 配置文件:永久有效
  全局:/etc/vimrc
  个人:~/.vimrc
扩展模式:当前vim进程有效
  (1) 行号
    显示:set number, 简写为set nu
    取消显示:set nonumber, 简写为set nonu
  (2) 忽略字符的大小写
    启用:set ic
    不忽略:set noic
  (3) 自动缩进
     启用:set ai
     禁用:set noai    (4)智能缩进
    启用:smartindent 简写 set si
    禁用:set nosi
  (5) 高亮搜索
    启用:set hlsearch
    禁用:set nohlsearch
  (6) 语法高亮
    启用:syntax on
    禁用:syntax off
  (7) 显示Tab和换行符 ^I 和$显示
    启用:set list
    禁用:set nolist   (8) 文件格式
    启用windows格式:set  fileformat=dos
    启用unix格式:set fileformat=unix
    简写: set ff=dos|unix
  (9) 设置文本宽度
    启用: set textwidth=65 (vim only)
    禁用: set wrapmargin=15
  (10) 设置光标所在行的标识线
    启用:set cursorline,简写cul
    禁用:set no cursorline
  (11) 复制保留格式
    启用: set paste
    禁用: set nopaste Set 帮助
  :help option-list 
  :set or :set all
vi/vim内置帮助 
  :help
  :help topic
  Use :q to exit help
vimtutor 练习 Linux安装包安装 rpm: RedHat Package Manager
   RPM  Package Manager 源代码:name-VERSION.tar.gz|bz2|xz
    VERSION: major.minor.release
rpm包命名方式:
  name-VERSION-release.arch.rpm
    例:bash-4.2.46-19.el7.x86_64.rpm
  VERSION: major.minor.release
  release:release.OS
  常见的arch:
    x86: i386, i486, i586, i686
    x86_64: x64, x86_64, amd64    
    跟平台无关:noarch 包:分类和拆包
  Application-VERSION-ARCH.rpm: 主包
  Application-devel-VERSION-ARCH.rpm 开发子包
  Application-utils-VERSION-ARHC.rpm 其它子包
  Application-libs-VERSION-ARHC.rpm 其它子包
包之间:可能存在依赖关系,甚至循环依赖
解决依赖包管理工具:
  yum:rpm包管理器的前端工具
  apt-get:deb包管理器前端工具
  zypper: SUSE上的rpm前端管理工具
  dnf: Fedora 18+ rpm包管理器前端管理工具 查看二进制程序所依赖的库文件
  ldd /PATH/TO/BINARY_FILE
管理及查看本机装载的库文件
  ldconfig 加载库文件
  /sbin/ldconfig -p: 显示本机已经缓存的所有可用库文件名及文件路径映射关系
配置文件:/etc/ld.so.conf, /etc/ld.so.conf.d/*.conf
缓存文件:/etc/ld.so.cache 程序包管理器:
  功能:将编译好的应用程序的各组成文件打包一个或几个程序包文件,从而方便快捷地实现程序包的安装、卸载、查询、升级和校验等管理操作
包文件组成 (每个包独有)
  RPM包内的文件
  RPM的元数据,如名称,版本,依赖性,描述等
  安装或卸载时运行的脚本
数据库(公共):/var/lib/rpm
  程序包名称及版本
  依赖关系
  功能说明
  包安装后生成的各文件路径及校验码信息 管理程序包的方式:
  使用包管理器:rpm
  使用前端工具:yum, dnf
获取程序包的途径:
  (1) 系统发版的光盘或官方的服务器;
    CentOS镜像:
    https://www.centos.org/download/
    http://mirrors.aliyun.com
    http://mirrors.sohu.com
    http://mirrors.163.com
 (2) 项目官方站点  (3) 第三方组织:
  Fedora-EPEL:
    Extra Packages for Enterprise Linux
  Rpmforge:RHEL推荐,包很全
  搜索引擎:
    http://pkgs.org
    http://rpmfind.net
    http://rpm.pbone.net
    https://sourceforge.net/
(4) 自己制作
  注意:第三方包建议要检查其合法性。    来源合法性,程序包的完整性  YUM: Yellowdog Update Modifier,rpm的前端程序,可解决软件包相关依赖性,可在多个库之间定位软件包,up2date的替代工具
  yum repository: yum repo,存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下)   yum客户端配置文件:
  /etc/yum.conf:为所有仓库提供公共配置
  /etc/yum.repos.d/*.repo:为仓库的指向提供配置
  仓库指向的定义:
    [repositoryID]
    name=Some name for this repository
    baseurl=url://path/to/repository/
    enabled={1|0}
    gpgcheck={1|0}
    gpgkey=URL
    enablegroups={1|0}
    failovermethod={roundrobin|priority}
      roundrobin:意为随机挑选,默认值
      priority:按顺序访问
    cost=   默认为1000 yum的repo配置文件中可用的变量:
  $releasever: 当前OS的发行版的主版本号
  $arch: 平台,i386,i486,i586,x86_64等
  $basearch:基础平台;i386, x86_64
  $YUM0-$YUM9:自定义变量
实例:
  http://server/centos/$releasever/$basearch/
  http://server/centos/7/x86_64
  http://server/centos/6/i384 阿里云repo文件:
  http://mirrors.aliyun.com/repo/
CentOS系统的yum源
  阿里云:https://mirrors.aliyun.com/centos/$releasever/os/x86_64/
EPEL的yum源: 
  阿里云: 
  https://mirrors.aliyun.com/epel/$releasever/x86_64
yum命令的用法:
    yum [options] [command] [package ...]
  显示仓库列表:
    yum repolist [all|enabled|disabled]
  显示程序包:
    yum list
    yum list [all | glob_exp1] [glob_exp2] [...]
    yum list {available|installed|updates} [glob_exp1] [...]
  安装程序包:
    yum install package1 [package2] [...]
    yum reinstall package1 [package2] [...]  (重新安装)   升级程序包:
    yum update [package1] [package2] [...]
    yum downgrade package1 [package2] [...] (降级)
  检查可用升级:
    yum check-update
  卸载程序包:
    yum remove | erase package1 [package2] [...]   查看程序包information:
    yum info [...]
  查看指定的特性(可以是某文件)是由哪个程序包所提供:
    yum provides | whatprovides feature1 [feature2] [...]
  清理本地缓存:
    清除/var/cache/yum/$basearch/$releasever缓存
    yum clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
  构建缓存:
    yum makecache 搜索:yum search string1 [string2] [...]
  以指定的关键字搜索程序包名及summary信息
查看指定包所依赖的capabilities:
  yum deplist package1 [package2] [...]
查看yum事务历史:
  yum history [info|list|packages-list|packages-info|
  summary|addon-info|redo|undo|
  rollback|new|sync|stats]
  yum history
  yum history info 6
  yum history undo 6 
日志 :/var/log/yum.log   安装及升级本地程序包:
    yum localinstall rpmfile1 [rpmfile2] [...]
       (用install替代)
    yum localupdate rpmfile1 [rpmfile2] [...]
      (用update替代)
  包组管理的相关命令:
    yum groupinstall group1 [group2] [...]
    yum groupupdate group1 [group2] [...]
    yum grouplist [hidden] [groupwildcard] [...]
    yum groupremove group1 [group2] [...]
    yum groupinfo group1 [...] yum的命令行选项:
  --nogpgcheck:禁止进行gpg check
  -y: 自动回答为“yes”
  -q:静默模式
  --disablerepo=repoidglob:临时禁用此处指定的repo
  --enablerepo=repoidglob:临时启用此处指定的repo
  --noplugins:禁用所有插件 linux学习交流群:690327559 参考资料:http://www.makeru.com.cn/