ubuntu自启动

一、openvpn自启动

在Ubuntu上,您放置在名为/etc/openvpn/$NAME.conf的文件中的任何VPN配置都将自动启动。

因此,您要做的就是将client.ovpn复制到/etc/openvpn/client.conf。我建议您还将client.conf中的绝对路径用于所有键,脚本等。

当然,您可能需要仔细检查/etc/default/openvpn文件。默认情况下,它将自动启动所有VPN,但AUTOSTART值可能已更改为none,或者是要自动启动的特定配置的列表。

设置自启动:

将xxx.ovpn放置到/etc/openvpn文件夹中,然后改名为xxx.conf,即可实现开机自启动openvpn。

取消自启动:

也就是说修改/etc/default/openvpn中,将AUTOSTART的参数改为“none”就可以取消openvpn的自启动。

参考:https://ubuntuqa.com/article/10000.html

二、nvidia xavier agx的自启动

参考:jetson agx xavier 设置上电自启动_weixin_48136049的博客-CSDN博客 

三、ROS程序的自启动

使用robot_upstart软件包

首先安装:

sudo apt install ros-$ROS_DISTRO-robot-upstart

只测试过melodic版本。

由于需要运行rosrun,首先打开roscore

将需要启动的所有ROS节点集中写到一个launch文件

然后装载所需要的launch:

rosrun robot_upstart install miiboo_bringup/launch/myrobot.launch \
--job myrobot \
--interface wlan0 \
--logdir ~/myrobot.log

--job指定任务的别名

--interface指定网络接口,一定要设置,不然无法实现多机ROS通信--logdir指定日志存放目录

启动、重启、停止任务

(1)启动任务

sudo systemctl daemon-reload && sudo systemctl start myrobot

(2)重启任务

sudo systemctl restart myrobot

(3)停止任务

sudo systemctl stop myrobot

(4)卸载

roscore && rosrun robot_upstart uninstall myrobot

(5)删除日志

sudo rm -rf ~/myrobot.log

参考:https://zhuanlan.zhihu.com/p/163048849


四、任意程序的自启动

1、切换到目录/lib/systemd/system,创建一个aatest.service。

2、Root权限下编辑该service文件:/bin/bash /home/nvidia/mttcantest为要启动的bash脚本路径,完成后保存。

[Unit]
Description=aatest

[Service]
ExecStart=/bin/bash /home/nvidia/mttcantest
Type=oneshot
#Restart=on-failure

[Install]
WantedBy=multi-user.target

设置服务自动启动,期间需要输入密码。

$ systemctl enable aatest.service


​ 设置成功时,会自动创建符号链接,如上图。

如需禁用自动启动,输入以下命令:

$ systemctl disable aatest.service

切换到/etc/systemd/system/multi-user.target.wants 目录下查看相关服务链接是否删除。删除即成功。

reboot重新启动系统,服务生效。
————————————————
版权声明:本文为CSDN博主「这个昵称已已已存在」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_38212787/article/details/116273724

一些例子,看来service的功能还是很强大的,可以检查网络然后执行代码,还可以重新启动。

nano /lib/systemd/system/xx.service

[Unit] 
Description=Check GPU INFO by chenwei   # 服务描述 
Wants=network-online.target             # 服务依赖于网络 
After=network-online.target 
 
[Service] 
Type=simple 
ExecStart=/root/shell/agent/chkgpu      # 服务开启时执行脚本 
ExecReload=/bin/kill -HUP $MAINPID      # 服务重新加载时执行脚本 
RestartSec=5s                           # 自动启动间隔时间 
Restart=on-failure                      # 在什么情况下会自动重启 
 
[Install] 
WantedBy=multi-user.target   
 
[Unit] 
Description=Advanced key-value store 
After=network.target 
 
[Service] 
Type=forking 
ExecStart=/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf 
ExecStop=/bin/kill -s TERM $MAINPID 
PIDFile=/var/run/redis_6379.pid 
Restart=always 
RestartSec=5s 
Restart=on-failure 
 
 
[Install] 
WantedBy=multi-user.target 
Alias=redis.service 

五、强大的systemctl

在使用中发现很多的自启动都涉及到systemctl工具,所以进行一个研究。

参考:linux systemctl 命令 - sparkdev - 博客园

常用:

sudo systemctl start/restart xxx.service
sudo systemctl stop xxx.service
sudo systemctl enable xxx.service
sudo systemctl status xxx.service

sudo systemctl daemon-reload # 重新加载

5.1 含义

5.1.1 命令格式

systemctl 提供了一组子命令来管理单个的 unit,其命令格式为:

  systemctl [command] [unit]
