一、软件源维护

1. 基本操作

(1)查看源列表

sudo vim /etc/apt/sources.list
  • deb:二进制软件安装包
  • deb-src:源码包

(2)备份软件源列表

sudo cp /etc/apt/source.list /etc/apt/backup_source.list

(3)更新源

sudo apt-get update

(4)升级源

sudo apt-get upgrade

(5)通过关键字查找安装包

sudo apt-cache search [软件名]

(6)安装软件

sudo apt-get install [软件名]

(7)卸载软件

sudo apt-get remove [软件名]

(8)升级软件

sudo apt-get -u install [软件名]

(9)从指定网址下载deb包

wget [网址/xxx.deb]

2. 常见问题:通过终端安装程序sudo apt-get install xxx时出错

错误提示:

E: Could not get lock /var/lib/dpkg/lock - open (11: Resource temporarily unavailable)
E: Unable to lock the administration directory (/var/lib/dpkg/), is another process using it

错误原因:

  • 可能是有另外一个程序正在运行,导致资源被锁不可用。
  • 资源被锁的原因可能是上次运行安装或更新时没有正常完成。

解决:

sudo rm /var/cache/apt/archives/lock
sudo rm /var/lib/dpkg/lock

二、Linux权限管理

1. 文件权限

(1)查看权限

ls -l

(2)9bit:权限管理相关

图片来源:Linux及安全——Linux基础实践

  • 文件类型
    • “-”表示普通文件。
    • “d”表示目录文件。
    • “l”表示链接文件。
    • “c”表示字符设备。
    • “b”表示块设备。
    • “p”表示命名管道,比如FIFO文件(先进先出)。
    • “f”表示堆栈文件,比如LIFO(后进先出)。
    • “s”表示套接字。
  • 属主权限:文件拥有者(u)对该文件的权限。
  • 属组权限:文件用户组(g)对该文件的权限。
  • 其它用户权限:系统其他用户(o)对该文件的权限。

(3)更改文件权限方法一

chmod [对象] [操作] [权限] [文件/目录名]
  • 对象:
    • u:表示文件所有者
    • g:表示同组用户
    • o:表示其它用户
    • a:表示所有用户
  • 操作:
    • +:添加某个权限
    • -:取消某个权限
    • =:赋予给定的权限,并取消原有的权限
  • 权限:
    • r:可读
    • w:可写
    • x:可执行

(4)更改文件权限方法二

chmod [_ _ _] [文件/目录名]
  • 将 r w x 看成二进制数,如果有则有1表示,没有则有0表示
  • 例:文件权限为最高权限 rwx rwx rwx,二进制表示为 111 111 111,换算后为 777,所以命令为 chmod 777 [文件/目录名]

(5)改变文件拥有者和群组

chown [选项] [所有者]:[组] [文件]
  • 选项
    • -c 显示更改的部分的信息
    • -f 忽略错误信息
    • -h 修复符号链接
    • -R 处理指定目录以及其子目录下的所有文件
    • -v 显示详细的处理信息
    • -deference 作用于符号链接的指向,而不是链接文件本身

2. 用户与用户组

(1)切换到root

sudo su

(2)切换到其它用户

su [用户名]

(3)创建用户

adduser [用户名]
useradd [用户名]
  • 在root权限下,useradd只是创建了一个用户名,它并没有在/home目录下创建同名文件夹,也没有创建密码,因此利用这个用户登录系统,是登录不了的。
  • 可以用 useradd -m [用户名] 的方式创建,它会在/home目录下创建同名文件夹,然后用 passwd [用户名] 为指定的用户名设置密码。
  • adduser创建新用户会在/home目录下会自动创建同名文件夹。
  • 系统会在 /etc/passwd 文件中增添了一行记录。

(4)删除用户

adddel

(5)创建用户组

groupadd [组名]

(6)查看用户组

grep [组名] /etc/group

(7)删除用户组

groupdel [组名]

(8)修改用户组

sudo usermod -g [用户] [用户组]
  • 如果用户已经是其他组的成员,需要添加 -a 这个选项

3. 开机脚本

(1)修改开机脚本

sudo vim /etc/init/rc-sysinit.conf
  • 其中有一行 env DEFAULT_RUNLEVEL指系统当前启动后运行级别

(2)Ubuntu的runlevel级别定义

0 – Halt,关机模式。不能将系统缺省运行级别设置为0,否则无法启动。
1 – Single,单用户模式。
2 - Full multi-user with display manager (GUI)。
3 - Full multi-user with display manager (GUI)。
4 - Full multi-user with display manager (GUI)。
5 - Full multi-user with display manager (GUI)。
6 – Reboot,重启。不能将系统缺省运行级别设置为6,否则会一直重启。
  • 2~5级是没有任何区别的。他们为多用户模式

(3)开机脚本使用原理

  • init进程就会读取这个系统运行级别设置,然后运行 /etc/rc.d/rc 脚本。
  • 通过这个脚本,然后进入rcx.d。启动相应的程序。其中 rcx.d为/etc/rc.d/rcx.d(x为对应的系统运行级别)。
  • /etc/rc.d/rcx.d/ 下的文件均为符号链接,最终绝大部分都是都是链接到 /etc/rc.d/init.d 下面。
  • /etc/rc.d/init.d 目录下面的都是开启启动脚本文件,用来启动相应的程序。
  • 在rcN.d中,对于以K开头的文件,系统将终止对应的服务;对于以S开头的文件,系统将启动对应的服务。

(4)修改某开机启动服务为开机终止服务

sudo mv Sxxgdm Kxxgdm

(5)删除某开机自启动文件

sudo update-rc.d –f xxx remove(其中xxx是文件名中除了S和K以外的非数字部分)

(6)写一个开机脚本并添加

  • 在/etc/init.d文件夹下编写一个新的脚本文件xx.sh
  • sudo chmod 给脚本文档设置权限。
  • 将脚本的路径写入 /etc/init.d/rc.local中。
  • sudo update-rc.d xx.sh defaults [启动顺序]

4. 环境变量

  • PATH决定了shell将到哪些目录中寻找命令或程序。

(1)临时修改环境变量

export PATH=$PATH:[目录]
  • 每当登出或注销系统以后,PATH 设置就会失效

(2)修改环境变量

vim /etc/profile 
  • 在文件中添加PATH="目录:$PATH"

source /etc/profile
  • 新PATH立即生效

5. 常见问题:新建用户后,新用户无法使用sudo的解决方法

错误提示:

xxx is not in the sudoers file.This incident will be reported.

错误原因:

  • 执行sudo命令的用户不在sudoers文件的列表中。

解决方法:

  • 在原用户中切换到root下:

      sudo su
    
  • 添加sudo文件的写权限:

      chmod u+w /etc/sudoers
    
  • 编辑/etc/sudoers文件:

    找到 root ALL=(ALL) ALL
    在下面添加 [新用户名] ALL=(ALL) ALL

  • 退出的时候撤销sudoers文件写权限

    chmod u-w /etc/sudoers


参考资料

参考资料1:Linux及安全——Linux基础实践
参考资料2:实践一:Linux基础实践
参考资料3:deb包构建手册
参考资料4:ubuntu常见错误--Could not get lock /var/lib/dpkg/lock解决
参考资料5:每天一个linux命令目录
参考资料6:深入理解linux下rc.d/目录文件以及程序开机自启动
参考资料7:xxx is not in the sudoers file.This incident will be reported.的解决方法