我的新手游项目很快就要进入到寻找发行商的环节,最近几天相对较空闲,逐将工作重心转移到服务器组运维工具的制作上.

回想一年之前经历的那个不算成功的端游项目,因为运维工具设计得不合理,使用十分不方便,游戏上线之后搞得我焦头烂额的.

之前一直没碰过web相关的技术,最近几天猛看了下php和javascript相关的东西,逐决定用web的方式实现一套游戏服务器的运维和gm管理工具.

这个系统的目标:

  • 按逻辑和物理机器的方式管理服务(包括监控,启动,关闭等)
  • 当机器或服务出现异常的时候自动向预先设定的邮件地址发送邮件
  • 控制目标机器执行版本升级任务
  • 提供gm管理工具以方便运维人员查看游戏的运行状况,发送游戏公告等.

下面是这套系统雏形的两个截图:

这两张截图展示的是服务器的管理界面.左边是一个有两个标签的树形控件.第一个标签是物理视图,第二个是逻辑视图.右边是监控界面和3个控制按扭.

监控界面按用户在左边选择的节点来展示监控信息.例如如果用户选择的是物理视图中的一个根节点,如192.168.0.87.则右边的界面上就会显示目标机器的状态以及运行在目标机器上进程的状态.而控制按扭则分别用于启动/关闭/强杀一个或一组服务.

下面简单的介绍下系统的实现.

首先所有的监控数据,管理系统的用户及权限数据,服务器配置数据都被保存到一台中央ssdb服务上.

每台物理机器运行一个daemon服务,每隔一秒收集机器状态信息和上面运行的服务信息并将信息发送到中心ssdb服务上.同时daemon上启动一个简单的http服务,用于处理发送到这台机器上的操作请求.

下面是daemon的代码:

local Sche = require "lua.sche"
local Redis = require "lua.redis"
local Cjson = require "cjson" local deployment={
{groupname="central",service={
{type="ssdb-server",logicname="ssdb-server",conf="ssdb.conf",ip="192.168.0.87"},
}
},
{groupname="group1",service={
{type="groupserver",logicname="groupserver",ip="192.168.0.87",port="8010"},
{type="gameserver",logicname="gameserver",ip="192.168.0.87",port="8011"},
{type="gateserver",logicname="gateserver",ip="192.168.0.87",port="8012"},
}
},
{groupname="group2",service={
{type="groupserver",logicname="groupserver",ip="192.168.0.88",port="8010"},
{type="gameserver",logicname="gameserver",ip="192.168.0.88",port="8011"},
{type="gateserver",logicname="gateserver",ip="192.168.0.88",port="8012"},
}
},
} local function split(s,separator)
local ret = {}
local initidx = 1
local spidx
while true do
spidx = string.find(s,separator,initidx)
if not spidx then
break
end
table.insert(ret,string. sub(s,initidx,spidx-1))
initidx = spidx + 1
end
if initidx ~= string.len(s) then
table.insert(ret,string. sub(s,initidx))
end
return ret
end local err,toredis = Redis.Connect("127.0.0.1",6379,function () print("disconnected") end)
if not err then
toredis:Command("set deployment " .. Cjson.encode(deployment))
AddTopFilter("distrilua")
AddTopFilter("ssdb-server")
while true do
local machine_status = Top()
print(machine_status)
local tb = split(machine_status,"\n")
local machine = {}
local i = 1
while i <= #tb do
if tb[i] ~= "process_info" then
table.insert(machine,tb[i])
else
i = i + 1
break
end
i = i + 1
end
local process = {}
while i <= #tb do
if tb[i] ~= "" then
local tmp = {}
local cols = split(tb[i],",")
for k,v in pairs(cols) do
local keyvals = split(v,":")
tmp[keyvals[1]] = keyvals[2];
end
table.insert(process,tmp)
end
i = i + 1
end local str = string.format("hmset MachineStatus 192.168.0.87 %s",CBase64.encode(Cjson.encode({machine,process})))
toredis:Command(str)
--toredis:Command("set machine " .. CBase64.encode(Cjson.encode(machine)))
--toredis:Command("set process " .. CBase64.encode(Cjson.encode(process)))
Sche.Sleep(1000)
end
else
Exit()
end

