博客
关于我
CentOS7利用Systemd添加用户自定义系统服务
阅读量:603 次
发布时间:2019-03-12

本文共 1501 字,大约阅读时间需要 5 分钟。

在CentOS7系统中,通过Systemd管理Java项目服务是一项非常实用的操作方法。下面将详细介绍如何配置一个自定义的Systemd服务。

一、创建服务文件

首先,进入 /usr/lib/systemd/system/ 目录,创建一个名为 service-demo.service 的文件。文件内容如下:

[Unit]Description=我的示例服务After=network.target[Service]Type=forkingExecStart=/home/bee/apps/service-demo.sh startExecReload=/home/bee/apps/service-demo.sh restartExecStop=/home/bee/apps/service-demo.sh stopPrivateTmp=True[Install]WantedBy=multi-user.target

二、设置权限

为避免权限问题,对服务文件进行权限设置:

chmod 644 /usr/lib/systemd/system/service-demo.service

这将确保文件的读写权限仅限于拥有者和特定的用户组。

三、启用服务

使用以下命令启用服务,确保服务在开机时自动启动:

systemctl enable service-demo.service

这将创建一个符号链接,如:

Created symlink '/etc/systemd/system/multi-user.target.wants/service-demo.service' → '/usr/lib/systemd/system/service-demo.service'

四、启动、重启和停止服务

通过以下命令控制服务的运行:

  • 启动:

    systemctl start service-demo.service
  • 停止:

    systemctl stop service-demo.service
  • 重启:

    systemctl restart service-demo.service
  • 检查状态:

    systemctl status service-demo.service

五、可选配置(高级应用)

  • 指定用户和组

    修改 [Service] 部分,添加 User=youruserGroup=yourgroup,以指定运行时的用户和组。

  • 指定PID文件

    添加 PIDFile=/home/YOURUSER/.pid,以记录服务的PID。

  • 资源限制

    为防止资源耗尽,可以设置 LimitCPU=LimitMemory=,例如:

    LimitCPU=-1LimitMemory=500M
  • 日志输出

    为了确保日志正确输出,可以使用 nohup 和重定向:

    在脚本中用:

    nohup /path/to/your/script.sh > /path/to/logfile.log 2>&1 &

六、停止服务(强制重载)

在某些情况下,服务可能不响应,可以使用以下命令强制停止并重载:

systemctl force-reload service-demo.service

注意事项

  • 确保所有脚本路径均为绝对路径,以避免相对路径导致的问题。
  • 如果服务依赖于特定用户登录(例如,使用-u选项),请在[Service]中指定用户。
  • 如果您遇到权限问题,可以尝试使用sudo执行相关命令。

通过以上步骤,您可以成功地将自定义Java项目配置为CentOS7的Systemd服务,确保其自动启动并在系统运行中顺利运行。

转载地址:http://lijxz.baihongyu.com/

你可能感兴趣的文章
Oracle 常用命令
查看>>
Oracle 常用的V$视图脚本(二)
查看>>
Oracle 并行原理与示例总结
查看>>
oracle 并集 时间_Oracle集合运算符 交集 并集 差集
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
ORACLE 异常错误处理
查看>>
oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
查看>>
oracle 批量生成建同义词语句和付权语句
查看>>
oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
查看>>
Oracle 拆分以逗号分隔的字符串为多行数据
查看>>
Oracle 排序中使用nulls first 或者nulls last 语法
查看>>
oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
查看>>
Oracle 操作笔记
查看>>
oracle 数据库 安装 和优化
查看>>
oracle 数据库dg搭建规范1
查看>>
Oracle 数据库常用SQL语句(1)
查看>>
Oracle 数据库特殊查询总结
查看>>
Oracle 数据类型
查看>>
Oracle 数据自动备份 通过EXP备份
查看>>
oracle 数据迁移 怎么保证 和原表的数据顺序一致_一个比传统数据库快 1001000 倍的数据库,来看一看?...
查看>>