springcloud打成jar包运行在centos7
文章目录
- 启动
- 关闭
- 脚本
- 限制内存
启动
在CentOS 7云服务器上,若希望通过systemctl命令来管理服务,并部署启动多个使用IDEA中的Maven插件打包的JAR包,可以遵循以下步骤。同时,我还将提供一个命令来同时启动所有服务。
一、前期准备
获取JAR包:
请确保已利用IDEA中的Maven插件对多模块Maven项目进行了打包,并成功生成了多个JAR包。
准备CentOS 7服务器:
请确认服务器上已安装Java环境,因为Spring Boot应用需要Java支持。
Maven的安装对于运行JAR包并非必需,但可能对后续操作有所帮助(例如,用于依赖管理或项目构建)。
二、将JAR包上传至服务器
连接到CentOS 7服务器:
使用SSH客户端(例如PuTTY、SecureCRT等)远程连接到CentOS 7服务器。
上传JAR包:
利用SCP命令或FTP工具,将JAR包上传至服务器的指定目录,例如/opt/myapp/jars/。
三、创建systemd服务单元文件
为每个JAR包创建一个systemd服务单元文件,例如:
为app1.jar创建/etc/systemd/system/myapp1.service文件。
为app2.jar创建/etc/systemd/system/myapp2.service文件。
(此处以myapp1.service为例展示服务单元文件的内容)
[Unit]
Description=My App 1
After=network.target
[Service]
User=yourusername # 替换为运行服务的用户名
Group=yourgroupname # 替换为运行服务的用户组
WorkingDirectory=/opt/myapp/jars/ # JAR包所在目录
ExecStart=/usr/bin/java -jar app1.jar # 启动JAR包的命令
SuccessExitStatus=143 # 允许systemd在停止服务时返回143状态码(表示正常退出)
StandardOutput=syslog # 将标准输出重定向到syslog
StandardError=syslog # 将标准错误重定向到syslog
SyslogIdentifier=myapp1 # syslog的标识符
Restart=on-failure # 如果服务失败则自动重启
[Install]
WantedBy=multi-user.target # 指定服务应在哪个运行级别下被自动启动
请为其他JAR包重复上述步骤,并确保修改相应的Description、User、Group、WorkingDirectory和ExecStart等参数。
四、启用并启动服务
重新加载systemd守护进程:
sudo systemctl daemon-reload
启用服务(以便在系统启动时自动启动):
sudo systemctl enable myapp1.service
sudo systemctl enable myapp2.service
… 根据需要为其他服务也执行启用操作
同时启动所有服务:
为了同时启动所有服务,可以创建一个shell脚本,或使用systemctl的批量操作功能(如果服务名称遵循一定的命名规则)。以下是一个简单的shell脚本示例:
#!/bin/bash
定义一个数组来存储服务名称
services=("myapp1.service" "myapp2.service" /* ... 可根据需要添加其他服务名称 */)
遍历数组并启动每个服务
for service in "${services[@]}"; do
sudo systemctl start "$service"
done
将上述脚本保存为start_all_services.sh,然后为其赋予执行权限并运行:
chmod +x start_all_services.sh
./start_all_services.sh
或者,如果服务名称遵循myapp*.service的模式,可以直接使用以下命令启动所有匹配的服务:
for service in $(systemctl list-units --type=service --state=inactive --no-pager | grep 'myapp\..*\.service' | awk '{print $1}'); do
sudo systemctl start "$service"
done
但请注意,上述命令是一个较为粗糙的示例,可能需要根据实际情况进行调整。
检查服务状态以确保它们正在运行:
sudo systemctl status myapp1.service
sudo systemctl status myapp2.service
… 根据需要为其他服务也执行状态检查操作
五、验证与测试
检查服务日志以获取更多信息:
sudo journalctl -u myapp1.service -f
sudo journalctl -u myapp2.service -f
… 根据需要为其他服务也执行日志检查操作
通过浏览器或其他客户端测试您的应用功能以确保一切正常。
通过上述步骤,应该能够在CentOS 7云服务器上成功部署并启动多个使用IDEA中的Maven插件打包的JAR包,并使用systemctl命令来管理服务。如果遇到任何问题,请检查日志文件以获取更多信息,并根据需要进行调整。
关闭
要关闭通过start_all_services.sh脚本启动的服务,有几个选项。由于使用的是systemctl来管理服务,因此最直接的方法是使用systemctl来停止这些服务。以下是如何操作的步骤:
列出所有服务:
首先,需要知道哪些服务是通过脚本启动的。如果已经有一个服务列表(如在脚本中定义的那样),则可以直接使用这些名称。
停止服务:
使用systemctl stop命令来停止每个服务。例如,如果要停止myapp1.service和myapp2.service,可以运行:
sudo systemctl stop myapp1.service
sudo systemctl stop myapp2.service
如果有很多服务,并且想要自动化这个过程,可以编写一个类似的脚本来停止它们:
#!/bin/bash
定义一个数组来存储服务名称
services=("myapp1.service" "myapp2.service" /* ... 根据需要添加其他服务名称 */)
遍历数组并停止每个服务
for service in "${services[@]}"; do
sudo systemctl stop "$service"
done
将上述脚本保存为stop_all_services.sh,然后为其赋予执行权限并运行:
chmod +x stop_all_services.sh
./stop_all_services.sh
检查服务状态(可选):
停止服务后,可以使用systemctl status命令来检查它们是否已成功停止:
sudo systemctl status myapp1.service
sudo systemctl status myapp2.service
… 根据需要为其他服务也执行状态检查操作
由于是通过systemctl启动的服务,因此不需要知道进程的PID(进程号)就可以停止它们。systemctl会管理服务的生命周期,包括启动、停止、重启和状态检查。
如果确实需要知道某个服务的进程号(例如,为了进行某些特定的系统级操作),可以使用ps命令结合grep来查找它,但通常这不是停止服务的必要步骤。例如:
ps aux | grep myapp1.jar | grep -v grep
这个命令会列出所有与myapp1.jar相关的进程,但请注意,由于是通过systemctl管理的服务,直接查找JAR文件的进程可能不是最佳实践。更好的方法是依赖systemctl提供的工具来管理服务。
脚本
当运行chmod +x start_all_services.sh给脚本添加执行权限,并随后通过./start_all_services.sh执行该脚本时,脚本的执行确实会占用一定的内存和CPU资源,因为它是在一个单独的shell进程中运行的。但是,这个脚本进程本身并不直接占用大量内存,除非脚本内部执行了非常消耗资源的操作。
重要的是要理解,start_all_services.sh脚本的作用是启动其他服务或进程。当脚本执行时,它会创建或触发其他进程(比如通过systemctl start命令启动的服务),而这些进程是独立于脚本进程的。因此,当“停止了所有服务”时,您实际上是在停止那些由脚本启动的服务进程,而不是脚本进程本身。
启动脚本是否占内存:是的,start_all_services.sh脚本在执行时会占用一定的内存和CPU资源。但是,这个占用通常是很小的,除非脚本中包含了大量的数据处理或复杂的逻辑。
是否有对应的进程号需要被杀掉:通常不需要。一旦start_all_services.sh脚本执行完毕(即它启动了所有需要的服务并完成了其他任务),它就会退出,并且其进程会被系统自动清理。除非脚本进入了某种循环或挂起状态,否则您不需要手动杀死它。
停止脚本:实际上,通常不需要一个单独的stop_all_services.sh脚本来停止由start_all_services.sh启动的服务,因为已经可以通过systemctl stop命令来停止每个服务。但是,如果确实编写了一个stop_all_services.sh脚本来简化这个过程,那么当运行这个停止脚本时,它也会像启动脚本一样,在执行期间占用一定的内存和CPU资源,但同样地,一旦它完成了停止服务的任务并退出,其进程也会被清理。
综上所述,除非遇到特定的问题(比如脚本挂起或无限循环),否则不需要担心启动或停止脚本本身的进程占用或需要被杀死。应该更多地关注那些由脚本启动或停止的服务的状态和资源占用。
文件权限:
确保 cubemall-common.service 文件具有正确的权限,以便 systemd 可以读取它。通常,这个文件的权限应该是 -rw-r–r–(644),并且应该位于 /etc/systemd/system/ 目录中。
限制内存
在服务的[Service]部分中,添加MemoryLimit参数来设置内存限制。例如,要将内存限制设置为500MB,你可以添加以下行:
[Service]
MemoryLimit=500M
或者,如果你想要设置更严格的限制,包括物理内存和交换内存的总和,你可以使用MemoryMax参数。例如,将总内存限制设置为600MB:
[Service]
MemoryMax=600M
请注意,MemoryLimit和MemoryMax的区别在于,MemoryLimit仅限制物理内存的使用,而MemoryMax则限制物理内存和交换内存的总和。