daemon服务运行在distri.lua环境之上,所以是用lua编写的.

这段代码首先定义了一个叫做deployment的lua表,这个表就是服务器组的逻辑和物理配置信息.这个配置表将会被转换成json字符串并保存到ssdb的deployment字段中.之后尝试连接ssdb服务,如果连接成功则添加两个信息收集的过滤器ssdb-serverdistrilua添加了这两个过滤器之后每轮循环调用Top函数收集信息的时候就只会收集进程名为ssdb-serverdistrilua的进程的信息.收集到数据之后经过一些处理然后转换成json字符串接着保存到ssdb的MachineStatus相关对象的ip下面.

http相关的处理在这里尚未实现所以暂时不介绍.

接下来是manage.php,这个是用户控制界面的文件.这个文件使用了名为webix的js ui库.

		function fetchdata(){
createXMLHttpRequest();
var url="info.php";
xmlHttp.open("GET",url,true);
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded; charset=UTF-8");
xmlHttp.onreadystatechange = callback;
xmlHttp.send(null);
} function callback(){
if(xmlHttp.readyState == 4){
if(xmlHttp.status == 200){
var info = JSON.parse(xmlHttp.responseText);
var deploydata = info.deployment;
var machinedata = info.machine_status;
if(firstrun){
webix.message("first");
buildDeployPhyTree(deploydata);
buildPhyTree(machinedata);
buildPhyView();
buildDeployLogTree(deploydata);
buildLogicalTree();
buildLogView();
}else{
buildPhyTree(machinedata);
buildLogicalTree();
updatePhyView();
updateLogView();
}
ShowStatus();
firstrun = false;
setTimeout("fetchdata()",1000);
}
}
}

这个文件的关键部分是这两个函数,fetchdata用于向服务器请求数据.这个请求被发往info.php页面.数据受到之后在callback中将数据转换成json对象然后根据数据构建视图.最后设置一个1秒钟的超时,超时之后继续向服务器请求数据.

接下来我们看下info.php:

<?php
header("cache-control:no-cache,must-revalidate");
header("Content-Type:text/html;charset=utf8"); function split_line($input,$separator){
$ret = array();
$line = strtok($input,$separator);
while($line != ""){
array_push($ret,$line);
$line = strtok($separator);
}
return $ret;
}
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$deployment = $redis->get('deployment');
$machine_status = $redis->hGetAll('MachineStatus');
$outputstr = "{\"deployment\":$deployment,\"machine_status\":[";
$first = true;
while(list($ip,$info) = each($machine_status)){
if($first){
$first = false;
}else{
$outputstr = $outputstr + ",";
}
$outputstr = $outputstr . "{\"ip\":\"$ip\",\"status\":" . base64_decode($info) . "}";
}
$outputstr = $outputstr . "]}";
echo $outputstr;
?>

处理相当简单,受到请求后向ssdb请求数据,然后将数据组合成一个json字符串返回给客户端.

感兴趣的朋友可以关注https://github.com/sniperHW/distri.lua,在examples目录下找到相关的文件.