command 主要有:
start:立刻启动后面接的 unit。
stop:立刻关闭后面接的 unit。
restart:立刻关闭后启动后面接的 unit,亦即执行 stop 再 start 的意思。
reload:不关闭 unit 的情况下,重新载入配置文件,让设置生效。
enable:设置下次开机时,后面接的 unit 会被启动。
disable:设置下次开机时,后面接的 unit 不会被启动。
status:目前后面接的这个 unit 的状态,会列出有没有正在执行、开机时是否启动等信息。
is-active:目前有没有正在运行中。
is-enable:开机时有没有默认要启用这个 unit。
kill :不要被 kill 这个名字吓着了,它其实是向运行 unit 的进程发送信号。
show:列出 unit 的配置。
mask:注销 unit,注销后你就无法启动这个 unit 了。
unmask:取消对 unit 的注销。

5.1.2 status 打印信息的解读
输出内容的第一行是对 unit 的基本描述。
第二行中的 Loaded 描述操作系统启动时会不会启动这个服务,enabled 表示开机时启动,disabled 表示开机时不启动。而启动该服务的配置文件路径为:/lib/systemd/system/prometheus.service。
第三行 中的 Active 描述服务当前的状态,active (running) 表示服务正在运行中。如果是 inactive (dead) 则表示服务当前没有运行。后面则是服务的启动时间。
第四行的 Docs 提供了在线文档的地址。
下面的 Main PID 表示进程的 ID,接下来是任务的数量,占用的内存和 CPU 资源。
再下面的 Cgroup 描述的是 cgrpup 相关的信息,笔者会在后续的文章中详细的介绍。
最后是输出的日志信息。

关于 unit 的启动状态,除了 enable 和 disable 之外还有:
static:这个 unit 不可以自己启动,不过可能会被其它的 enabled 的服务来唤醒。
mask:这个 unit 无论如何都无法被启动!因为已经被强制注销。可通过 systemctl unmask 改回原来的状态。

关于 unit 的运行状态 Active,除了 active 和 inactive 之外还有:
active (exited):仅执行一次就正常结束的服务,目前并没有任何程序在系统中执行。举例来说,开机或者是挂载时才会进行一次的 quotaon 功能,就是这种模式! Quotaon 不需要一直执行,只在执行一次之后,就交给文件系统去自行处理。通常用 bash shell 写的小型服务,大多是属于这种类型。
active (waiting):正在执行当中,不过还再等待其他的事件才能继续处理。举例来说,打印的相关服务就是这种状态。


5.1.3 关于enable和disable的使用
比如我们为 prometheus 服务创建了配置文件 /lib/systemd/system/prometheus.service,然后执行 enable 命令:
$ sudo systemctl enable prometheus.service
所谓的 enable 就是在 multi-user.target.wants 下面创建了一个链接文件:
至于为什么会链接到 multi-user.target.wants 目录下,则是由 prometheus.server 文件中的配置信息决定的。

5.1.4 查看 unit 的配置
使用 show 子命令可以查看 unit 的详细配置情况:
$ sudo systemctl show prometheus.service
这里的输出非常多,主要是很多的默认设置也都显示出来了。

5.1.5 注销与反注销 unit
如果我们想暂时的禁用某个 unit,比如 prometheus.service,可以注销这个 unit,注销之后就无法再启动这个服务了:
$ sudo systemctl mask prometheus.service
从上图中的输出我们可以看到,所谓的注销就是把 prometheus.service 文件链接到 /dev/null 这个空设备中去了。所以就无法再启动该服务了。下面我们尝试执行一次反注销:
$ sudo systemctl unmask prometheus.service
unmask 操作就是删除掉 mask 操作中创建的链接。


5.2 查询

5.2.1 
sudo systemctl list-unit-files
列出所有启动项


systemctl 提供了子命令可以查看系统上的 unit,命令格式为:
systemctl [command] [--type=TYPE] [--all]
command 有:
list-units:列出当前已经启动的 unit,如果添加 -all 选项会同时列出没有启动的 unit。
list-unit-files:根据 /lib/systemd/system/ 目录内的文件列出所有的 unit。
--type=TYPE:可以过滤某个类型的 unit。
不带任何参数执行 systemctl 命令会列出所有已启动的 unit:

5.2.2 查看加载失败的 unit
如果发现某个 unit 不工作,可以查看是否有 unit 加载失败:


$ systemctl --failed


5.3 重新加载


sudo systemctl daemon-reload
重新加载某个服务的配置文件,如果新安装了一个服务,归属于 systemctl 管理,要是新服务的服务程序配置文件生效,需重新加载。


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值