如何在服务器里优雅地终止一个程序? (服务器里终止一个程序)


在服务器运维中,终止一个程序是非常常见的操作。一般情况下,我们可能会选择直接使用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()

关于服务器里终止一个程序的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。