包含snaolinux命令的词条

linux环境下snap函数怎样实现摄像头的拍照功能

工具/原料

创新互联公司专注于岚县网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供岚县营销型网站建设,岚县网站制作、岚县网页设计、岚县网站官网定制、微信平台小程序开发服务,打造岚县网络公司原创品牌,更为您提供岚县网站排名全网营销落地服务。

ubuntu /linux 系统,联网

方法/步骤

cheese的安装非常简单,只需要在命令行中输入$sudo apt-get install cheese 即可自动安装。

cheese的界面也挺简洁,如下图所示,其可实现拍照、连拍、录像等功能。

当然cheese也可以给自己的照片添加不同的效果,像功夫、增加饱和度、凸出、扭曲……你可以尝试一下,哈哈。

步骤阅读

END

注意事项

卸载程序命令:$sudo apt-get remove cheese

linux上的rsync命令详解

rsync 就是远程同步的意思remote sync.

rsync 被用在UNIX / Linux执行备份操作操作.

rsync 工具包被用来从一个位置到另一个位置高效地同步文件和文件夹. rsync可以实现在同一台机器的不同文件直接备份,也可以跨服务器备份.

rsync 语法如下

从语法结构我们可以看出, 源和目标即可以在本地也可以在远端. 如果是远端的话,需要指明登录用户名, 远端服务器名, 和远端文件或目录. 同时源可以是多个, 目标位置只能是一个.

说明:

-z: --compress 使用压缩机制

-v: --verbose 打印详细信息

-r: --recursive 以递归模式同步子目录

注意: 同步完成后, 我们会发现文件的时间戳timestamps发生了改变.

有时我们希望拷贝或同步时, 时间戳不要发生变化, 源文件是什么时间戳,目标文件就是什么时间戳, 这时我们需要使用 -a --archive 归档模式选项. -a 选项相当于7个选项的组合 -rlptgoD

-r, --recursive: 递归模式Recursive mode

-l, --links: 将符号链接当作符号链接文件拷贝, 不拷贝符合链接指向的文件内容.

-p, --perms: 保留文件权限

-t, --times: 保留修改时间戳

-g, --group: 保留用户组信息

-o, --owner: 保留用户信息(需要超级用户权限)

-D, 相当于 --devices --specials 的组合, 保留设备文件, 保留特殊文件.

同步完成后, 我们再来看文件属性, 时间戳信息得到了保留, 不仅如此文件的所有者 和所在组也得到保留.

说明: Pubkeys 是一个普通文件

使用rsync, 也可以从本地拷贝多个文件或目录到远端, 以下即为示例:

注意:

与本地文件拷贝不同的地方在于, 当拷贝文件到远程服务器时, 我们指定远程主机上的用户名, 服务器地址, 路径等信息, 类是于使用scp命令拷贝, 如果没有设置ssh免密码登录我们还需要提供远程用户的密码等信息.有时你不想频繁输入密码, 或者rsync运行在一个无人执守的脚本里面, 这是需要预先设置ssh免密登录, 或者使用结合expect命令,自动输入密码, 但是出于安全考虑, 密码需要加密. 所以在条件许可的情况下, 还是推荐设置ssh免密登录.

与示例 4 稍有不同, 这时远端目录或文件作为源位置, 本地目录或文件作为目标位置, 示例如下:

rsync 允许指定远程主机上运行shell命令.

这时需要使用 -e 选项:

-e, --rsh=COMMAND 指定远端使用的shell命令

Use rsync -e ssh to specify which remote shell to use. In this case, rsync will use ssh.

在一下特殊的使用场景中, 我们不希望拷贝文件时, 我们不希望拷贝过程覆盖掉目标位置中用户做出的修改. 这时我们需要使用 -u 选项明确的告诉rsync命令保留用户在目标文件中作出的修改. 在下面的例子中, 文件Basenames是用户基于上次的拷贝, 修改过的文件, 当我们使用了-u 选项后, 该文件中的修改将不会被覆盖掉.

在某些特殊场景中, 我们只需要远程服务器上的目录结构, 而不希望花大量时间, 带宽拷贝文件内容, 这时我们可以使用 -d, --dirs选项来达到目的.