distri.lua的web运维工具的更多相关文章

  1. CheungSSH国产自动化运维工具开源Web界面

    CheungSSH web2.0 发布文档 CheungSSH 简介 CheungSSH是一款国人自主研发的Linux运维自动化管理服务器软件,秉着为企业降低运营成本,解放管理员双手和自动化生产的理念 ...

  2. 【运维工具】Git代码发布系统

    引言 代码发布系统是互联网公司必备的运维系统,作用主要用户发布业务代码 到 业务服务器 为什么需要代码发布系统 有的同学可能说,我们公司服务器就那么一台,做个发布系统太麻烦了? 不认同这说法 发布系统 ...

  3. Linux实战教学笔记25:自动化运维工具之ansible (一)

    第二十五节 ansible之文件的批量分发 标签(空格分隔): Linux实战教学笔记-陈思齐 ---本教学笔记是本人学习和工作生涯中的摘记整理而成,此为初稿(尚有诸多不完善之处),为原创作品,允许转 ...

  4. 自动化运维工具——ansible详解(一)

    ansible 简介 ansible 是什么? ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.chef.func.fabric)的优点,实现了批量系统 ...

  5. 企业级自动化运维工具应用实战-ansible

    背景 公司计划在年底做一次大型市场促销活动,全面冲刺下交易额,为明年的上市做准备.公司要求各业务组对年底大促做准备,运维部要求所有业务容量进行三倍的扩容,并搭建出多套环境可以共开发和测试人员做测试,运 ...

  6. 项目实战10.1—企业级自动化运维工具应用实战-ansible

    实战环境: 公司计划在年底做一次大型市场促销活动,全面冲刺下交易额,为明年的上市做准备.公司要求各业务组对年底大促做准备,运维部要求所有业务容量进行三倍的扩容,并搭建出多套环境可以共开发和测试人员做测 ...

  7. Ansible自动化运维工具-上

    [Ansible特点] 1)Ansible与saltstack均是基于Python语言开发的 2)安装使用简单,基于不同插件和模块实现各种软件,平台,版本的管理以及支持虚拟容器多层级的部署 3)不需要 ...

  8. 自动化运维工具——ansile详解

    自动化运维工具——ansible详解(一) 目录 ansible 简介 ansible 是什么? ansible 特点 ansible 架构图 ansible 任务执行 ansible 任务执行模式 ...

  9. Python自动化运维工具-Fabric部署及使用总结

    使用shell命令进行复杂的运维时,代码往往变得复杂难懂,而使用python脚本语言来编写运维程序,就相当于开发普通的应用一样,所以维护和扩展都比较简单,更重要的是python运维工具fabric能自 ...

随机推荐

  1. Webpack使用教程五(Babel)

    Babel是一个JavaScript编译和工具平台,使用Babel我们可以:使用新版本的JavaScript(ES6/ES2015,ES7/ES2016),尽管有些浏览器不能全部支持新特性:使用Jav ...

  2. VIM编辑器的命令

    最近看书,说要熟悉一个文本编辑器的用法最好,在mac上找来找去,发现还是VIM最简单,是自带的,哈哈,决定先转下常用的命令,后续如果有时间,可以慢慢试用,慢慢分类,以下: VIM命令大全 保存文本和退 ...

  3. couchbase作为分布式session容器时的注意事项

    在开发MVC程序时,选择了couchbase作为session provider,但在部署的过程当中发现,两台web server负载均衡,只有一台有session,而负载到另外一台web serve ...

  4. 数据库优化实践【TSQL篇】

    在前面我们介绍了如何正确使用索引,调整索引是见效最快的性能调优方法,但一般而言,调整索引只会提高查询性能.除此之外,我们还可以调整数据访问代码和TSQL,本文就介绍如何以最优的方法重构数据访问代码和T ...

  5. 地址转换协议ARP

    地址转换协议ARP 在以太网协议中规定,同一局域网中的一台主机要和另一台主机进行直接通信,必须要知道目标主机的MAC地址.而在TCP/IP协议中,网络层和传输层只关心目标主机的IP地址.这就导致在以太 ...

  6. 2014-3-5 星期三 [New Change && New Start]

    昨日进度: [计算方法]:起晚啦,迟到一点,有点困,可能因为睡得太晚吧! [无课]:制作IEEE标准在JAVA中的应用. [组成]:-- [多媒体]:-- [人工智能]:-- [寝室]:学习API. ...

  7. php性能分析工具 - xhprof的安装使用

    一.前言 有用的东西还是记录下来吧,也方便以后的查询:这次记录一下xhprof的安装使用: xhprof是facebook开源出来的一个php轻量级的性能分析工具,跟Xdebug类似,但性能开销更低, ...

  8. Microsoft Azure开发体验 – 网络报名系统

    去年底RP好抢到了中国版Azure的使用机会,最近社团里讨论到9月份招新的问题,就用Azure Website和Azure Table Storage打造了这个报名系统. 网站放在 http://jo ...

  9. paip.信用卡账单处理分类bug o21

    paip.信用卡账单处理分类bug o21 cmb 惠众04年度10/12    insure gdb 零售利息    itrst gdb    2013-10-5    97.5    int   ...

  10. AngularJS的date 过滤器

    date 过滤器可以将日期格式化成需要的格式.AngularJS中内置了几种日期格式,如果没有指定使用任何格式,默认会采用 mediumDate 格式,下面的例子中展示了这个格式. ·下面是内置的支持 ...