diff --git a/server/tools/scripts/ci/masterserer2002/boundle.sh b/server/tools/scripts/ci/masterserer2002/boundle.sh new file mode 100644 index 0000000..9d1b066 --- /dev/null +++ b/server/tools/scripts/ci/masterserer2002/boundle.sh @@ -0,0 +1,14 @@ +cd third_party/game2001/server/masterserver +#python ../tools/scripts/construct/build_pb.py --nohooks 1 +cmake -DGAME_ID=2002 . +make clean +make +cp ../bin/masterserver ../../../../bin/ + +cd ../../../../ + +tag_name=`git status |grep '# On branch '|sed 's/# On branch //g'` +dir_name=`basename $PWD` +package_name=${dir_name}.tar.gz + +tar --exclude=*.git -chzf target/${package_name} bin reload.sh restart.sh start_instance.sh manage.py config diff --git a/server/tools/scripts/ci/masterserer2002/manage.py b/server/tools/scripts/ci/masterserer2002/manage.py new file mode 100755 index 0000000..438640a --- /dev/null +++ b/server/tools/scripts/ci/masterserer2002/manage.py @@ -0,0 +1,75 @@ +#!/usr/bin/python +#coding utf8 + +import os +import sys +import time + +def getRuningProgramPids(progname): + pids = [] + lines = os.popen('ps -ef | grep %s' % progname).readlines() + for l in lines: + line = '' + oldc = '' + for c in l.strip(): + if c in [' ', '\t'] and c == oldc: + continue + oldc = c + line += c + line = line.split(' ') + + if line[7] == './%s' % progname: + pids.append(line[1]) + return pids + +def getExePath(pid): + return os.popen('ls -l /proc/%d | grep "exe ->" | cut -d " " -f 7-' % int(pid)).read() + +def getExeCmdLine(pid): + return os.popen('cat /proc/%d/cmdline' % int(pid)).read() + +def stop(instance_id, node_id): + masterserver_ids = getRuningProgramPids('masterserver') + pids = masterserver_ids + for pid in pids: + exepath = getExePath(pid) + cmdline = getExeCmdLine(pid) + if cmdline == ("./masterserver\0-i\0%d\0-n\0%d\0" % (instance_id, node_id)): + os.popen('kill -9 %d' % int(pid)) + +def listServer(): + masterserver_ids = getRuningProgramPids('masterserver') + pids = masterserver_ids + for pid in pids: + exepath = getExePath(pid) + cmdline = getExeCmdLine(pid) + print(pid, exepath, cmdline) + +def restartServer(str_instance_ids, str_node_id): + instance_ids = str_instance_ids.split(',') + node_id = int(str_node_id) + for instance_id in instance_ids: + instance_id = int(instance_id) + stop(instance_id, node_id) + time.sleep(0.5) + print('masterserver %d starting......' % instance_id) + cmd = 'sh start_instance.sh %d %d' % (instance_id, node_id) + os.popen(cmd) + time.sleep(0.5) + +def printHelp(): + print('usuage: [restart]') + +def main(argv): + if len(argv) == 1: + printHelp() + else: + if argv[1] == 'restart': + restartServer(argv[2], argv[3]) + elif argv[1] == 'stop': + stop(argv[2], argv[3]) + elif argv[1] == 'list': + listServer() + +if __name__ == '__main__': + main(sys.argv) diff --git a/server/tools/scripts/ci/masterserer2002/reload.sh b/server/tools/scripts/ci/masterserer2002/reload.sh new file mode 100644 index 0000000..e69de29 diff --git a/server/tools/scripts/ci/masterserer2002/restart.sh b/server/tools/scripts/ci/masterserer2002/restart.sh new file mode 100755 index 0000000..7d3ed21 --- /dev/null +++ b/server/tools/scripts/ci/masterserer2002/restart.sh @@ -0,0 +1,5 @@ +#!/bin/bash + +python manage.py restart $1 $2 + +echo 'success' diff --git a/server/tools/scripts/ci/masterserer2002/start_instance.sh b/server/tools/scripts/ci/masterserer2002/start_instance.sh new file mode 100755 index 0000000..7537a25 --- /dev/null +++ b/server/tools/scripts/ci/masterserer2002/start_instance.sh @@ -0,0 +1,4 @@ +#!/bin/bash + +cd bin +nohup ./masterserver -i $1 -n $2>> masterserver$2_$1.out 2>&1 &