有时我们希望拷贝文件时, 能实时的显示拷贝进度, 以及传输速率等信息. 尤其是拷贝大文件时, 程序不输出信息, 用户往往无法区分程序是在响应中, 还是已经挂起, 在这种情况下如果使用 –progress 就会非常有帮助.

rsync –progress option displays detailed progress of rsync execution as shown below.

你也可以使用rsnapshot工具 (rsnapshot会调用rsync)来备份本地linux服务器, 或者备份远程linux服务器.

有时我们希望目标文件和源文件保持严格一致, 不要多文件也不要少文件, 这是我们可能需要使用 -delete 选项来达到目的. 如果使用 -delete 选项, rsync将删除目标位置多余的文件或文件夹. 此选项还可以结合--delete-excluded 选项一起使用, 添加一些例外的文件.

上述示例中, new-file.txt 是源文件中没有的文件, 其将会在拷贝时被删除掉.

在某些特殊的场景下, 我们只想更新, 目标位置已经存在的文件或目录, 而不关心源位置的新文件, 这时我们可以使用-existing 选项仅仅更新已经存在的文件.

让我们来验证一下这个选项的功能, 首先在源端添加一个新文件 new-file.txt.

从上面的例子可以看到, 由于加了--existing选项新文件new-file.txt没有被拷贝到目标位置

选项-i, --itemize-changes 非常有用, 当我们想了解目标位置和源位置的文件差异时.

在源端:

在目标端:

注意: 在上面的例子中, 源位置和目标位置有两处差异. 第一, 源文件Basenames的所有者和组 与 目标文件不同, 第一Dirnames文件大小也不一样.

现在让我们来看看rsync会怎样显示这些差异

输出信息只在相应文件前面显示了9个字母来标识改变, 这些字母具体是什么意思呢? 请参考以下详细说明

rsync 可以使用--include 和 --exclude 选项结合通配符进行文件或文件夹过滤

在上面的示例中, 仅仅以P打头的文件和文件夹被包含了进来, 其他的文件都被过滤在拷贝的过程中被排除在外了.

可以使用--max-size 告诉rsync 不要拷贝大小超过某个值的文件, 可以使用K, M, G指定文件大小, M for megabytes and G for gigabytes.

rsync 有个重要优点就是, 可以做到在拷贝的过程中, 只拷贝发生变化了的部分, 而不是发送整个文件.

但是在某些场景中, 比如文件较少, 文件size较小时, 我们的带宽又足够大, cpu资源相对又贫乏, 我们不希望它这样做, 因为毕竟计算源端和目标端的checksum, 并做对比, 也需要额外cpu开销. 这时我们可以使用 -W, --whole-file 选项, 让rsync不用计算那么多, 一上来就直接开始传送文件. 我们可以像下面这么做.

15个Rsync命令实例

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中获得系统恢复功能,然而你会发现它们在技术上是非常相似的,那么有没有更好的方法来代替现有的系统恢复功能呢?也许在未来随着这些应用程序的不断发展将会出现更好的方法,或者是对这些现有的工具更有效的进行组合应用,这些都需要使用者们不断进行探索发掘。

;

Ubuntu 16.04使用Snap软件包教程

上周新鲜出炉的Ubuntu

16.04

LTS

为用户带来了众多新功能特性,其中非常受关注的就有对

Snap

软件包的支持。据

Canonical

官方消息称,Snap

软件包拥有更加稳定和安全的特性,本文我们就一起来看看如何在

Ubuntu

16.04

中使用

Snap

软件包。

什么是Snap软件包

首先要说什么是「包」?Linux

中应用程序的安装通常有两种方式:其一,是直接通过源代码编译安装,需要用户手动执行脚本、处理依赖等不太人性化的操作;其二,是由软件发行商将应用程序打包成「软件包」进行交付,例如

Ubuntu

用户直接双击

.deb(Debian

软件包)

文件即可安装软件。

现在

Ubuntu

搞一个新的

Snap

包管理系统是因为基于

Debian

.deb

文件并被大量使用的包管理方式不好吗?其实不然,它只对包管理进行了规范并更多会在类似无人机项目等物联网领域进行使用。

Canonical

官方是这么进行描述的:

.snap

包中包含了

Ubuntu

核心中的所有依赖关系,这比传统

.deb

或基于

RPM

