如何使用systemd部署服务?

简介: 如何使用systemd部署服务?

1、前言


通常,我们在开发过程中,难免需要去部署我们的服务,但是,我们应该如何去做呢?如果主机重启了,服务怎么自己启动呢?可能你的心里已经有了几种不同的答案,接下来我们就一起看看吧。


2、如何部署服务


假设,我们现在有一个python项目(名为xx),现在我们想要将其部署在Linux服务器上,我们应该如何操作呢?


xx的内容


#!/usr/bin/python
import time
i=0
while True:
    print i
    i+=1
    time.sleep(60)
复制代码


2.1、后台进程方式启动


第一种方式,我们可以直接将这个项目以后台进程的方式进行启动。


nohup python xx &
复制代码


2.2、使用systemd方式启动


第二种方式,我们可以通过systemd将项目进行托管。


关于systemd:systemd是Linux平台的一款软件,其支持以守护进程方式启动任务,支持cgroup资源隔离,可以非常高效的在Linux启动过程中加载我们的服务。


2.2.1、创建service文件


xx文件所在路径:/root/

service文件所在路径:/etc/systemd/system/


xx.service内容


[Unit]
Description=myself service
[Service]
ExecStart=/root/xx
[Install]
WantedBy=multi-user.target
复制代码


由于我们在xx文件中定义了解释器,所以我们可以直接给xx增加可执行权限,在启动命令中直接指定xx的路径即可。


2.2.2、启动服务


指定service文件使能xx服务的命令:


systemctl -f enable /etc/systemd/system/xx.service
复制代码


启动xx服务:



查看xx服务状态:


systemctl status xx
复制代码


网络异常,图片无法展示
|


3、如何自动启动


3.1、自动启动文件

3.1.1、rc.local


对于后台进程部署的服务,我们可以将启动命令添加到开机自启文件中。

自动启动文件路径:/etc/rc.local


3.1.2、rc.d


我们除了可以将启动命令直接加入到rc.local文件中,也可以直接将可执行脚本移动到/etc/rc.d/init.d/路径下。


3.2、systemd


systemd默认会在服务器启动的时候启动我们的服务,因为我们已经enable了服务。但是我们为了防止服务在异常退出后无法恢复,我们可以向service文件中增加[Service]配置块中增加Restart=on-failure的配置以达到当服务异常退出的时候自动重启服务的效果。

相关文章
|
存储 大数据 数据库
电商数据分析-02-电商业务介绍及表结构
电商数据分析-02-电商业务介绍及表结构
|
Prometheus 监控 异构计算
阿里云容器服务GPU监控2.0基础篇3:监控NVIDIA XID错误
本系列相关文章:阿里云容器服务GPU监控2.0基础篇1:基本功能使用阿里云容器服务GPU监控2.0基础篇2:监控NVLINK带宽阿里云容器服务GPU监控2.0基础篇3:监控NVIDIA XID错误阿里云容器服务GPU监控2.0进阶篇1:剖析(Profiling)GPU使用情况必备知识阿里云容器服务GPU监控2.0进阶篇2:学会剖析(Profiling)GPU使用情况本篇文章将向您介绍如何使用GPU
9042 0
阿里云容器服务GPU监控2.0基础篇3:监控NVIDIA XID错误
|
Web App开发 自然语言处理 安全
免费IDM下载器序列号2023Internet Download Manager许可证
由于是付费的,很多人都在使用版的 IDM,它通常包含对您的计算机系统有害的恶意软件。为了克服这个问题,我们带着一份免费IDM序列号2023的工作清单来到这里。它将帮助您轻松访问 Internet 下载管理器的所有高级功能。
13242 0
|
8月前
|
算法 数据可视化 机器人
《从代码混乱到架构清晰:经营类游戏NPC行为系统重构指南》
本文以古风山水经营游戏开发实践为核心,分享NPC行为系统从机械执行到环境共生的技术优化路径。初期因架构缺乏扩展性,简单条件判断设计在需求迭代后陷入维护困境,经模块化重构与行为树设计破解耦合问题。后续围绕真实感与系统联动展开技术突破:构建需求层次与环境因子双重驱动模型,让NPC随天气、资源动态调整行为;引入隐性信号与分帧更新,解决群体行为冲突与性能问题;以事件驱动架构打通环境、NPC与经济系统,实现霜降等事件的连锁响应;通过NPC行为设计调控经济,化解低阶道具泛滥;采用组件化与规则引擎,保障系统长期可扩展性,最终显著提升玩家沉浸感与互动频次。
750 1
|
算法 应用服务中间件 测试技术
接入层限流之ngx_http_limit_req_module
ngx_http_limit_req_module模块是Nginx提供的基于漏桶算法实现的请求限流模块,用于对指定KEY对应的请求进行限流,比如按照IP维度限制请求速率。
1819 0
接入层限流之ngx_http_limit_req_module
|
分布式计算 并行计算 调度
基于HPC场景的集群任务调度系统LSF/SGE/Slurm/PBS
在HPC场景中,集群任务调度系统是资源管理和作业调度的核心工具。LSF、SGE、Slurm和PBS是主流调度系统。LSF适合大规模企业级集群,提供高可靠性和混合云支持;SGE为经典开源系统,适用于中小规模集群;Slurm成为HPC领域事实标准,支持多架构和容器化;PBS兼具商业和开源版本,擅长拓扑感知调度。选型建议:超大规模科研用Slurm,企业生产环境用LSF/PBS Pro,混合云需求选LSF/PBS Pro,传统小型集群用SGE/Slurm。当前趋势显示Slurm在TOP500系统中占比超60%,而商业系统在金融、制造等领域保持优势。
3282 32
|
机器学习/深度学习 传感器 人工智能
2024.11|全球具身智能的端到端AI和具身Agent技术发展到哪里了
2024年,具身智能领域取得显著进展,特别是在端到端AI控制系统和多模态感知技术方面。这些技术不仅推动了学术研究的深入,也为科技公司在实际应用中带来了突破。文章详细介绍了端到端AI的演化、自监督学习的应用、多模态感知技术的突破、基于强化学习的策略优化、模拟环境与现实环境的迁移学习、长程任务规划与任务分解、人机协作与社会交互能力,以及伦理与安全问题。未来几年,具身智能将在多模态感知、自监督学习、任务规划和人机协作等方面继续取得重要突破。
1118 2
|
JavaScript
elementUI/Plus 输入框按回车刷新页面分析与解决
elementUI/Plus 输入框按回车刷新页面分析与解决
elementUI/Plus 输入框按回车刷新页面分析与解决
|
传感器 人工智能 自动驾驶
【Android App】物联网实战项目之自动驾驶的智能小车(附源码和演示 超详细)
【Android App】物联网实战项目之自动驾驶的智能小车(附源码和演示 超详细)
831 2
|
Oracle 关系型数据库 数据库
SqlAlchemy 2.0 中文文档(五十一)(3)
SqlAlchemy 2.0 中文文档(五十一)
531 1

热门文章

最新文章