如何在服务器里优雅地终止一个程序? (服务器里终止一个程序)
在服务器运维中,终止一个程序是非常常见的操作。一般情况下,我们可能会选择直接使用kill命令来关闭程序,但是这种方式有时会造成数据丢失或者程序无法正常关闭的情况。因此,在服务器里优雅地终止一个程序是非常重要的一项技能。下面,我们就来介绍一些常见的优雅终止程序的方法。
1. 使用kill命令
kill命令是最常见的终止程序的方式,它可以发送信号给进程来终止程序。如果我们想优雅地关闭程序,可以使用kill -TERM PID命令。这条命令会发送一个终止信号给进程,并等待进程完成后再退出。如果进程没有正确地退出,可以使用kill -KILL PID命令来强制终止进程。
2. 使用killall命令
killall命令可以批量终止进程,如果我们想要优雅地终止所有同名进程,可以使用killall -TERM program_name命令。这条命令会发送一个终止信号给所有同名进程,并等待进程完成后再退出。如果进程没有正确地退出,可以使用killall -KILL program_name命令来强制终止所有同名进程。
3. 使用pkill命令
pkill命令可以根据进程名和其他条件来批量终止进程,如果我们想要优雅地终止一个进程,可以使用pkill -TERM program_name命令。这条命令会发送一个终止信号给所有符合条件的进程,并等待进程完成后再退出。如果进程没有正确地退出,可以使用pkill -KILL program_name命令来强制终止所有符合条件的进程。
4. 使用systemctl命令
如果程序是通过systemd服务运行的,我们可以使用systemctl命令来优雅地终止程序。我们可以使用systemctl status program.service命令来查看服务的状态,如果服务正在运行,则可以使用systemctl stop program.service命令来停止服务。这条命令会发送一个终止信号给服务,并等待服务完成后再退出。如果服务没有正确地关闭,可以使用systemctl kill program.service命令来强制终止服务。
5. 使用服务端信号
有些高级程序会支持使用服务端信号来终止程序,例如Nginx和Apache等。我们可以使用nginx -s stop或者apachectl -k stop命令来优雅地终止程序。这条命令会发送一个终止信号给程序,并等待程序完成后再退出。如果程序没有正确地终止,可以使用nginx -s quit或者apachectl -k graceful-stop命令来强制终止程序。
终止进程是服务器运维中非常常见的操作,但要想避免数据丢失和程序无法正常关闭的情况发生,需要我们优雅地终止程序。本文介绍了五种不同的优雅终止程序的方法,包括使用kill命令、killall命令、pkill命令、systemctl命令和服务端信号。我们可以根据具体情况选择合适的方式来终止程序,以避免程序出现异常。
相关问题拓展阅读:
- 服务器应用程序池老是自动停止
- Python中如何在一段时间后停止程序
服务器应用程序池老是自动停止
一、2023应用程序池自动死了,不能恢复了,一直出现 Service Unavailable 常见方法如下。
1:没有打培桐SP1补丁的时候会出现这个IIS6.0假死问题,但现在微软都在自动更新里面出补丁了,一般你打好最新补丁后是不会出现此问题了。(所以现在的IIS假死与这个关系不是很大)
2:从IIS6.0开始CPU资源都在应用池里面限制了,不象以前的IIS.5。所以假死的池的缘故就是池被拉死,你在网站打不开的时候可以看到你的某个应用池是禁用的,上面出现一个红叉。你鼠标右键启动网站又会自动恢复。 这个原因:大概是以下几个因数造成的。
(1):你限制了应用池的资源,限制得太小 比如:50这样或更少更多一点,这个时候如果你这个池下面的配汪坦网站占用CPU太高,比如超过50% 那么5分钟后他就自动死了,手工默认建立的应用池默认是超过资源不操作。
出现上面这个情况解决方法:1:不限制CPU资源,(这个是不可取的,不限制资源,有的程序有BUG占用资源厉害了的,服务器都会被拉死,你可能都无法操作服务器。)2:在超过资源那里选择关闭,这个关闭默认是失败5次,90秒内恢复,一般默认就可。网站能自动恢复,这个关闭:不是永久关闭,意思是超过资源关闭,然后在某时间内自动恢复池。不操作就是不恢复,这个是很多人的误区。
(2):内存限制 在IIS6.0应用池上面有虚拟内存和更大内存限制,如果你设置了这个。那么网站访问量大了 也会出现假死,所以不建议设置这里。默认就可。
3:就是服务器自身内存太小,网站运行当然需要使用到内存了,当内存不够的时候应用池也会死掉变成禁用。那么只有等内存全部释放出来才能恢复应用池了。出现这个情况:那么你就要考虑加内存或者检查到底是什么程陵宴序占用了内存了。比如MSSQL数据库,这个可是吃内存得大户啊,更好别和WEB服务器同时一个服务器上。很多人用1G内存做 2023系统,2023NET结构是很占用内存的,所以做服务器选2023还得把内存加到2G或更高才好。 内存不够上面 2点讲到的,是没办法操作了,也无法自动恢复。
4:就是ACCESS数据库太大或查询太多,这个也会出现把IIS拉死,解决方法;修复ACCESS数据库,或尽量少用ACCESS数据库,升级至sqlserver数据库;或者在技术方面革新,像现在有些网站系统,风讯、动易等cms;pjblog、zblog等博客程序,都支持生成静态功能.
5:不同网站用不同应用池:根据你自己实际情况而定,站点大的更好独立一个应用池,限制他的资源超过了自动回收,看上面(1)讲到的,这样就不影响其他站点。中型站点:多个网站共用一个应用池,比如5个站点用一个池,设置他资源时间等等。这样他们就算超资源了也不影响其他应用池的网站。
6:设置回收时间:很多人以为设置回收池越短越好,其实是错误的,每次回收当然是把内存回收回来了,但加重了一次服务器的负担,当服务器比较繁忙的时候,有可能导致其他应用池死。所以建议设置共1000就行了。其他独立池按照他网站流量而设置 可以设置600 也行,共用的不建议设置太短。
7:网站后台过不了多久自动退出又要重新登陆:这个情况就是你设置回收时间太短了,按照 6点设置吧。 不要设置什么20分、30分这样的,这样不好的。另外一个原因就是和站的响应设置时间有关,设置得稍长些。
8:windows 2023系统iis6访问本机的站点时提示“Service Unavailable”;
查看iis的应用程序池,状况提示为:未指定错误,同时应用程序池自动停止运行;
一般情况出现这个情况是你的应用池冲突,如果你有茄搭多个web站点或用了喊返不郑纳饥同的.net架构如(.net2 net3 net3.5等),建议你多加几个应用池。
Python中如何在一段时间后停止程序
用装饰器能做到。不过有点技巧
用到threading的Timer,也类似
单片机
那样子,在中断程序中再重置定时器,设置中断,python实例代码如下:
import threading
import time
def change_user():
print(‘这是中断,切换账号’)
t = threading.Timer(3, change_user)
t.start()
#每过3秒切换一次账号
t = threading.Timer(3, change_user)
t.start()
while True:
print(‘我在爬数据’)
time.sleep(1)
扩展资料
有时当一个条件成立的情况下,需要终止程序,可以使用sys.exit()退出程序胡孙。sys.exit()会引发一个异常:
1、如果这个异常没有被捕获,那么python
编译器
将会退出,后面的程序将不会执行。
2、如果这个异常被捕获(try…except…finally),捕获这个异常可以做一些额外的清理工作,后面的程序还会继续执行。
注:0为正常退出,其他数值(1-127)为不正常,可抛异常事租扒件供捕获。另一种终止程序的方法os._exit()
一般情况下使用sys.exit()即可,一般在fork出弊做昌来的子进程中使用os._exit()
采用sys.exit(0)正常终止程序,程序终止后shell运行不受影响。
采用os._exit(0)关闭整个shell,调用sys._exit(0)后整个shell都重启了(RESTART Shell)。
#python 2.7
import time #导入 time类
start=time.clock()
def func(a,b):
while True:
end=time.clock ()
if int(end-start)==10:
print(‘Warning: Timeout!!’*5)
break
a=a+b
print a
func(1,2)
主闭迅竖要思路昌辩:开始时间-当前时间=10则停止运行并轿大输出时间到了(注意缩进)
建议你另起一个timer的线程,计算时间并输出警告。送你一段定时器timer的代码。
使用前先做一个简单试验袭镇:
import threading def sayhello():
print “hello world”
global t#Notice: use global variable!
t = threading.Timer(5.0, sayhello)
t.start()
t = threading.Timer(5.0, sayhello)
t.start()
运行结果如下
>python hello.py
hello world
hello world
hello world
下面是定时器类的实现:
class Timer(threading.Thread):”””
very simple but useless timer.
“猜禅脊””
def __init__(self, seconds):
self.runTime = seconds
threading.Thread.__init__(self)
def run(self):
time.sleep(self.runTime)
print “Buzzzz!! Time’s up!”
class CountDownTimer(Timer):
“””
a timer that can counts down the seconds.
“””
def run(self):
counter = self.runTime
for sec in range(self.runTime):
print counter
time.sleep(1.0)
counter -= 1
print “Done”
class CountDownExec(CountDownTimer):
“穗渗””
a timer that execute an action at the end of the timer run.
“””
def __init__(self, seconds, action, args=):
self.args = args
self.action = action
CountDownTimer.__init__(self, seconds)
def run(self):
CountDownTimer.run(self)
self.action(self.args)
def myAction(args=):
print “Performing my action with args:”
print args
if __name__ == “__main__”:t = CountDownExec(3, myAction, )
t.start()
关于服务器里终止一个程序的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。