的依赖处理更有优势。更重要的是,开发人员不必担心应用被分发到用户系统之后其它方面触发的系统变更。

使用Snap软件包

通常我们都使用

apt-get

来管理

Ubuntu

中的软件包,

16.04

发布之后建议大家直接使用

apt

命令。与此类似,用户可以使用

snap

find

命令来列出适用于当前系统的

Snap

软件包。

安装

Snap

包可以使用如下命令:

sudo

snap

install

包名

查看当前系统中已安装的

Snap

软件包:

snap

list

大家看到了吧,Ubuntu

16.04

Ubuntu

核心已经使用

Snap。

Snap

还提供了其对系统的更改历史记录,可以使用如下命令查看:

snap

changes

要升级

Snap

软件包版本,可以使用如下命令:

sudo

snap

refresh

包名

移除

Snap

软件包使用如下命令:

sudo

snap

remove

包名

目前来看,采用

Snap

方式打包的软件非常少,不过国外已经有大的开源软件发行商已经公开表态将逐步开始采用

Snap

软件包发行软件。Canonical

也已经推出了

Snapcraft

工具帮助开发人员打包

Snap

应用。

Linux ps命令详解

【 ps 】

»语法

ps[必要参数][选择参数]

»功能

ps 命令:用来显示当前进程的状态

»类似命令 top kill pgrep

»执行权限 超级用户 普通用户

»命令属性 系统管理

»参数

必要参数

a 显示所有进程

-a 显示同一终端下的所有程序

-A 显示所有进程

c 显示进程的真实名称

-N 反向选择

-e 等于“-A”

e 显示环境变量

f 显示程序间的关系

-H 显示树状结构

r 显示当前终端的进程

T 显示当前终端的所有程序

u 指定用户的所有进程

选择参数

-C命令 列出指定命令的状况

--lines行数 每页显示的行数

--width字符数 每页显示的字符数

--help 显示帮助信息

--version 显示版本显示

范例1: 显示所有进程信息

root@localhost :~# ps -A 显示进程信息

PID TTY TIME CMD

1 ? 00:00:02 init

2 ? 00:00:00 kthreadd

3 ? 00:00:00 migration/0

4 ? 00:00:00 ksoftirqd/0

5 ? 00:00:00 watchdog/0

6 ? 00:00:00 events/0

7 ? 00:00:00 cpuset

……

范例2: 显示指定用户信息

root@localhost :~# ps -u root //显示root进程用户信息

PID TTY TIME CMD

1 ? 00:00:02 init

2 ? 00:00:00 kthreadd

3 ? 00:00:00 migration/0

4 ? 00:00:00 ksoftirqd/0

5 ? 00:00:00 watchdog/0

6 ? 00:00:00 events/0

7 ? 00:00:00 cpuset

8 ? 00:00:00 khelper

9 ? 00:00:00 netns

10 ? 00:00:00 async/mgr

11 ? 00:00:00 pm

12 ? 00:00:00 sync_supers

13 ? 00:00:00 bdi-default

14 ? 00:00:00 kintegrityd/0

15 ? 00:00:02 kblockd/0

16 ? 00:00:00 kacpid

……省略部分结果

30487 ? 00:00:06 gnome-terminal

30488 ? 00:00:00 gnome-pty-helpe

30489 pts/0 00:00:00 bash

30670 ? 00:00:00 debconf-communi

30749 pts/0 00:00:15 gedit

30886 ? 00:01:10 qtcreator.bin

30894 ? 00:00:00 qtcreator.bin

31160 ? 00:00:00 dhclient

31211 ? 00:00:00 aptd

31302 ? 00:00:00 sshd

31374 pts/2 00:00:00 bash

31397 pts/2 00:00:00 ps

范例3: 显示指定终端信息

root@localhost :~# ps -u root //显示终端1进程信息

PID TTY TIME CMD

1 ? 00:00:02 init

2 ? 00:00:00 kthreadd

3 ? 00:00:00 migration/0

4 ? 00:00:00 ksoftirqd/0

5 ? 00:00:00 watchdog/0

6 ? 00:00:00 events/0

7 ? 00:00:00 cpuset

8 ? 00:00:00 khelper

9 ? 00:00:00 netns

10 ? 00:00:00 async/mgr

11 ? 00:00:00 pm

