微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

004.开机启动新

一. 写在前面

centos7建议使用systemctl来管理服务的自启动,它能够满足之前service和chkconfig功能

  1. systemd有系统和用户区分;系统(/user/lib/systemd/system/)、用户(/etc/lib/systemd/user/)

  2. 一般系统管理员手工创建的单元文件建议存放在/etc/systemd/system/目录下面

  3. 创建service文件

[Unit]
Description=Nginx - high performance web server
Documentation=http://Nginx.org/en/docs/
After=network.target remote-fs.target nss-lookup.target
  
[Service]
Type=forking
PIDFile=/run/Nginx.pid
ExecStartPre=/usr/sbin/Nginx -t -c /etc/Nginx/Nginx.conf
ExecStart=/usr/sbin/Nginx -c /etc/Nginx/Nginx.conf
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
  
[Install]
WantedBy=multi-user.target
  1. 配置参数说明
    [Unit]

    Description : 服务的简单描述

    Documentation : 服务文档

    Before、After:定义启动顺序。Before=xxx.service,代表本服务在xxx.service启动之前启动。After=xxx.service,代表本服务在xxx.service之后启动。

    Requires:这个单元启动了,它需要的单元也会被启动;它需要的单元被停止了,这个单元也停止了。

    Wants:推荐使用。这个单元启动了,它需要的单元也会被启动;它需要的单元被停止了,对本单元没有影响。

    [Service]

    Type=simple(认值):systemd认为该服务将立即启动。服务进程不会fork。如果该服务要启动其他服务,不要使用此类型启动,除非该服务是socket激活型。

    Type=forking:systemd认为当该服务进程fork,且父进程退出后服务启动成功。对于常规的守护进程(daemon),除非你确定此启动方式无法满足需求,使用此类型启动即可。使用此启动类型应同时指定 PIDFile=,以便systemd能够跟踪服务的主进程。

    Type=oneshot:这一选项适用于只执行一项任务、随后立即退出的服务。可能需要同时设置 RemainAfterExit=yes 使得 systemd 在服务进程退出之后仍然认为服务处于激活状态。

    Type=notify:与 Type=simple 相同,但约定服务会在就绪后向 systemd 发送一个信号。这一通知的实现由 libsystemd-daemon.so 提供。

    Type=dbus:若以此方式启动,当指定的 BusName 出现在DBus系统总线上时,systemd认为服务就绪。

    Type=idle: systemd会等待所有任务(Jobs)处理完成后,才开始执行idle类型的单元。除此之外,其他行为和Type=simple 类似。

    PIDFile:pid文件路径

    ExecStart:指定启动单元的命令或者脚本,ExecStartPre和ExecStartPost节指定在ExecStart之前或者之后用户自定义执行的脚本。Type=oneshot允许指定多个希望顺序执行的用户自定义命令。

    ExecReload:指定单元停止时执行的命令或者脚本。

    ExecStop:指定单元停止时执行的命令或者脚本。

    PrivateTmp:True表示给服务分配独立的临时空间

    Restart:这个选项如果被允许,服务重启的时候进程会退出,会通过systemctl命令执行清除并重启的操作。

    RemainAfterExit:如果设置这个选择为真,服务会被认为是在激活状态,即使所以的进程已经退出认的值为假,这个选项只有在Type=oneshot时需要被配置。

    [Install]

    Alias:为单元提供一个空间分离的附加名字。

    requiredBy:单元被允许运行需要的一系列依赖单元,requiredBy列表从Require获得依赖信息。

    WantBy:单元被允许运行需要的弱依赖性单元,Wantby从Want列表获得依赖信息。

    Also:指出和单元一起安装或者被协助的单元。

    DefaultInstance:实例单元的限制,这个选项指定如果单元被允许运行认的实例。

  2. 常用操作

systemctl daemon-reload 修改配置后重载是配置生效
systemctl enable Nginx.service 开机启用服务
systemctl disable Nginx.service 禁用开机启动
systemctl is-enabled Nginx.service 判断服务是否开机状态
systemctl list-unit-files | grep enabled 查看开机启动状态服务列表
systemctl start Nginx.service 启动一个服务
systemctl stop postfix.service 关闭一个服务
systemctl restart Nginx.service 重启一个服务
systemctl status postfix.service 显示一个服务的状态

二. tomcat

  1. 环境准备

操作系统:CentOS 7(64位)
已安装JDK,并配置好环境变量
已安装tomcat,可手动启动,安装路径:/opt/tomcat/(可自定义

  1. 创建tomcat启动脚本setenv.sh在/bin路径下

catalina.sh在执行的时候会调用同级路径下的setenv.sh来设置额外的环境变量,因此需要在/opt/tomcat/bin路径下创建setenv.sh文件

export JAVA_HOME=/usr/lib/jvm/jdk1.8.0_121
export CATALINA_HOME=/opt/tomcat
export CATALINA_BASE=/opt/tomcat
#设置Tomcat的PID文件
CATALINA_PID="$CATALINA_BASE/bin/tomcat.pid"
#添加JVM选项
JAVA_OPTS="-server -XX:PermSize=256M -XX:MaxPermSize=1024m -xms512M -Xmx1024M -XX:MaxNewSize=256m"

  1. 在/usr/lib/systemd/system路径下添加tomcat.service文件
    注意:路径都使用绝对路径
[Unit]
Description=Tomcat8
After=syslog.target network.target remote-fs.target nss-lookup.target

[Service]
Type=forking

PIDFile=/opt/tomcat/bin/tomcat.pid
ExecStart=/opt/tomcat/bin/startup.sh
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true

[Install]
WantedBy=multi-user.target

  1. 重载配置的服务
systemctl daemon-reload
  1. 设置开机启动
systemctl enable tomcat.service
  1. 重启后测试结果

三. Nginx

  1. 在/usr/lib/systemd/system路径下添加Nginx.service文件
[Unit]
Description=Nginx
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/Nginx/sbin/Nginx
ExecReload=/usr/local/Nginx/sbin/Nginx -s reload
ExecStop=/usr/local/Nginx/sbin/Nginx -s quit
PrivateTmp=true

[Install]
WantedBy=multi-user.target
  1. 重载配置的服务
systemctl daemon-reload
  1. 设置开机启动
systemctl enable Nginx.service
  1. 重启后测试结果

Chen不旧 发布了36 篇原创文章 · 获赞 14 · 访问量 4万+ 私信 关注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