This commit is contained in:
messon007 2020-05-04 22:42:37 +08:00 committed by GitHub
parent 9a52a7fe5c
commit 894a99a021
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -4,47 +4,45 @@ Systemd Services: Reacting to Change Systemd服务响应变更
![](https://www.linux.com/sites/lcom/files/styles/rendered_file/public/webcam.png?itok=zzYUs5VK)
[I have one of these Compute Sticks][1] (Figure 1) and use it as an all-purpose server. It is inconspicuous and silent and, as it is built around an x86 architecture, I don't have problems getting it to work with drivers for my printer, and thats what it does most days: it interfaces with the shared printer and scanner in my living room.
[我有其中一个计算棒] [1]图1并将其用作通用服务器。 它不起眼且安静并且由于它是基于x86架构构建的因此我可以将其与打印机驱动程序配合使用时没有任何问题这就是大多数日子所做的事情它与我的共享打印机和扫描仪接口 客厅
[我有一个这样的电脑棒][1]图1并将其用作通用服务器。它很小且安静由于它是基于x86架构因此我为我的打印机安装驱动没有任何问题而且这就是它大多数时候干的事与客厅的共享打印机和扫描仪通信
![ComputeStick][3]
An Intel ComputeStick. Euro coin for size.
英特尔计算棒。 大小的欧洲硬币
一个英特尔电脑棒。欧元硬币大小
[Used with permission][4]
Most of the time it is idle, especially when we are out, so I thought it would be good idea to use it as a surveillance system. The device doesn't come with its own camera, and it wouldn't need to be spying all the time. I also didn't want to have to start the image capturing by hand because this would mean having to log into the Stick using SSH and fire up the process by writing commands in the shell before rushing out the door.
大多数情况下,它处于空闲状态,尤其是当我们外出时,因此我认为将其用作监视系统是个好主意。 该设备没有自带的摄像头,也不需要一直监视。 我也不想手动开始图像捕获因为这意味着必须使用SSH登录到Stick并在冲出门之前在shell中编写命令来启动该过程。
大多数时候它都闲着尤其是当我们外出时因此我认为用它作监视系统是个好主意。该设备没有自带的摄像头也不需要一直监视。我也不想手动启动图像捕获因为这样就意味着在出门前必须通过SSH登录并在shell中编写命令来启动该进程。
So I thought that the thing to do would be to grab a USB webcam and have the surveillance system fire up automatically just by plugging it in. Bonus points if the surveillance system fired up also after the Stick rebooted, and it found that the camera was connected.
因此,我认为要做的就是抓住USB网络摄像头然后仅通过将其插入即可自动启动监视系统。如果在Stick重新启动后监视系统也启动则奖励积分。 连接的
因此,我以为应该这么做抓住USB摄像头然后只需插入它即可自动启动监视系统。如果Stick重启后发现连接了摄像头也启动监视系统就更加分了
In prior installments, we saw that [systemd services can be started or stopped by hand][5] or [when certain conditions are met][6]. Those conditions are not limited to when the OS reaches a certain state in the boot up or powerdown sequence but can also be when you plug in new hardware or when things change in the filesystem. You do that by combining a Udev rule with a systemd service.
在先前的文章中,我们看到[可以手动启动或停止系统服务] [5]或[在满足某些条件时] [6]。 这些条件不仅限于操作系统在启动或关机顺序中达到某种状态时,还可以在您插入新硬件或文件系统发生变化时进行。 您可以通过将Udev规则与systemd服务结合来实现。
在先前的文章中,我们看到[systemd服务可以手动启动或停止][5]或[在满足某些条件时][6]。这些条件不限于操作系统在启动或关机时序中达到某种状态还可以在您插入新硬件或文件系统发生变化时进行。您可以通过将Udev规则与systemd服务结合来实现。
### Hotplugging with Udev
### Hotplugging with Udev 有Udev(支持)的热插拔
Udev rules live in the _/etc/udev/rules_ directory and are usually a single line containing _conditions_ and _assignments_ that lead to an _action_.
Udev规则位于 _/etc/udev/rules_ 目录中,通常是由导致一个 _动作(action)__条件(conditions)__赋值(assignments)_ 的单行语句来描述。
That was a bit cryptic. Let's try again:
Udev规则位于_ / etc / udev / rules_目录中通常是包含_conditions_和_assignments_的单行它们导致_action_。
那有点神秘。让我们再试一次:
有点神秘。让我们再试一次:
Typically, in a Udev rule, you tell systemd what to look for when a device is connected. For example, you may want to check if the make and model of a device you just plugged in correspond to the make and model of the device you are telling Udev to wait for. Those are the _conditions_ mentioned earlier.
通常在Udev规则中您告诉systemd连接设备时要查找什么。例如,您可能要检查刚插入的设备的品牌和型号是否与您让Udev等待的设备的品牌和型号相对应。这些是前面提到的条件。
通常在Udev规则中您告诉systemd当连接一个设备时需要查看什么信息。例如,您可能想检查刚插入的设备的品牌和型号是否与您让Udev等待的设备的品牌和型号相对应。这些是前面提到的条件。
Then you may want to change some stuff so you can use the device easily later. An example of that would be to change the read and write permissions to a device: if you plug in a USB printer, you're going to want users to be able to read information from the printer (the user's printing app would want to know the model, make, and whether it is ready to receive print jobs or not) and write to it, that is, send stuff to print. Changing the read and write permissions for a device is done using one of the _assignments_ you read about earlier.
然后您可能需要更改一些内容以便以后可以轻松使用该设备。例如更改对设备的读写权限如果插入USB打印机您将希望用户能够从打印机中读取信息用户的打印应用程序希望了解模型制造商以及是否准备好接受打印作业并向其写入内容即发送要打印的内容。更改设备的读写权限是使用您之前阅读的_assignments_之一完成的。
然后您可能想要更改一些内容以便以后可以轻松使用该设备。例如更改设备的读写权限如果插入USB打印机您将希望用户能够从打印机读取信息用户的打印应用程序需要知道其模型制造商以及是否准备好接受打印作业并向其写入内容即发送要打印的内容。更改设备的读写权限是通过您之前阅读的 _赋值(assignments)_ 之一完成的。
Finally, you will probably want the system to do something when the conditions mentioned above are met, like start a backup application to copy important files when a certain external hard disk drive is plugged in. That is an example of an _action_ mentioned above.
最后您可能希望系统在满足上述条件时执行某些操作例如在插入某个外部硬盘驱动器时启动备份应用程序以复制重要文件。这就是上述_action_的示例。
最后,您可能希望系统在满足上述条件时执行某些动作,例如在插入某个外接硬盘时启动备份程序以复制重要文件。这就是上面提到的 _动作(action)_ 的例子。
With that in mind, ponder this:
了解这些之后, 来看看以下几点:
```
ACTION=="add", SUBSYSTEM=="video4linux", ATTRS{idVendor}=="03f0", ATTRS{idProduct}=="e207",
@ -52,6 +50,7 @@ SYMLINK+="mywebcam", TAG+="systemd", MODE="0666", ENV{SYSTEMD_WANTS}="webcam.ser
```
The first part of the rule,
规则的第一部分,
```
ACTION=="add", SUBSYSTEM=="video4linux", ATTRS{idVendor}=="03f0",
@ -59,32 +58,32 @@ ATTRS{idProduct}=="e207" [etc... ]
```
shows the conditions that the device has to meet before doing any of the other stuff you want the system to do. The device has to be added (`ACTION=="add"`) to the machine, it has to be integrated into the `video4linux` subsystem. To make sure the rule is applied only when the correct device is plugged in, you have to make sure Udev correctly identifies the manufacturer (`ATTRS{idVendor}=="03f0"`) and a model (`ATTRS{idProduct}=="e207"`) of the device.
显示在执行系统要执行的其他任何操作之前设备必须满足的条件。 必须将设备添加到ACTION ==“ add”机器上并且必须将其集成到video4linux子系统中。 为了确保仅在插入正确的设备时才应用该规则您必须确保Udev正确标识制造商`ATTRS {idVendor} ==“ 03f0”`)和型号(`ATTRS {idProduct} == 设备的“ e207”`)。
表明了执行您想让系统执行的其他动作之前设备必须满足的条件。设备必须被添加到(`ACTION=="add"`)机器上,并且必须添加到 `video4linux` 子系统中。为了确保仅在插入正确的设备时才应用该规则您必须确保Udev正确识别设备的制造商`ATTRS{idVendor}=="03f0"`)和型号(`ATTRS{idProduct}=="e207"`)。
In this case, we're talking about this device (Figure 2):
在这种情况下我们正在讨论此设备图2
在本例中我们讨论的是这个设备图2
![webcam][8]
The HP webcam used in this experiment.
这个试验使用的是HP的摄像头。
[Used with permission][4]
Notice how you use `==` to indicate that these are a logical operation. You would read the above snippet of the rule like this:
注意如何使用“ ==”来表示这些是逻辑操作。 您将阅读以下规则的摘要
注意怎样用`==`来表示这是一个逻辑操作。您应该像这样阅读上面的简要规则
```
if the device is added and the device controlled by the video4linux subsystem
and the manufacturer of the device is 03f0 and the model is e207, then...
```
```
如果添加了设备并且该设备由video4linux子系统控制
设备的制造商是03f0型号是e207...
如果添加了一个设备并且该设备由video4linux子系统控制
且该设备的制造商是03f0型号是e207那么...
```
But where do you get all this information? Where do you find the action that triggers the event, the manufacturer, model, and so on? You will probably have to use several sources. The `IdVendor` and `idProduct` you can get by plugging the webcam into your machine and running `lsusb`:
但是,您从哪里获得所有这些信息? 您在哪里找到触发事件的动作,制造商,模型等? 您可能必须使用多个资源。 您可以通过将摄像头插入计算机并运行`lsusb`来获得`IdVendor`和`idProduct`
但是,您从哪里获取的这些信息? 您在哪里找到触发事件的动作,制造商,模型等等?您可能必须使用多个来源。您可以通过将摄像头插入机器并运行`lsusb`来获得`IdVendor`和`idProduct`
```
lsusb
@ -99,15 +98,15 @@ Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
```
The webcam Im using is made by HP, and you can only see one HP device in the list above. The `ID` gives you the manufacturer and the model numbers separated by a colon (`:`). If you have more than one device by the same manufacturer and not sure which is which, unplug the webcam, run `lsusb` again and check what's missing.
正在使用的网络摄像头是由HP制造的并且您在上面的列表中只能看到一台HP设备。 “ ID”为您提供制造商和型号以冒号``)分隔。 如果同一制造商提供的设备不止一个,并且不确定是哪个设备,请拔下网络摄像头,再次运行`lsusb`并检查缺少的内容
用的摄像头是HP的您在上面的列表中只能看到一个HP设备。`ID`告诉了制造商和型号,它们以冒号(`:`)分隔。如果您有同一制造商的多个设备,不确定哪个是哪个设备,请拔下摄像头,再次运行`lsusb`, 看看少了什么
OR...
Unplug the webcam, wait a few seconds, run the command `udevadmin monitor --environment` and then plug the webcam back in again. When you do that with the HP webcam, you get:
要么...
或者...
拔下网络摄像头,等待几秒钟,运行命令“ udevadmin monitor --environment”然后重新插入网络摄像头。 使用HP网络摄像头进行操作时您将获得
拔下摄像头,等待几秒钟,运行命令`udevadmin monitor --environment`然后重新插入摄像头。当您使用的是HP摄像头时您将看到
```
udevadmin monitor --environment
@ -152,38 +151,35 @@ XKBVARIANT=
That may look like a lot to process, but, check this out: the `ACTION` field early in the list tells you what event just happened, i.e., that a device got added to the system. You can also see the name of the device spelled out on several of the lines, so you can be pretty sure that it is the device you are looking for. The output also shows the manufacturer's ID number (`ID_VENDOR_ID=03f0`) and the model number (`ID_VENDOR_ID=03f0`).
可能要处理很多事情,但是,请检查一下:列表前面的“ ACTION”字段告诉您刚刚发生了什么事件即设备已添加到系统中。您还可以在几行中看到设备名称的拼写,因此可以确定它是您要找的设备。输出还显示制造商的IDID_VENDOR_ID = 03f0和型号ID_VENDOR_ID = 03f0
可能看起来有很多信息要处理,但是,看一下这个:列表前面的`ACTION`字段, 它告诉您刚刚发生了什么事件,即一个设备被添加到系统中。您还可以在几行中看到设备名称的拼写,因此可以非常确定它是您要找的设备。输出还显示制造商的ID`ID_VENDOR_ID = 03f0`)和型号(`ID_VENDOR_ID = 03f0`)。
This gives you three of the four values the condition part of the rule needs. You may be tempted to think that it a gives you the fourth, too, because there is also a line that says:
这为您提供了规则条件部分需要的四个值中的三个。您可能会想起它也给您第四,因为还有一行这样写
这为您提供了规则条件部分需要的四个值中的三个。您可能也会想到它还给了您第四个,因为还有一行这样写道
```
SUBSYSTEM=input
```
```
SUBSYSTEM =输入
```
Be careful! Although it is true that a USB webcam is a device that provides input (as does a keyboard and a mouse), it is also belongs to the _usb_ subsystem, and several others. This means that your webcam gets added to several subsystems and looks like several devices. If you pick the wrong subsystem, your rule may not work as you want it to, or, indeed, at all.
小心尽管USB网络摄像头确实是提供输入的设备(键盘和鼠标也是如此但它也属于_usb_子系统和其他几个子系统。这意味着您的网络摄像头已添加到多个子系统,并且看起来像多个设备。如果选择了错误的子系统,则您的规则可能无法按您希望的那样工作,或者甚至根本无法工作。
小心尽管USB摄像头确实是提供输入的设备键盘和鼠标也是但它也属于 _usb_ 子系统和其他几个子系统。这意味着您的摄像头被添加到了多个子系统,并且看起来像多个设备。如果您选择了错误的子系统,那么您的规则可能无法按您期望的那样工作,或者根本无法工作。
So, the third thing you have to check is all the subsystems the webcam has got added to and pick the correct one. To do that, unplug your webcam again and run:
因此,您需要检查的第三件事是网络摄像头已添加到的所有子系统中,并选择了正确的子系统。为此,请再次拔下网络摄像头,然后运行:
因此,您必须检查的第三件事是摄像头添加到的所有子系统,并选择正确的那个。为此,请再次拔下摄像头,然后运行:
```
ls /dev/video*
```
This will show you all the video devices connected to the machine. If you are using a laptop, most come with a built-in webcam and it will probably show up as `/dev/video0`. Plug your webcam back in and run `ls /dev/video*` again.
这将向您显示连接到本机的所有视频设备。 如果您使用的是笔记本电脑大多数笔记本电脑都带有内置摄像头,它可能会显示为`/ dev / video0`。 重新插入网络摄像头,然后再次运行`ls / dev / video *`。
这将向您显示连接到本机的所有视频设备。如果您使用的是笔记本,大多数笔记本都带有内置摄像头,它可能会显示为`/dev/video0`。重新插入摄像头,然后再次运行`ls /dev/video*`。
Now you should see one more video device (probably `/dev/video1`).
现在,您应该再看到一个视频设备(可能是“ / dev / video1”)。
现在,您应该看到多一个视频设备(可能是`/dev/video1`)。
Now you can find out all the subsystems it belongs to by running `udevadm info -a /dev/video1`:
现在,您可以通过运行`udevadm info -a / dev / video1`找出它所属的所有子系统:
现在,您可以通过运行`udevadm info -a /dev/video1`找出它所属的所有子系统:
```
udevadm info -a /dev/video1
@ -207,35 +203,36 @@ and the attributes from one single parent device.
```
The output goes on for quite a while, but what you're interested is right at the beginning: `SUBSYSTEM=="video4linux"`. This is a line you can literally copy and paste right into your rule. The rest of the output (not shown for brevity) gives you a couple more nuggets, like the manufacturer and mode IDs, again in a format you can copy and paste into your rule.
输出持续了一段时间,但是您感兴趣的只是开始:`SUBSYSTEM ==“ video4linux”`。您可以按实际情况将这行复制并粘贴到规则中。输出的其余部分(为简便起见未显示)为您提供了更多的块,例如制造商和模式ID它们的格式也可以复制并粘贴到规则中。
输出持续了一段时间,但是您感兴趣的只是开始:`SUBSYSTEM =="video4linux"`。您可以将这行按文本复制并粘贴到规则中。输出的其余部分(为简便起见未显示)为您提供了更多的块,例如制造商和模型ID您也可以以同样的格式复制并粘贴到规则中。
Now you have a way of identifying the device and what event should trigger the action univocally, it is time to tinker with the device.
现在,您有了一种识别设备的方式,什么事件应该明确触发该操作,现在该对设备进行修改了。
现在,您有了识别设备的方式并明确了什么事件应该触发该动作,该对设备进行修改了。
The next section in the rule, `SYMLINK+="mywebcam", TAG+="systemd", MODE="0666"` tells Udev to do three things: First, you want to create symbolic link from the device to (e.g. _/dev/video1_ ) to _/dev/mywebcam_. This is because you cannot predict what the system is going to call the device by default. When you have an in-built webcam and you hotplug a new one, the in-built webcam will usually be _/dev/video0_ while the external one will become _/dev/video1_. However, if you boot your computer with the external USB webcam plugged in, that could be reversed and the internal webcam can become _/dev/video1_ and the external one _/dev/video0_. What this is telling you is that, although your image-capturing script (which you will see later on) always needs to point to the external webcam device, you can't rely on it being _/dev/video0_ or _/dev/video1_. To solve this problem, you tell Udev to create a symbolic link which will never change in the moment the device is added to the _video4linux_ subsystem and you will make your script point to that.
规则的下一部分,`SYMLINK + =“ mywebcam”TAG + =“ systemd”MODE =“ 0666”`告诉Udev做三件事首先您要创建从设备到的符号链接例如_ / dev / video1_到_ / dev / mywebcam_。这是因为您无法预测默认情况下系统将调用什么设备。当您拥有内置摄像头并热插拔新摄像头时内置摄像头通常为_ / dev / video0_而外部摄像头通常为_ / dev / video1_。但是如果您在插入外部USB网络摄像头的情况下引导计算机则可能会相反并且内部网络摄像头可能会变成_ / dev / video1_而外部网络摄像头会变成_ / dev / video0_。这告诉您的是尽管您的图像捕获脚本稍后将看到始终需要指向外部网络摄像头设备但是您不能依靠它是_ / dev / video0_或_ / dev / video1_。为了解决这个问题您告诉Udev创建一个符号链接该链接在将设备添加到_video4linux_子系统的那一刻就不会改变并且您将使脚本指向该链接。
规则的下一部分,`SYMLINK+="mywebcam", TAG+="systemd", MODE="0666"`告诉Udev做三件事首先您要创建设备的符号链接例如_/dev/video1_到_/dev/mywebcam_。这是因为您无法预测系统默认情况下会把那个设备叫什么。当您拥有内置摄像头并热插拔一个新的时内置摄像头通常为_/dev/video0_而外部摄像头通常为_/dev/video1_。但是如果您在插入外部USB摄像头的情况下重启计算机则可能会相反内部摄像头可能会变成_/dev/video1_而外部摄像头会变成_/dev/video0_。这想告诉您的是尽管您的图像捕获脚本稍后将看到总是需要指向外部摄像头设备但是您不能依赖它是_/dev/video0_或_/dev/video1_。为了解决这个问题您告诉Udev创建一个符号链接该链接在设备被添加到 _video4linux_ 子系统的那一刻起就不会再变,您将使您的脚本指向该链接。
The second thing you do is add `"systemd"` to the list of Udev tags associated with this rule. This tells Udev that the action that the rule will trigger will be managed by systemd, that is, it will be some sort of systemd service.
您要做的第二件事是将“ systemd”添加到与此规则关联的Udev标记列表中。这告诉Udev该规则将触发的操作将由systemd管理即它将是某种systemd服务。
您要做的第二件事是将`"systemd"`添加到与此规则关联的Udev标记列表中。这告诉Udev该规则触发的动作将由systemd管理即它将是某种systemd服务。
Notice how in both cases you use `+=` operator. This adds the value to a list, which means you can add more than one value to `SYMLINK` and `TAG`.
注意在两种情况下如何使用 + =”运算符。这会将值添加到列表中,这意味着您可以向“ SYMLINK”和“ TAG”添加多个值。
注意在两种情况下如何使用 `+=` 运算符。这会将值添加到列表中,这意味着您可以向 `SYMLINK``TAG` 添加多个值。
The `MODE` values, on the other hand, can only contain one value (hence you use the simple `=` assignment operator). What `MODE` does is tell Udev who can read from or write to the device. If you are familiar with `chmod` (and, if you are reading this, you should be), you will also be familiar of [how you can express permissions using numbers][9]. That is what this is: `0666` means " _give read and write privileges to the device to everybody_ ".
另一方面,“ MODE”值只能包含一个值因此您可以使用简单的“ =”赋值运算符)。 MODE的作用是告诉Udev谁可以读取或写入设备。如果您熟悉`chmod`(并且应该阅读),那么您还将熟悉[如何使用数字表示权限] [9]。这就是它的意思:“ 0666”的意思是“向所有人授予对设备的读写特权”。
另一方面,`MODE` 值只能包含一个值(因此,您可以使用简单的 `=` 赋值运算符)。`MODE` 的作用是告诉Udev谁可以读或写该设备。如果您熟悉 `chmod`(您读到此文, 应该会熟悉),您就也会熟悉[如何用数字表示权限][9]。这就是它的含义: `0666` 的含义是 “ _向所有人授予对设备的读写权限_ ”。
At last, `ENV{SYSTEMD_WANTS}="webcam.service"` tells Udev what systemd service to run.
最后,`ENV {SYSTEMD_WANTS} =“ webcam.service”`告诉Udev要运行什么systemd服务。
最后, `ENV{SYSTEMD_WANTS}="webcam.service"` 告诉Udev要运行什么systemd服务。
Save this rule into file called _90-webcam.rules_ (or something like that) in _/etc/udev/rules.d_ and you can load it either by rebooting your machine, or by running:
将此规则保存到_ / etc / udev / rules.d_中名为_90-webcam.rules_或类似名称的文件中您可以通过重新启动计算机或运行以下命令来加载它:
将此规则保存到 _/etc/udev/rules.d_ 目录名为 _90-webcam.rules_ (或类似的名称)的文件中,您可以通过重启机器或运行以下命令来加载它:
```
sudo udevadm control --reload-rules && udevadm trigger
```
## Service at Last
## Service at Last 最后描述服务
The service the Udev rule triggers is ridiculously simple:
Udev规则触发的服务非常简单
@ -248,10 +245,10 @@ ExecStart=/home/[user name]/bin/checkimage.sh
```
Basically, it just runs the _checkimage.sh_ script stored in your personal _bin/_ and pushes it the background. [This is something you saw how to do in prior installments][5]. It may seem something little, but just because it is called by a Udev rule, you have just created a special kind of systemd unit called a _device_ unit. Congratulations.
基本上,它只运行存储在您个人_bin / _中的_checkimage.sh_脚本并将其推入后台。 [这是您在先前的部分中看到的操作方法] [5]。 它看起来似乎很少但是仅由于它是由Udev规则调用的因此您刚刚创建了一种特殊的systemd单元称为_device_ unit。 恭喜你
基本上,它只是运行存储在您个人 _bin/_ 中的 _checkimage.sh_ 脚本并将其放到后台。 [这是您在先前的部分中看过的内容][5]。 它看起来似乎很小但那只是因为它是被Udev规则调用的您刚刚创建了一种特殊的systemd单元称为 _device_ 单元。 恭喜。
As for the _checkimage.sh_ script _webcam.service_ calls, there are several ways of grabbing an image from a webcam and comparing it to a prior one to check for changes (which is what _checkimage.sh_ does), but this is how I did it:
至于_checkimage.sh_脚本_webcam.service_调用有几种方法可以从网络摄像头获取图像并将其与前一个图像进行比较以检查更改_checkimage.sh_所做的工作但这就是我的方法 它
至于 _webcam.service_ 调用的 _checkimage.sh_ 脚本,有几种方法从摄像头抓取图像并将其与前一个图像进行比较以检查变化(这是 _checkimage.sh_ 所做的事),但这是我的方法
```
#!/bin/bash
@ -278,15 +275,16 @@ done
```
Start by using [MPlayer][10] to grab a frame ( _00000001.png_ ) from the webcam. Notice how we point `mplayer` to the `mywebcam` symbolic link we created in our Udev rule, instead of to `video0` or `video1`. Then you transfer the image to the _monitor/_ directory in your home directory. Then run an infinite loop that does the same thing again and again, but also uses [Image Magick's _compare_ tool][11] to see if there any differences between the last image captured and the one that is already in the _monitor/_ directory.
首先使用[MPlayer] [10]从摄像头抓取一个帧_00000001.png_。 注意我们如何将mplayer指向在Udev规则中创建的mywebcam符号链接而不是指向video0或video1。 然后将映像传输到主目录中的_monitor / _目录。 然后运行一个无限循环,一次又一次地执行相同的操作,但还使用[Image Magick的_compare_工具] [11]来查看最后捕获的图像与_monitor / _目录中的图像之间是否存在差异。
首先使用[MPlayer][10]从摄像头抓取一帧_00000001.png_。注意我们怎样将 `mplayer` 指向Udev规则中创建的 `mywebcam` 符号链接,而不是指向 `video0``video1` 。然后,将图像传输到主目录中的 _monitor/_ 目录。然后执行一个无限循环,一次又一次地执行相同的操作,但还使用[Image Magick的_compare_工具][11]来查看最后捕获的图像与 _monitor/_ 目录中已有的图像之间是否存在差异。
If the images are different, it means something has moved within the webcam's frame. The script overwrites the original image with the new image and continues comparing waiting for some more movement.
如果图像不同,则表示网络摄像头框架内已移动了某些东西。 该脚本将新图像覆盖原始图像,并继续比较以等待更多移动。
如果图像不同,则表示摄像头的镜框里某些东西动了。该脚本将新图像覆盖原始图像,并继续比较以等待更多变动。
### Plugged
### Plugged 插线
With all the bits and pieces in place, when you plug your webcam in, your Udev rule will be triggered and will start the _webcam.service_. The _webcam.service_ will execute _checkimage.sh_ in the background, and _checkimage.sh_ will start taking pictures every half a second. You will know because your webcam's LED will start flashing indicating every time it takes a snap.
一切零碎将网络摄像头插入电源后您的Udev规则将被触发并启动_webcam.service_。 _webcam.service_将在后台执行_checkimage.sh_而_checkimage.sh_将每半秒开始拍照。 您会知道因为网络摄像头的LED指示灯将开始闪烁表明每次需要快照。
所有东西准备好后当您插入摄像头后您的Udev规则将被触发并启动 _webcam.service__webcam.service_ 将在后台执行 _checkimage.sh_ ,而 _checkimage.sh_ 将开始每半秒拍一次照。您会感觉到因为摄像头的LED在每次拍照时将开始闪。
As always, if something goes wrong, run
与往常一样,如果出现问题,请运行
@ -298,23 +296,23 @@ systemctl status webcam.service
to check what your service and script are up to.
检查您的服务和脚本正在做什么。
### Coming up
### Coming up 接下来
You may be wondering: Why overwrite the original image? Surely you would want to see what's going on if the system detects any movement, right? You would be right, but as you will see in the next installment, leaving things as they are and processing the images using yet another type of systemd unit makes things nice, clean and easy.
您可能想知道:为什么要覆盖原始图像? 当然,如果系统检测到任何移动,您肯定想知道发生了什么,对吗? 您将是对的但是如您在下一部分中将看到的那样将它们保持原样并使用另一种类型的systemd单元处理图像将使事情变得更好,干净和容易
您可能想知道:为什么要覆盖原始图像? 当然,系统检测到任何动静,您都想知道发生了什么,对吗?您是对的但是如您在下一部分中将看到的那样将它们保持原样并使用另一种类型的systemd单元处理图像将更好,更清晰和更简单
Just wait and see.
请稍等。
Learn more about Linux through the free ["Introduction to Linux" ][12]course from The Linux Foundation and edX.
通过Linux基金会和edX的免费[[Linux简介]] [12]课程了解有关Linux的更多信息。
通过Linux基金会和edX的免费["Linux简介"][12]课程了解有关Linux的更多信息。
--------------------------------------------------------------------------------
via: https://www.linux.com/blog/intro-to-linux/2018/6/systemd-services-reacting-change
作者:[Paul Brown][a]
选题:[lujun9972][b]
译者:[译者ID](https://github.com/译者ID)
译者:[messon007](https://github.com/messon007)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出