12 ? 00:00:00 sync_supers

13 ? 00:00:00 bdi-default

14 ? 00:00:00 kintegrityd/0

15 ? 00:00:02 kblockd/0

16 ? 00:00:00 kacpid

……省略部分结果

30487 ? 00:00:06 gnome-terminal

30488 ? 00:00:00 gnome-pty-helpe

30489 pts/0 00:00:00 bash

30670 ? 00:00:00 debconf-communi

30749 pts/0 00:00:15 gedit

30886 ? 00:01:10 qtcreator.bin

30894 ? 00:00:00 qtcreator.bin

31160 ? 00:00:00 dhclient

31211 ? 00:00:00 aptd

31302 ? 00:00:00 sshd

31374 pts/2 00:00:00 bash

31397 pts/2 00:00:00 ps

范例4: 显示所有进程信息,连同命令行

root@localhost :~# ps -ef //显示所有命令,连带命令行

UID PID PPID C STIME TTY TIME CMD

root 1 0 0 10:22 ? 00:00:02 /sbin/init

root 2 0 0 10:22 ? 00:00:00 [kthreadd]

root 3 2 0 10:22 ? 00:00:00 [migration/0]

root 4 2 0 10:22 ? 00:00:00 [ksoftirqd/0]

root 5 2 0 10:22 ? 00:00:00 [watchdog/0]

root 6 2 0 10:22 ? /usr/lib/NetworkManager

……省略部分结果

root 31302 2095 0 17:42 ? 00:00:00 sshd: root@pts/2

root 31374 31302 0 17:42 pts/2 00:00:00 -bash

root 31400 1 0 17:46 ? 00:00:00 /usr/bin/python /usr/sbin/aptd

root 31407 31374 0 17:48 pts/2 00:00:00 ps -ef

范例5: ps 与grep 常用组合用法,查找特定进程

root@localhost :~# ps -ef |grep sshd //查找字串为sshd的进程

root 2095 1 0 10:31 ? 00:00:00 /usr/sbin/sshd

root 31302 2095 0 17:42 ? 00:00:00 sshd: root@pts/2

root 31409 31374 0 17:50 pts/2 00:00:00 grep --color=auto sshd

root@localhost :~#

范例6: 显示命令的完整命令行

root@localhost :~# ps -efww

UID PID PPID C STIME TTY TIME CMD

root 1 0 0 10:22 ? 00:00:02 /sbin/init

root 2 0 0 10:22 ? 00:00:00 [kthreadd]

root 3 2 0 10:22 ? 00:00:00 [migration/0]

root 4 2 0 10:22 ? 00:00:00 [ksoftirqd/0]

root 5 2 0 10:22 ? 00:00:00 [watchdog/0]

root 6 2 0 10:22 ? 00:00:00 [events/0]

……省略部分结果

root 41 2 0 10:23 ? 00:00:00 [kstriped]

root 42 2 0 10:23 ? 00:00:00 [kmpathd/0]

root 43 2 0 10:23 ? 00:00:00 [kmpath_handlerd]

root 44 2 0 10:23 ? 00:00:00 [ksnapd]

root 45 2 0 10:23 ? 00:00:00 [kondemand/0]

root 46 2 0 10:23 ? 00:00:00 [kconservative/0]

root 233 2 0 10:23 ? 00:00:00 [mpt_poll_0]

root 234 2 0 10:23 ? 00:00:00 [mpt/0]

root 235 2 0 10:23 ? 00:00:00 [scsi_eh_2]

root 253 2 0 10:23 ? 00:00:12 [jbd2/sda1-8]

root 254 2 0 10:23 ? 00:00:00 [ext4-dio-unwrit]

root 314 1 0 10:23 ? 00:00:00 upstart-udev-bridge --daemon

范例7: 显示进程间的关系

root@localhost :~# ps -efh

Warning: bad ps syntax, perhaps a bogus '-'? See

31374 pts/2 Ss 0:00 -bash USER=root LOGNAME=root HOME=/root PATH=/usr/local/sbin:/usr/

31418 pts/2 R+ 0:00 \_ ps -efh TERM=xterm SHELL=/bin/bash XDG_SESSION_COOKIE=93b5d3d0

30489 pts/0 Ss+ 0:00 bash XDG_CONFIG_DIRS=/etc/xdg/xdg-gnome:/etc/xdg SPEECHD_PORT=6560

