linux启动菜单修复1、在系统启动过程中 , 会出现图1所示画面,按任意键,进入GRUB菜单选项 。
2、按“e”键编辑GRUB引导菜单选项,图2显示为按“e”键后的GRUB屏幕 。
GRUB引导菜单选项
通过箭头键下移到kernel行 , 并按“e”键,得到图3中显示的编辑界面:
kernel行编辑界面
在尾行光标处添加single或者s,按回车键返回前一个屏幕,按“b”键进行引导,则系统自动进入单用户模式 , 如果要改变root密码,则执行命令:
sh-3.1# passwd root
更改成功后,执行命令exit退出重启即可 。
linux apt命令功能一、apt的简介
apt命令可以说是Linux系统下最为重要的命令,安装、更新、卸载软件,升级系统内核都离不开apt命令 。
apt的全称是Advanced Packaging Tool是Linux系统下的一款安装包管理工具 。
最初需要在Linux系统中安装软件,需要自行编译各类软件,缺乏一个统一管理软件包的工具 。此后当Debian系统出现后,dpkg管理工具也就被设计出来了,此后为了更加快捷、方便的安装各类软件,dpkg的前端工具APT也出现了 。在Ubuntu16.04系统下apt命令功能又得到了强化 , 使其更加方便快捷和受欢迎了 。
二、apt命令介绍
1.apt update
更新软件源中的所有软件列表 。因为更新数据库等操作需要管理员的权限,所以在apt命令前要加上sudo命令取得权限 。
运行apt update命令会返回三种状态:一是命中 , 一是获取,一是忽略 。
命中表示连接上网站,包的信息没有改变 。
获取表示有更新并且下载 。
忽略表示无更新或更新无关紧要无需更新 。
在命令显示的最后,会提示你有多少软件包可以升级,你可以根据自身的需求立即或稍后进行升级 。
2. apt list
apt list --upgradeable:显示可升级的软件包 。
apt list --installed:显示已安装的软件包 。
3.apt upgrade
执行完update命令后 , 就可以使用apt upgrade来升级软件包了 。执行命令后系统会提示有几个软件需要升级 。在得到你的同意后,系统即开始自动下载安装软件包 。
4. apt install 软件包名
安装指定软件 。此命令需管理员权限 。如果你对名字并不十分清楚,你可以输入软件名的一部分,系统会给出名字相近的软件包名的提示 。在老版本中安装程序需要使用 sudo apt-get install 软件包名 , 现在新版本中已建议直接使用apt替代apt-get命令 。
sudo apt install -f
使用此命令可修复依赖关系,假如有软件因依赖关系不满足而无法安装,就可以运行此命令自动修复安装程序包所依赖的包 。特别是在使用dpkg命令安装deb软件包时出现依赖问题常需要此命令来修复 。
5. apt remove 软件包名和apt autoremove
apt remove 软件包名用来卸载指定软件 。
apt autoremove用来自动清理不再使用的依赖和库文件 。
7.apt show 软件包名
显示软件包具体信息 。例如:版本号,安装大小,依赖关系,bug报告等等 。
Linux安装基本命令Linux安装基本命令大全
Linux常用命令linux修复安装命令,linux修复安装命令你还能记得多少呢?下文是linux修复安装命令我为大家准备linux修复安装命令的Linux常用命令 , 一起来看看吧!
安装升级
查看软件xxx安装内容
dpkg -L xxx
查找软件库中的软件
apt-cache search 正则表达式
或
aptitude search 软件包
显示系统安装包的统计信息
apt-cache stats
显示系统全部可用包的名称
apt-cache pkgnames
显示包的信息
apt-cache show k3b
查找文件属于哪个包
dpkg -S filename
apt-file search filename
查看已经安装了哪些包
dpkg -l
也可用
dpkg -l | less
翻页查看
查询软件xxx依赖哪些包
apt-cache depends xxx
查询软件xxx被哪些包依赖
apt-cache rdepends xxx
增加一个光盘源
sudo apt-cdrom add
系统更新
sudo apt-get update (这一步更新包列表)
sudo apt-get dist-upgrade (这一步安装所有可用更新)
或者
sudo apt-get upgrade (这一步安装应用程序更新 , 不安装新内核等)
清除所有已删除包的残馀配置文件
dpkg -l |grep ^rc|awk '{print $2}' |sudo xargs dpkg -P
如果报如下错误,证明你的系统中没有残留配置文件了,无须担心 。
----------------------------------------------------------
dpkg: --purge needs at least one package name argument
Type dpkg --help for help about installing and deinstalling packages [*];
Use `dselect' or `aptitude' for user-friendly package management;
Type dpkg -Dhelp for a list of dpkg debug flag values;
Type dpkg --force-help for a list of forcing options;
Type dpkg-deb --help for help about manipulating *.deb files;
Type dpkg --license for copyright license and lack of warranty (GNU GPL) [*].
Options marked [*] produce a lot of output - pipe it through `less' or `more' !
----------------------------------------------------------
编译时缺少h文件的自动处理
sudo auto-apt run ./configure
查看安装软件时下载包的临时存放目录
ls /var/cache/apt/archives
备份当前系统安装的所有包的列表
dpkg --get-selections | grep -v deinstall~/somefile
从上面备份的安装包的列表文件恢复所有包
dpkg --set-selections~/somefile
sudo dselect
清理旧版本的软件缓存
sudo apt-get autoclean
清理所有软件缓存
sudo apt-get clean
删除系统不再使用的孤立软件
sudo apt-get autoremove
如果使用
sudo apt-get autoremove --purge
的话会把这些孤立软件的残留配置文件也一并移除
查看包在服务器上面的地址
apt-get -qq --print-uris download 软件包名称 | cut -d\' -f2
彻底删除Gnome
sudo apt-get --purge remove liborbit2
彻底删除KDE
sudo apt-get --purge remove libqt3-mt libqtcore4
一键安装 LAMP 服务
sudo tasksel install lamp-server
删除旧内核
sudo aptitude purge ~ilinux-image-.*\(\!\(`uname -r`\|generic-.*\)\)
导入ppa源的'key值
#W: GPG签名验证错误:jaunty Release: 由于没有公钥,下列签名无法进行验证: NO_PUBKEY 5126890CDCC7AFE0
sudo apt-key adv --recv-keys --keyserver keyserver.ubuntu.com 5126890CDCC7AFE0 #5126890CDCC7AFE0替换为你需要导入的Key值
增加 add-apt-repository 命令
sudo apt-get install software-properties-common
增加一个ppa源
sudo add-apt-repository ppa:user/ppa-name
#使用 ppa 的地址替换 ppa:user/ppa-name
添加163镜像源
sudo add-apt-repository "deb`lsb_release -cs` main restricted universe multiverse"
sudo add-apt-repository "deb`lsb_release -cs`-updates main restricted universe multiverse"
sudo add-apt-repository "deb`lsb_release -cs`-security main restricted universe multiverse"
系统升级
1 这里指的是版本间的升级 , 例如 9.04=10.04 。
2 使用该升级方式通常需要使用 backports 源 。
sudo apt-get update
sudo apt-get install update-manager-core
sudo do-release-upgrade
系统
查看内核
uname -a
查看系统是32位还是64位
#查看long的位数,返回32或64
getconf LONG_BIT
#查看文件信息,包含32-bit就是32位 , 包含64-bit就是64位
file /sbin/init
或者使用
uname -m
查看Ubuntu版本
lsb_release -a
或 cat /etc/lsb-release
查看内核加载的模块
lsmod
查看PCI设备
lspci
查看USB设备
lsusb
#加参数 -v 可以显示USB设备的描述表(descriptors)
lsusb -v
查看网卡状态
sudo apt-get install ethtool
sudo ethtool eth0
激活网卡的 Wake-on-LAN
sudo apt-get install wakeonlan
或 sudo ethtool -s eth0 wol g
查看CPU信息
cat /proc/cpuinfo
显示当前硬件信息
sudo lshw
查看内存型号
sudo dmidecode -t memory
获取CPU序列号或者主板序列号
#CPU ID
sudo dmidecode -t 4 | grep ID
#Serial Number
sudo dmidecode | grep Serial
#CPU
sudo dmidecode -t 4
#BIOS
sudo dmidecode -t 0
#主板:
sudo dmidecode -t 2
#OEM:
sudo dmidecode -t 11
显示当前内存大小
free -m |grep "Mem" | awk '{print $2}'
查看硬盘温度
sudo apt-get install hddtemp
sudo hddtemp /dev/sda
显示系统运行时间
uptime
查看系统限制
ulimit -a
查看内核限制
ipcs -l
查看当前屏幕分辨率
xrandr
硬盘
查看块设备
lsblk
查看硬盘的分区
sudo fdisk -l
硬盘分区
#危险!小心操作 。
sudo fdisk /dev/sda
硬盘格式化
#危险!将第一个分区格式化为 ext3 分区, mkfs.reiserfs mkfs.xfs mkfs.vfat
sudo mkfs.ext3 /dev/sda1
硬盘检查
#危险!检查第一个分区,请不要检查已经挂载的分区,否则容易丢失和损坏数据
sudo fsck /dev/sda1
硬盘坏道检测
sudo badblocks -s -v -c 32 /dev/sdb
#得到坏的块后,使用分区工具隔离坏道 。
分区挂载
sudo mount -t 文件系统类型 设备路经 访问路经
#常用文件类型如下: iso9660 光驱文件系统, vfat fat/fat32分区, ntfs ntfs分区, smbfs windows网络共享目录, reiserfs、ext3、xfs Linux分区
#如果中文名无法显示尝试在最後增加 -o nls=utf8 或 -o iocharset=utf8
#如果需要挂载後,普通用户也可以使用,在 -o 的参数後面增加 ,umask=022 如:-o nls=utf8,umask=022
分区卸载
sudo umount 目录名或设备名
只读挂载ntfs分区
sudo mount -t ntfs -o nls=utf8,umask=0 /dev/sdb1 /mnt/c
可写挂载ntfs分区
sudo mount -t ntfs-3g -o locale=zh_CN.utf8,umask=0 /dev/sdb1 /mnt/c
挂载fat32分区
sudo mount -t vfat -o iocharset=utf8,umask=0 /dev/sda1 /mnt/c
挂载共享文件
sudo mount -t smbfs -o username=xxx,password=xxx,iocharset=utf8 //192.168.1.1/share /mnt/share
挂载ISO文件
sudo mount -t iso9660 -o loop,utf8 xxx.iso /mnt/iso
查看IDE硬盘信息
sudo hdparm -i /dev/sda
查看软raid阵列信息
cat /proc/mdstat
参看硬raid阵列信息
dmesg |grep -i raid
cat /proc/scsi/scsi
查看SATA硬盘信息
sudo hdparm -I /dev/sda
或
sudo apt-get install blktool
sudo blktool /dev/sda id
查看硬盘剩余空间
df
df --help 显示帮助
查看目录占用空间
du -hs 目录名
闪盘没法卸载
sync
fuser -km /media/闪盘卷标
使用文件来增加交换空间
#创建一个512M的交换文件 /swapfile
sudo dd if=/dev/zero of=/swapfile bs=1M count=512
sudo mkswap /swapfile
sudo swapon /swapfile
#sudo vim /etc/fstab #加到fstab文件中让系统引导时自动启动
/swapfile swap swap defaults 0 0
查看硬盘当前读写情况
# 首先安装 sysstat 包
sudo apt-get install sysstat
#每2秒刷新一次
sudo iostat -x 2
测试硬盘的实际写入速度
dd if=/dev/zero of=test bs=64k count=512 oflag=dsync
进程
查看当前的内存使用情况
free
连续监视内存使用情况
watch -d free
# 使用 Ctrlc 退出
动态显示进程执行情况
top
top指令运行时输入H或?打开帮助窗口,输入Q退出指令 。
查看当前有哪些进程
ps -AFL
查看进程的启动时间
ps -A -opid,stime,etime,args
查看目前登入用户运行的程序
w
查看当前用户程序实际内存占用,并排序
ps -u $USER -o pid,rss,cmd --sort -rss
统计程序的内存耗用
ps -eo fname,rss|awk '{arr[$1] =$2} END {for (i in arr) {print i,arr[i]}}'|sort -k2 -nr
按内存从大到小排列进程
ps -eo "%C : %p : %z : %a"|sort -k5 -nr
列出前十个最耗内存的进程
ps aux | sort -nk4 | tail
按cpu利用率从大到小排列进程
ps -eo "%C : %p : %z : %a"|sort -nr
ps aux --sort -pcpu |head -n 20
查看当前进程树
pstree
中止一个进程
kill 进程号(就是ps -A中的第一列的数字)
或者 killall 进程名
强制中止一个进程(在上面进程中止不成功的时候使用)
kill -9 进程号
或者 killall -9 进程名
图形方式中止一个程序
xkill 出现骷髅标志的鼠标,点击需要中止的程序即可
查看进程打开的文件
lsof -p 进程的pid
显示开启文件abc.txt的进程
lsof abc.txt
显示22端口现在运行什么程序
lsof -i :22
显示nsd进程现在打开的文件
lsof -c nsd
在後台运行程序,退出登录後,并不结束程序
nohup 程序
#查看中间运行情况 tail nohup
在后台运行交互式程序 , 退出登录后,并不结束程序
sudo apt-get install screen
screen vim a.txt
#直接退出后使用
screen -ls # 2208pxs-0.ubuntu (Detached)
screen -r 1656 #恢复
#热键,同时按下Ctrl和a键结束后 , 再按下功能键
C-a ? #显示所有键绑定信息
C-a w #显示所有窗口列表
C-a C-a #切换到之前显示的窗口
C-a c #创建一个新的运行shell的窗口并切换到该窗口
C-a n #切换到下一个窗口
C-a p #切换到前一个窗口(与C-a n相对)
C-a 0..9 #切换到窗口0..9
C-a a #发送 C-a到当前窗口
C-a d #暂时断开screen会话
C-a k #杀掉当前窗口
在后台运行交互式程序,退出登录后 , 并不结束程序
tmux 进入后再运行其它命令
tmux attach #恢复
#热键 , 同时按下Ctrl和b键结束后,再按下功能键
C-b c #创建一个新的运行shell的窗口并切换到该窗口
C-b n #切换到下一个窗口
C-b p #切换到前一个窗口(与C-a n相对)
C-b 0..9 #切换到窗口0..9
C-b d #暂时断开会话
C-b#杀掉当前窗口
详细显示程序的运行信息
strace -f -F -o outfile
增加系统最大打开文件个数
#ulimit -SHn
sudo vim /etc/security/limits.conf
文件尾追加
* hard nofile 4096
* soft nofile 4096
sudo vim /etc/pam.d/su
将 pam_limits.so 这一行注释去掉
重起系统
清除僵尸进程
ps -eal | awk '{ if ($2 == "Z") {print $4}}' | xargs sudo kill -9
将大于120M内存的php-cgi都杀掉
ps -eo pid,fname,rss|grep php-cgi|grep -v grep|awk '{if($3=120000) print $1}' | xargs sudo kill -9
Linux系统中如何限制用户进程CPU占用率
renice10 `ps aux | awk '{ if ($30.8id -u $1500) print $2}'`
#或直接编辑/etc/security/limits.conf文件 。;
Linux系统恢复10个方法 Linux系统恢复10个方法
在Linux中有一些应用程序可以帮助你保存系统快照 。大多数应用程序都是针对于新手的 , 并不需要高级的Linux操作技巧 。我们在这里挑选了10个 , 你可以从中选择适合自己的应用 。
Windows中的系统恢复功能
Windows家族最初的系统恢复功能要回溯到2000年的Windows ME版本,当时还只能恢复系统文件和注册表,而且并不稳定 。在Windows XP和Vista中系统恢复的性能得到了很大的提高 。也是从那时起,系统恢复开始依赖于一个叫做硬盘快照服务(Volume Snapshot Service)的系统服务功能,能够自动创建系统快照–包括正在使用的文件–然后将这些文件转换为可恢复的节点文件 。
新的方式给用户提供了更多的自定义功能 , 比如用户可以为快照分配磁盘空间,可以选择监视哪些文件目录等等 。但是还是有很多的限制,比如只有NTFS格式的分区具有系统恢复快照功能 , 而且在Windows 8版本之前 , 快照并不能长期保存 。
Windows的每次版本更新都带来了混乱,比如Vista的家庭版中没有提供恢复从前的系统快照的用户界面,而Windows 8出现了不兼容之前版本的系统快照的问题,最终Windows 10索性禁用了系统恢复功能,让用户手动启用与操作,这么看起来这项决定是有意而为 。
好了 , 不再说关于Windows的事了,还是来看看在Linux中我们应该怎么做吧!
Linux系统恢复的工作原理是什么
呃,实际上这并不是一项系统功能,至少不应该在名字里带上“系统”这两个字,因为你不会在任何一个Linux系统发行版的系统菜单中找到所谓的系统恢复(System Restore)功能 。你要做的是找到一个合适的应用程序并安装才可以 。绝大多数的系统恢复应用程序和Windows中系统恢复功能的工作原理是相同的,在特定的时间节点为你的系统创建快照文件,然后在系统出现问题的时候,允许你回滚到选定的时间点 。
在介绍这些应用程序之前,让我们先简单的了解一下系统快照究竟是什么?
系统快照与备份的区别
抛开这两者的名字不同,总的来说 , 备份(Backup)是指将文件复制出一份副本并且保存到另一个位置 。备份很少会将整个磁盘备份,那样做通常是叫做磁盘镜像或者是磁盘克?。庵掷嘈偷谋阜菔导噬鲜嵌哉龃排套隽艘桓鼍迪瘢ㄓ没荩僮飨低常舳智鹊?。磁盘镜像可以被用在裸机恢复工作中 。这时候你就可以在不需要安装操作系统情况下,将一块硬盘的全部内容复制到另一台电脑上 。
而系统快照(Snapshot)则是在特定的时间节点上保存文件系统的状态 , 并且保存在与文件系统相同的存储设备上 。通常系统快照中会包含所有的目录与文件信息,或者至少是保存了操作系统所需要的文件信息 。
将快照和文件系统保存在同一个位置就实现了回滚的可能性,同样也有利于节省磁盘空间 。在这种情况下,每新建一个系统快照并不需要将整个文件系统的状态全部保存下来 。形象地说,系统快照就像是一个不断增长的备份过程,每次只是保存和上次不同的信息变化,这也就意味着每一个系统快照都要依赖于上一次系统快照,这样才能完全完成系统恢复工作 。而与之相反的是,一个完整的磁盘备份或者是磁盘镜像则与其他的备份文件相互独立,可以单独完成系统恢复工作 。
系统快照可能会碰到的问题是它们对于硬盘故障非常的脆弱 。如果你的硬盘受到了严重的物理损伤,那么很可能你的系统快照就无法帮助你恢复系统了 。为了防止这一点,我们建议在安装与设置好你的Linux系统之后立即做一份系统快照,然后把它单独复制到另外的存储设备中 。
保存系统快照
在Linux中有一些应用程序可以帮助你保存系统快照 。大多数应用程序都是针对于新手的,并不需要高级的Linux操作技巧 。我们在这里挑选了一些 , 你可以从中选择适合自己的应用 。
TimeShift
TimeShift提供了一个非常简洁的图形用户界面,你也可以直接在终端输入命令使用它 。默认情况下 。TimeShift并不会包含用户的个人文件,但你可以通过自定义将特殊的目录添加到快照中去 。Ubuntu及其分支的用户可以从开发者的PPA获取TimeShift:
sudo apt-add-repository ppa:teejee2008/ppa
sudo apt-get update
sudo apt-get install timeshift
其他版本的用户可以下载安装文件并在命令行终端运行:
./timeshift-latest-amd.64.run
TimeShift还提供了专门针对BTRFS文件系统的版本,可以支持原生的BTRFS系统快照功能 。
工作方式
TimeShift能够帮助你随时完成快照工作,或者你也可以设置让TimeShift自动创建快照 。你可以安排任务计划 , 每小时、每天、每周或者每个月进行快照,也可以设置清除这些快照的时间 。TimeShift有一个特殊的选项叫做重启快照,用来在每次系统重启之后创建一个新的快照文件 。
TimeShift从快照中进行系统恢复是一项非常简单直接的工作,只要选择快照文件并且告诉它应该存储的位置就可以了 。TimeShift提供了将快照恢复到外设的选项,克隆功能能够直接将现有系统状态复制到另一个设备中,这在将你的操作系统迁移到另一台新电脑时非常方便,因为你不再需要从头开始安装各种功能和应用 。
在恢复快照之前,TimeShift会询问你是不是需要保存现有的应用设置,并且让你选择保存哪一个 。请记住TimeShift需要GRUB 2启动进入快照恢复 。
cronopete
如果你认为TimeShift的操作已经足够简单的话,那么Cronopete甚至更加简单,至少从外观上看来是这样的 。Cronopete自称为OS X的时间机器,与TimeShift工作起来稍有不同 。Cronopete为Ubuntu,Debian和Fedora提供了包文件,Arch Linux使用者可以在AUR中找到它 。
工作方式
与本文中介绍的其他应用程序不同,Cronopete将备份与快照功能捆绑在一起,并且要求你将快照保存在外部设备上 。默认情况下,它会每个小时都检查一遍你的文件变化,但是当然可以在设置中改变这个时间间隔 。如果某个文件并没有发生变化,那么Cronopete将对这个文件只进行一个硬链接而并不复制这份文件,这会帮助节省磁盘空间 。
Cronopete的文件恢复可能是它最酷的功能,好像真的能帮助你“穿越时间”,也就是说,可视化的浏览所有储存版本的文件与文件夹 。想要恢复哪一个文件,只需要选上它,然后点击恢复就可以了,这个文件就会从外部的存储设备中复制到你现有的`系统中来 。当然这里你可能也猜测到了,Cronopete对于全系统恢复并不十分具有意义,但是如果你想要保存单独文件的多个版本,那么它是一个很好的选择 。
Back In Time
Back In Time的用户界面看起来非常友好 , 能够吸引住Linux新手 。它的设置对话框中提供了非常精细的操作控件,用户界面看上去就像是一个文件管理器一样,在这里你可以阅览所有的快照,浏览快照中的文件,以及恢复选定的文件与文件夹 。
Ubuntu用户可以从PPA中安装Back In Time:
sudo add-apt-repository ppa:bit-team/stable
sudo apt-get update
sudo apt-get install backintime-qt4
有些发行版会在自己的资源库中提供Back In Time,如果你的发行版没有的话,也总可以在网上找到源代码并且下载安装 。
工作方式
Back In Time会对那些你选择的目录创建快照,但是只会恢复那些拥有写权限的目录 。你可以对快照进行加密并且存储在网络设备、外部硬盘或者是本地的文件系统中 。Back In Time只会对那些改变过的文件进行更新 。在设置选项标签中,你可以选择在没有变化发生的时候禁用快照 。
Back In Time的快照时间根据计划设定,每天、每周、每个月或者是每天的某个或某几个时间段 , 或者是每次重启之后 。你可以在主工具栏的菜单中自己更改计划时间 。
与Cronopete相似,Back In Time更加适合于基于文件夹或者是基于文件的回滚操作,但是如果你想对整个文件系统进行回滚也是同样可行的 。恢复一个快照相当简单,只要选择它,并且选择在哪里进行恢复就可以了 , 取决于你是只想恢复几个文件夹还是对整个系统进行恢复 。
Systemback
Systemback的界面很小巧,但是功能却非常强大 。但不幸的是只有Debian和Ubuntu及其分支的用户可以使用,而没有提供其他Linux发行版的安装文件 。Systemback可以通过开发者PPA安装:
sudo add-apt-repository ppa:nemh/systemback
sudo apt-get update
sudo apt-get install systemback
工作方式
Systemback并不仅仅是另一个快照工具 。它可以把你现在的系统转变为一张live CD或DVD , 这样就可以直接在另一台电脑上启动了 。它可以修复或重装GRUB 2启动器以及修复fstab文件,当然,Systemback的主要用途还是用于系统快照 。
Systemback将快照的总数量限制在10个以内 。用户拥有删除快照的权限 。快照的功能可以选择为递增,也就是只复制被改变过的文件 , 而将其他的文件以硬链接的形式保存 。但是在设置对话框中,你可以禁用这个功能 。在恢复文件的时候 , 你可以选择执行全系统恢复,或者只是复制关键的系统文件 。个人数据比如照片与文档并不会被包含在快照中,但是你可以在创建包含用户数据的选项中通过自定义操作将它们转移到live CD中 。
Systemback允许用户自定义自动快照的计划 , 但你也将这个选项关闭来手动设置恢复点 。需要注意的是Systemback并不支持NTFS文件系统,因此不能对NTFS系统分区进行快照或者是恢复操作 。
Snapper
Snapper和openSUSE的关系非常密切 。在其他Linux版本上也许能够安装Snapper,但是并不一定能正常工作了 。在openSUSE中安装Snapper的最简单方法是将它安装在BTRFS分区上,这样做Snapper就能够自动安装与配置 。你可以使用命令行工具来操作Snapper,或者通过YaST工具,此外还有另一种替代方案snapper-GUI 。
工作方式
Snapper能够创建几种不同类型的快照,比如在安装新的应用程序之前与之后创建快照 。通过这种方式你可以将快照进行对比,并且更有效的进行系统恢复 。Snapper会为快照自动建立时间计划,你当然也可以把这个功能禁用掉 。在Snapper中,快照是存放在与系统相同的分区中 , 因此它们会不断长大 , 要记得随时检查自己的硬盘容量 。
默认情况下,Snapper只对根分区创建快照 。如果想要包含其他分区和BTRFS副磁盘卷,你就需要为每一个项目创建一个配置,这必须在命令行终端中完成,你需要以root权限运行下面的命令:
snapper -c CONFIGNAME create-config /PATH
在这里-c代表着配置“configure”,CONFIGNAME是你为这个配置所取的名称,/PATH则是分区或是副磁盘卷的位置 , 例如:
snapper -c home create-config /home
你可以用下面的命令查看当前的配置:
snapper list-configs
所有的配置文件都保存在/etc/snapper/configs目录 。在这里,你可以用一个常用的文本编辑器来修改它们 , 例如你可以禁用每小时创建快照的功能 , 启用自动删除快照的功能 , 手动设置可保存旧快照的数量 。
在YaST Snapper模式中,你可以创建并对比快照进行系统回滚操作 , 或者将一个文件或者其他一些被选择的文件恢复到以前的版本 。
怎样备份与恢复已安装的应用程序
了解了怎样对整个操作系统进行恢复之后,你可能想知道怎样恢复那些已经安装的应用软件 。这在系统新版升级或重装系统的情况下很常见 。幸运的是已经有一些工具提供了应用程序迁移的功能,而且使用起来非常方便 。
Aptik
首先我要提到的是Aptik,它是由TimeShift的开发者创建的应用程序备份工具 。
Aptik只能用于基于Ubuntu的发行版,你可以直接从开发者PPA安装:
sudo apt-add-repository ppa:teejee2008/ppa
sudo apt-get update
sudo apt-get install aptik
Aptik能够以列表的形式输出系统现有的已安装的包以及所使用的库以及下载的包文件 。此外还有用于导出应用程序设置、桌面主题和图标集的选项 。Aptik会根据安装类型对这些包进行分类,例如分为操作系统预装、用户自主安装、自动安装的依赖与从.deb文件安装等等 。对于.deb文件你可以将它们拖拽到列表中并且包含在备份文件里 。备份可以保存在任何位置,如果想把它们提取到一个新安装的发行版中 , 只需要先安装Aptik,然后在主窗口中选择备份并进行恢复即可 。
Linux Mint
Linux Mint的用户可以选择Mint备份工具,功能几乎与Aptik一模一样 。除了恢复已安装的应用程序之外,这个工具还可以对所选定的文件夹及其权限执行快速备份 。
Arch Linux
Arch Linux的用户可以使用Backpac来备份与恢复应用程序 。Backpac可以建立手动安装包的列表文件,也可以按照你的选择单独备份文件 。使用Backpac恢复系统状态会重新安装所输出的包,删除掉快照中并不包含的文件 , 并且会用之前输出的版本覆盖系统文件 。
dpkg
当然 , 你可以不使用任何一个第三方工具来完成这样的操作 。在包管理系统中提供了这样的工具 。在基于dpkg的系统中,你可以使用下面的操作来输出一个已安装应用的列表文件:
dpkg --get-selections/home/yourusername/apps.txt
然后 , 将这个txt文件与库信息从/etc/apt/sources.d/目录与/etc/apt/sources.list文件复制到新的系统中 。使用如下命令行并提供正确的文件路径就可以将备份的应用迁移到新的系统中:
dpkg --set-selections/path/to/apps.txt
sudo apt-get update
sudo apt-get dselect-upgrade
有些图形化的包管理工具例如Synaptic能够提供图形化的用户界面 , 用来输出与导入已经安装的应用程序的列表 , 不需要使用终端命令行的形式来操作 。
高级系统回滚解决方案
如果上面建议的这些应用你并不认为合适,那么我们还有其他的解决方案 。我在这里将它们称为“高级”并不意味着这些方案非常复杂,而是说它们可能并不是新手用户的第一选择 。
Rsnapshot
如果你想在命令行终端使用一种极简而快速的方法进行快照操作,那么可以试一下Rsnapshot 。你可以在绝大多数Linux发行版的资源库中找到它 。Rsnapshot的所有设置都在/etc/rsnapshot.conf这个文件中 。你可以打开这个文件 , 自定义快照时间表,设置何时删除旧的快照,以及需要包含哪些文件与文件夹 。当你设置完毕之后,最好使用下面两个命令来做一下测试:
rsnapshot configtest
rsnapshot -t hourly
这样可以保证你的所有设置都正常启用 。请记住修改设置文件时需要在两个功能选项中使用一个tab符进行分割而并不是空格,因此不要用空格键移动这些参数 。Rsnapshot没有自动恢复功能 , 所以你只能从选定的快照中手动复制文件 。
Obnam
Obnam与Rsnapshot非常相似 , 另外还提供了一些有趣的功能 。它可以先创建一个全系统备份,然后逐渐生成包含新的或是改变过的文件的快照 。你可以对快照进行加密与自动解密 。Obnam在进行系统恢复时的操作也是相似的,提供命令,并且让你选择存储的位置 。
你可以设置或是修改自定义路径,将快照存放在服务器上或者是其他远程设备上 。Obnam提供的官方手册是一项很了不起的工作 , 清楚的解释了所有的功能操作 。
LVM Snapshots
如果系统中将会存放一些重要的数据,那么一定要事先考虑好备份与恢复的方法 。如果你正在安装与设置Linux系统的话,那么值得考虑将LVM(Logical Volume Manager)作为硬盘的管理工具 。
准确的说 , LVM并不算是一个应用程序,它在Linux内核中提供了内置的快照功能,可以将快照安装到任何其他磁盘或分区,合并若干个快照,并还原它们来解决系统问题 。或者你可以使用Linux内核模块dattobd支持对运行中的系统进行增量快照,这样无需卸载分区或重新启动计算机 。
总结
正如你所看到的,有很多种选择可以在Linux中获得系统恢复功能,然而你会发现它们在技术上是非常相似的,那么有没有更好的方法来代替现有的系统恢复功能呢?也许在未来随着这些应用程序的不断发展将会出现更好的方法,或者是对这些现有的工具更有效的进行组合应用,这些都需要使用者们不断进行探索发掘 。
;
【linux修复安装命令 linux系统怎么修复】关于linux修复安装命令和linux系统怎么修复的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。
推荐阅读
- php客户端请求数据库,php实现数据库连接
- 手机赛车游戏图片,手机赛车游戏图片壁纸
- 电视盒子网络代理设置方法,电视盒子的网络设置
- 关于windows怎么查系统的信息
- html5基础知识个人小结,html5语言基础
- 乐华通用安卓主板刷机,乐华电视主板怎么刷程序
- 制作什么王者视频会火,做王者视频的软件
- php查询跨数据库 php查询sqlserver数据库
- ios应用开发转做游戏,苹果手机游戏开发软件