部署问题集合(十九)linux设置Tomcat、Docker,以及使用脚本开机自启(亲测)

前言

  • 因为不想每次启动虚拟机都要手动启动一遍这些东西,所以想要设置成开机自启的状态

设置Tomcat开机自启

  • 创建service文件
shell 复制代码
vi /etc/systemd/system/tomcat.service
  • 添加如下内容,注意修改启动脚本和关闭脚本的地址
shell 复制代码
[Unit]
Description=Tomcat9068
After=syslog.target network.target remote-fs.target nss-lookup.target

[Service]
Type=oneshot
ExecStart=/usr/local/tomcat/bin/startup.sh
ExecStop=/usr/local/tomcat/bin/shutdown.sh
ExecReload=/bin/kill -s HUP $MAINPID
RemainAfterExit=yes

[Install]
WantedBy=multi-user.target
  • 进入目录:cd /etc/systemd/system/
  • 设置开机自启:systemctl enable tomcat
  • 重新载入配置文件,使设置生效:systemctl daemon-reload
  • 重新启动看看效果:reboot(如果不能随便重启先别急哈哈)

设置Docker开机自启

  • 查看已启动的服务:systemctl list-units --type=service
  • 查看服务是否开机自启:systemctl list-unit-files | grep enable
  • 设置开机自启:systemctl enable docker.service

设置Docker容器开机自启

  • Docker容器启动时添加:--restart=always
  • 添加位置取决于你是通过命令启动还是Dockerfile或其他脚本
  • 若是已经启动的容器,通过updata进行更新:docker update --restart=always 容器id或name

使用脚本开机自启

  • 方法一:使用crontab启动脚本
shell 复制代码
#编辑定时任务
crontab -e
#添加如下内容,@reboot表示开机时执行
@reboot /home/evsoft/everyDayStart.sh
  • 方法二:使用systemd服务
shell 复制代码
#添加service文件
vi /etc/systemd/system/everyDayStart.service

#添加如下内容
[Unit]
Description=everyDayStart
After=default.target
 
[Service]
ExecStart=/home/evsoft/everyDayStart.sh
 
[Install]
WantedBy=default.target

#重新载入配置文件,使设置生效:
systemctl daemon-reload

#设置开机自启:
systemctl enable everyDayStart
  • 此时systemctl start everyDayStart.service可能会报错
    • 解决方案:
    • 在自定义脚本everyStartDay.sh的开头加上#!/bin/sh
    • 或缺少执行权限chmod +x everyStartDay.sh
    • 或编码格式错误,通过:set ff查看编码格式,并通过:set ff=unix修改编码格式

参考

相关推荐
刘一说1 分钟前
CentOS 系统 Java 开发测试环境搭建手册
java·linux·运维·服务器·centos
卷福同学8 分钟前
来上海三个月,我在马路边上遇到了阿里前同事...
java·后端
bingbingyihao2 小时前
多数据源 Demo
java·springboot
在努力的前端小白7 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
木易双人青7 小时前
01-Docker-简介、安装与使用
运维·docker·容器
一叶飘零_sweeeet9 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
艾伦~耶格尔10 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
一只叫煤球的猫10 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
最初的↘那颗心10 小时前
Flink Stream API 源码走读 - print()
java·大数据·hadoop·flink·实时计算
JH307311 小时前
Maven的三种项目打包方式——pom,jar,war的区别
java·maven·jar