30749 pts/0 S 0:15 \_ gedit ui_mainlocalhost.h ORBIT_SOCKETDIR=/tmp/orbit-root SSH_AGENT

1025 tty7 Ss+ 10:12 /usr/bin/X :0 -nr -verbose -auth /var/run/gdm/auth-for-gdm-Ge8TFD/

1021 tty1 Ss+ 0:00 /sbin/getty -8 38400 tty1 PATH=/usr/local/sbin:/usr/local/bin:/usr

867 tty6 Ss+ 0:00 /sbin/getty -8 38400 tty6 PATH=/usr/local/sbin:/usr/local/bin:/usr

864 tty3 Ss+ 0:00 /sbin/getty -8 38400 tty3 PATH=/usr/local/sbin:/usr/local/bin:/usr

862 tty2 Ss+ 0:00 /sbin/getty -8 38400 tty2 PATH=/usr/local/sbin:/usr/local/bin:/usr

855 tty5 Ss+ 0:00 /sbin/getty -8 38400 tty5 PATH=/usr/local/sbin:/usr/local/bin:/usr

852 tty4 Ss+ 0:00 /sbin/getty -8 38400 tty4 PATH=/usr/local/sbin:/usr/local/bin:/usr

如何使用Linux命令创建快照

逐个字节进行快照

在Xen里创建快照的一种方法是在保存虚拟机当前状态后使用Linux dd。这包括以下步骤:

1.使用xm save命令禁用当前的虚拟机状态并将其写入磁盘文件。这只把机器状态写入一个文件,不是用于Xen磁盘文件或分区的当前状态。使用名称linux01这样做,用xm save linux01 linux01.sav。注意这个命令将停止虚拟机。

2.现在使用dd将磁盘镜像文件的当前状态转存到一个备份文件。下面的例子将为LVM逻辑卷:

dd if=/dev/xenvols/linux01_root of=/data/xen_linux01_root.img

3.使用xm restore命令重新启动虚拟机。

这种解决方案的主要缺点在于耗时。dd命令逐个字节地对虚拟机磁盘文件进行复制,因此需要消费大量时间。所以这种方案不是非常实用。

LVM方法

在Linux里,Logical Volume Manager(LVM)也能用于创建快照,它比先前的磁盘文件方法节省了许多时间。这种方法意味着你的虚拟机使用LVM逻辑卷作为存储后端,与使用虚拟磁盘文件形成对比。由于这个逻辑卷,你接下来需要创建快照。这个快照是一种备份,只包含当时进行快照时所改变的元数据和块。当你通过元数据使用dd制作快照副本时,你通常在原始卷上制作原始块的快照,不需要重新激活原始卷。通过这种方式,能大幅度减少创建快照的时间。步骤如下:

1.使用xm save命令保存虚拟机当前状态,并写入磁盘文件:

xm save linux01 linux01.sav

2.假定你已经有一个LVM逻辑卷用来作为你虚拟机的存储后端,使用下面的命令对这个卷进行快照。比较好的准则是使用在原始逻辑卷里所分配磁盘空间的10%作为快照卷的大小:

lvcreate -s -L 1G -n linux01-snap /dev/xenvols/linux01

3.由于现在你已经在LVM快照里保存了虚拟机的状态,你能重新启动虚拟机,显著减少虚拟机的停机时间:

xm restore linux01-sav

4.使用dd创建虚拟机快照并写入一个镜像文件。由于要使用快照复制所有虚拟机分配的磁盘块,这将花费很长时间:

dd if=/dev/xenvols/linux01-snap of=/data/xen01.img

5.不要忘记在最后一步移除快照。这很重要,因为快照最终将被完全覆盖而导致快照不能用。这样的问题是将阻止你从原始卷重新启动,因此不要忘记这最后一步:

lvremove /dev/xenvols/linux01-snap

目前,没有任何一种Linux版本提供了在开源Xen堆栈里创建虚拟机快照的方法,在本文中,我们学习了使用标准Linux工具,如LVM和dd命令来创建快照。

这样你就学会如何用Linux命令创建快照了。


网站栏目:包含snaolinux命令的词条
文章路径:http://pwwzsj.com/article/hsjsgo.html