sqlite处理数据
# coding: UTF-8
import platform
from _utils.patrol2 import run_cmd, data_format, report_format
import os, sys, re, json, copy
import stat
import socket
import stat
import sqlite3 #
# conn=sqlite3.connect(':memory:')
if os.path.exists('was_patrol.db'):
os.remove('was_patrol.db')
conn = sqlite3.connect('was_patrol.db')
c = conn.cursor()
c.execute('''CREATE TABLE WAS
(ID INT PRIMARY KEY NOT NULL,
CELL CHAR(50),
HOME CHAR(50),
CLUSTER CHAR(50),
NODE CHAR(50),
SERVER CHAR(50),
STATE CHAR(50),
PORTS CHAR(500),
HOST CHAR(50));''')
print "Table created successfully"
conn.commit() version = version.split('.')[0]
content = """import sys, java
def get_names(type,parent_obj=None):
if not parent_obj:
obj_list = AdminConfig.list(type)
else:
obj_list = AdminConfig.list(type, parent_obj)
if len(obj_list) == 0:
return [],None
obj_lists = obj_list.split(lineSeparator)
names=[]
for obj in obj_lists:
name = AdminConfig.showAttribute(obj, "name")
names.append(name)
return names,obj_lists lineSeparator = java.lang.System.getProperty('line.separator') cell_names,cells=get_names("Cell")
reports = []
print cell_names,cells
for cell in cells:
cell_name=AdminConfig.showAttribute(cell, "name") cluster_names,clusters=get_names("ServerCluster",parent_obj=cell)
node_names, nodes = get_names("Node", parent_obj=cell) for node in nodes:
nname = AdminConfig.showAttribute(node, "name")
server_names, servers = get_names("Server", parent_obj=node)
hostname= AdminConfig.showAttribute(node, "hostName") print 'node:',node
print 'servers:',servers
for server in servers:
type=AdminConfig.showAttribute(server, "serverType")
if type=='NODE_AGENT':
continue
sname = AdminConfig.showAttribute(server, "name")
cname = AdminConfig.showAttribute(server, "clusterName") runserv = AdminConfig.getObjectName(server)
if len(runserv) > 0:
state = AdminControl.getAttribute(runserv, "state")
else:
state='down' other_port=id=''
if int('{version}')>=6:
ports=AdminTask.listServerPorts(sname, '[-nodeName '+nname+']')
else:
ports=[]
endpoints=AdminConfig.list('EndPoint', server).split(lineSeparator)
print endpoints
#endpoints=AdminConfig.list('EndPoint', AdminConfig.getid( '/Cell:'+cell_name+'/Node:'+nname+'/Server:'+sname+'/')).split(lineSeparator)
for endpoint in endpoints[1:]:
end_result=AdminConfig.show(endpoint).split(lineSeparator)
print end_result
if end_result:
ports.append(end_result[1].split()[1].split(']')[0])
ports=','.join(ports)
print ports id=AdminConfig.getid( '/Cell:'+cell_name+'/VirtualHost:default_host/')
if not id:
id=AdminConfig.getid( '/Cell:'+cell_name+'/VirtualHost:admin_host/')
if id:
other_port=AdminConfig.list('HostAlias',id ).split(lineSeparator)[0]
other_port=AdminConfig.showAttribute(other_port,'port')
if not cname:
# no cluster and has server
reports.append({{'cell': cell_name, 'cluster': 'N/A', 'server': sname, 'node': nname,'obj':server,'state':state,'ports':ports,'host':hostname,'other_port':other_port}})
else:
# has cluster and node
reports.append({{'cell': cell_name, 'cluster': cname, 'server': sname, 'node': nname,
'obj': server,'state':state,'ports':ports,'host':hostname,'other_port':other_port}})
print 'clusters',clusters
reports1=[]
if clusters:
for cluster in clusters:
cluster_name = AdminConfig.showAttribute(cluster, "name")
memberList = AdminConfig.showAttribute(cluster, "members") if memberList!='[]' and memberList!=[] :
#has cluster and node
#pass
members = memberList[1:len(memberList)-1].split(" ")
for member in members:
mname = AdminConfig.showAttribute(member, "memberName")
nname = AdminConfig.showAttribute(member, "nodeName")
reports1.append({{'cell':cell_name,'cluster':cluster_name,'server':mname,'node':nname,'obj':server}})
else:
# has cluster and no node
reports1.append({{'cell':cell_name,'cluster':cluster_name,'server':'N/A','node':'N/A','obj':None}}) print "==data=="
print reports
print "==data=="
print "==datas=="
print reports1
print "==datas=="
""".format(version=version) if 'Windows' in platform.system():
tmp_script = 'C:\\patrol.py'
else:
tmp_script = '/tmp/patrol.py'
with open(tmp_script, 'w') as f:
f.write(content)
os.chmod(tmp_script, stat.S_IRWXU | stat.S_IRGRP | stat.S_IROTH) hostname = platform.node() was_homes = was_home
datas = {'cell': [], 'cluster': [], 'node': [], 'server': []}
all_reports = []
cell_reports = []
cluster_reports = []
server_reports = []
resource = []
count = 0
for was_home in was_homes.split(','):
run_script = os.path.join('{}'.format(was_home), 'bin/wsadmin.sh')
if mw_password:
password = '-password {}'.format(mw_password)
else:
password = '' if 'Windows' in platform.system():
run_script = os.path.join('{}'.format(was_home), 'bin', 'wsadmin.bat')
cmd = '"{}" -username {} {} -lang jython -f {}'.format(run_script, mw_user, password,
tmp_script)
else:
cmd = 'su {} -c "{} -username {} {} -lang jython -f {}"'.format(os_was_user,
run_script, mw_user,
password,
tmp_script)
print cmd
code, out = run_cmd(cmd)
print out
if 'Ensure that user and password are correct' in out:
print '请确认输入的用户名和密码是否正确'
sys.exit(1)
if code:
print out
sys.exit(1)
try:
res = re.findall(r'==data==([\s\S]*)==data==', out)
if not res:
print '无输出'
sys.exit(1)
res = eval(res[0].strip()) res1 = re.findall(r'==datas==([\s\S]*)==datas==', out)
if not res1:
print '无输出'
sys.exit(1)
res1 = eval(res1[0].strip())
print '集群信息', res1 except Exception as e:
print e
sys.exit(1)
resource.append({'res': res, 'washome': was_home}) cell_name = None
for i in res:
cell_name = i['cell']
if i['cell'] not in datas['cell']:
datas['cell'].append(i['cell'])
if i['cluster'] not in datas['cluster']:
datas['cluster'].append(i['cluster'])
if i['node'] not in datas['node']:
datas['node'].append(i['node'])
if i['server'] not in datas['server']:
datas['server'].append(i['server']) c = conn.cursor() port = ''
ports = i.get('ports', '')
if int(version) >= 6:
for j in ports.split('\n'):
if j.startswith('[[WC_adminhost ') and i['server'] == 'dmgr':
port = j.rstrip('] ]]] ]').split(' ')[-1]
if not port:
for j in ports.split('\n'):
if j.startswith('[[WC_defaulthost '):
port = j.rstrip('] ]]] ]').split(' ')[-1]
if not port:
for j in ports.split('\n'):
if j.startswith('[[WEBSERVER_ADDRESS '):
port = j.rstrip('] ]]] ]').split(' ')[-1]
else:
print '端点:', ports
import requests for j in ports.split(','):
print j
try:
res = requests.get('http://localhost:{}/snoop'.format(j))
if res.status_code == 200:
port = j
break
if not port:
res = requests.get('https://localhost:{}/snoop'.format(j), is_verify=False)
if res.status_code == 200:
port = j
break
except:
pass
if not port:
port = ports.split(',')[0] print 'port',port state= i.get('state','')
if int(version) <= 5:
cmd = "netstat -Aan|grep -w '*.{}'".format(port)
code, res = run_cmd(cmd)
if res and 'LISTEN' in res.split()[-1]:
state = 'STARTED' c.execute("INSERT INTO WAS (ID,CELL,HOME,CLUSTER,NODE,SERVER,STATE,PORTS,HOST) \
VALUES ({}, '{}', '{}', '{}', '{}','{}','{}','{}','{}' )".format(count,
i['cell'],
was_home,
i['cluster'],
i['node'],
i['server'],state,
port,
i.get('host',
'')))
count += 1 conn.commit()
print datas cursor = conn.execute("SELECT distinct CELL from WAS")
cells = []
for row in cursor:
cell = row[0]
if cell not in cells:
cells.append(cell)
cell_reports.append(data_format('单元名称', cell, alert=0, group_name="单元情况"))
cell_num = len(cells)
if cell_num == 1:
all_reports.append(report_format("{}".format(hostname), cell_reports))
else:
all_reports.append(report_format("{}".format(hostname), childs=cell_reports)) cell_clusters = []
cell_cluster_report = {}
cursor = conn.execute("SELECT id, cell, home,cluster,node, server,state,ports,host from WAS")
for row in cursor:
cell = row[1]
node = row[4]
server = row[5]
home = row[2]
cluster = row[3]
if cell_num == 1:
cell_cluster = '{}'.format(hostname)
else:
cell_cluster = '{}/{}'.format(hostname, cell)
if cell_cluster not in cell_clusters:
cell_cluster_report.update({cell_cluster: []})
cell_clusters.append(cell_cluster)
if cluster not in cell_cluster_report[cell_cluster]:
cell_cluster_report[cell_cluster].append(cluster) reports = []
for k, v in cell_cluster_report.items():
for i in v:
reports.append(data_format('集群名称', i, alert=0, group_name="集群名称"))
all_reports.append(report_format(k, childs=reports)) reports = json.dumps(all_reports)
print reports
sqlite处理数据的更多相关文章
- Android 一键直接查看Sqlite数据库数据
转自:http://www.cnblogs.com/trinea/archive/2012/11/16/2773656.html 本文主要介绍Android开发中如何一键直接查看sqlite数据库中的 ...
- 解决sqlite删除数据后,文件大小不变问题(VACUUM)
删除表格的全部数据: DELETE FROM [Name] 当在sqlite中删除了大量数据后,数据库文件的大小还是那样,没有变.原因是:从Sqlite删除数据后,未使用的磁盘空间被添加到一个内在的” ...
- Python读取和处理文件后缀为".sqlite"的数据文件
最近在弄一个项目分析的时候,看到有一个后缀为”.sqlite”的数据文件,由于以前没怎么接触过,就想着怎么用python来打开并进行数据分析与处理,于是稍微研究了一下. SQLite是一款非常流行的关 ...
- 解决sqlite删除数据或者表后,文件大小不变的问题
原因分析: sqlite采用的是变长纪录存储,当你从Sqlite删除数据后,未使用的磁盘空间被添加到一个内在的"空闲列表"中用于存储你下次插入的数据,用于提高效率,磁盘空间并没有丢 ...
- 解决sqlite删除数据后,文件大小不变问题 转载
原文地址:http://blog.csdn.net/yangchun1213/article/details/7656146 说了这么多,没进主题,我的主题是给Sqlite在删除数据后擦屁股. 大 ...
- Android开发之利用SQLite进行数据存储
Android开发之利用SQLite进行数据存储 Android开发之利用SQLite进行数据存储 SQLite数据库简单介绍 Android中怎样使用SQLite 1 创建SQLiteOpenHel ...
- sqlite删除数据
sqlite删除数据 某日, 在使用sqlite的时候发现查询速度极慢, 查看了一下文件大小, sqlite数据库文件已经达到了 22G! 对于一个文件数据库来说, 已经相当致命了,先不说后面如果解决 ...
- C#(.net)实现用apache activemq传递SQLite的数据
版权声明:本文为搜集借鉴各类文章的原创文章,转载请注明出处:http://www.cnblogs.com/2186009311CFF/p/6382623.html. C#(.net)实现用apache ...
- mono for android中使用dapper或petapoco对sqlite进行数据操作
在mono for android中使用dapper或petapoco,很简单,新建android 类库项目,直接把原来的文件复制过来,对Connection连接报错部分进行注释和修改就可以运行了.( ...
- 从SQLite获取数据完成一个产品信息展示
在ios实际开发当中,我们常常用到Core Data做为数据储存首选.但在处理一些大量复杂的数据值且数据之间相互关联的时候,这就不得不使用关系型数据库来实现.例如一个导航程序,自身应该包含大量的地图自 ...
随机推荐
- 解决gitk显示文件内容中文乱码
解决gitk显示文件内容中文乱码 1.git config 命令 设置git gui的界面编码 git config --global gui.encoding utf-8 2.修改配置文件 在~\e ...
- HDFS 开发中的文件配置优先级
一.先看集群上的配置,这里设置了文件块副本数为 3 上传一个文件试试 public class ConfigPriority { private Configuration conf; private ...
- java动态获取上传文件的编码类型
package com.sjfl.main; import java.io.BufferedReader; import java.io.File; import java.io.FileInputS ...
- spring整合curator实现分布式锁
为什么要有分布式锁? 比如说,我们要下单,分为两个操作,下单成功(订单服务),扣减库存(商品服务).如果没有锁的话,同时两个请求进来.先检查有没有库存,一看都有,然后下订单,减库存.这时候肯定会出现错 ...
- C#图像检测开源项目
AForge.NET AForge.NET is an open source C# framework designed for developers and researchers in the ...
- LeetCode(194.Transpose File)(awk进阶)
194. Transpose File Given a text file file.txt, transpose its content. You may assume that each row ...
- in和hasOwnProperty的区别
两者都代表查看某个属性是不是对象自己的,返回布尔值 in判断的是对象的所有属性,包括对象实例及其原型的属性 hasOwnProperty则是判断对象实例的是否具有某个属性
- [Android] Android v4包CompoundButtonCompatLollipop.class重复问题
用 Butter Knife 8.8.1 导致v4包CompoundButtonCompatLollipop.class重复问题 详细错误如下: Error:Execution failed fo ...
- multiprocessing.Manager共享内存的问题记录
问题:https://stackoverflow.com/questions/8640367/python-manager-dict-in-multiprocessing 使用 multiproces ...
- java的几个奇怪语法
=============================Java 双冒号 :: 语法的含义=============================下面的代码中有双冒号,初看上去很奇怪, list. ...