授之以渔-运维平台Saltstack Web 管理一(模块管理篇)

写在片头:2011年接触到了Puppet ,感叹老美对自动化的理解高了咱不是一个档次。2015年接触到了Saltstack,再次感叹。当时Saltstack还没有类似Puppet Foreman之类的Web管理,,从那时起,我就有了一个小小目标,我要山寨Foreman.....

####Saltstack Web分为几块,下面用与Puppet Foreman对比的方式进行说明:
对比图
图1
图2
图3
i图4
图5
图6

##一、 环境

  • Master和遍历程序在同一台服务器(Saltstack是否有对应的API可以远程操作models,暂时没研究)
  • Django运行版本1.6.1
  • Python运行版本2.7.1

##二、 食用过程

思路:在Saltstack master 写好相应的模块,按照一定的格式放到对应的目录中,通过遍历将类的名称,路径,sls名称写入Mysql中,然后通过Web方式进行展现。先取出所有本地模块列表,组成一个本地模块列表。然后用本地模块列表的数量和远端数据库内所存的模块列表数量进行比较。本地多了,就在远端数据库添加,本地少了,就在远端数据库删除。
###1.导入模块代码如下(根据实际情况调整目录)

def salt_model_import(request):
if request.method == 'POST':
os_list = []
add_count = 0
del_count = 0
try:
for i in os.listdir('/srv/salt/'):
""""遍历一级目录,判断目录下是否为目录"""
if os.path.isdir('/srv/salt/%s/'%i):
for ii in os.listdir('/srv/salt/%s/'%i):
""""遍历二级目录,判断目录下是否为文件且为sls结尾"""
if os.path.isfile('/srv/salt/%s/%s' %(i,ii)) and str('/srv/salt/%s/%s' %(i,ii)).endswith('sls'):
os_list.append('%s.%s' %(i,ii.split('.')[0]))
else:
pass
for i in os.listdir('/srv/salt/'):
""""遍历一级目录,判断目录下是否为目录"""
if os.path.isdir('/srv/salt/%s/'%i):
for ii in os.listdir('/srv/salt/%s/'%i):
""""遍历二级目录,判断目录下是否为文件且为sls结尾"""
if os.path.isfile('/srv/salt/%s/%s' %(i,ii)) and str('/srv/salt/%s/%s' %(i,ii)).endswith('sls'):
"""与数据库内容进行匹对"""
if len(os_list) > Salt_model.objects.all().count():
if Salt_model.objects.filter(salt_model_name=i, salt_model_sls_name=ii, salt_model_dir='/srv/salt/%s/%s' %(i,ii)):
pass
else:
Salt_model(salt_model_name=i, salt_model_sls_name=ii, salt_model_dir='/srv/salt/%s/%s' %(i,ii)).save()
add_count = add_count + 1
elif len(os_list) < Salt_model.objects.all().count():
for i in Salt_model.objects.all():
if '%s.%s'%(i.salt_model_name,i.salt_model_sls_name.split('.')[0]) not in os_list:
Salt_model.objects.filter(salt_model_name=i.salt_model_name, salt_model_sls_name=i.salt_model_sls_name).delete()
del_count = del_count + 1
else:
pass
else:
pass
else:
pass
return HttpResponse('{"status":1,"add_action":%s,"del_action":%s}' % (add_count, del_count))
except Exception as err:
return HttpResponse('{"status":0,"err":%s}' % err)
else:
return HttpResponse('{"status":0}')

数据结果存储如下:
image.png

###2.模块组代码如下(根据实际情况调整目录)

思路:数据库已经存储了对应的模块名称和路径,我们只需要借助模块组的概念,让目标主机挨个通过State.sls挨个去执行对应的模块即可。


def salt_models_group_edit(request):
if request.method == 'GET':
edit_group_id = request.GET['edit_group_id']
salt_models_group = Salt_models_group.objects.get(id = edit_group_id)
salt_models_group_member_list = salt_models_group.salt_models_group_member.split(',')
salt_model = Salt_model.objects.all().order_by('salt_model_name')
salt_model_list = []
for i in salt_model:
salt_model_list.append('%s.%s'%(i.salt_model_name,i.salt_model_sls_name.split(".")[0]))
list = []
for ii in salt_model_list:
if ii in salt_models_group_member_list:
list.append('<option selected>%s</option>' % str(ii))
else:
list.append('<option>%s</option>' % str(ii))
return render_to_response("mysalt/salt_models_group_edit.html",{'list':list},context_instance=RequestContext(request))
else:
edit_group_id = request.META['QUERY_STRING'].split('=')[-1]
salt_models_select_list = request.POST.getlist('salt_models_select',[])
salt_models_group = Salt_models_group.objects.get(id = edit_group_id)
salt_models_group_member_list = salt_models_group.salt_models_group_member.split(',')
for i in salt_models_select_list:
if i not in salt_models_group_member_list:
salt_models_group_member_list.append(i)
for i in salt_models_group_member_list:
if i not in salt_models_select_list:
salt_models_group_member_list.remove(i)
Salt_models_group.objects.filter(id=edit_group_id).update(salt_models_group_member=(','.join(salt_models_group_member_list)).lstrip(','))
return HttpResponseRedirect('/cmdb/salt_models_group/')

def salt_models_group_add (request):
"""1为添加成功,0为不成功"""
if request.method == 'POST':
salt_models_group_name = request.POST['salt_models_group_name']
Salt_models_group(salt_models_group_name = salt_models_group_name).save()
return HttpResponse('{"status":1}')
else:
return HttpResponse('{"status":0}')

def salt_models_group_del (request):
"""1为添加成功,0为不成功"""
if 'salt_models_group' in request.GET:
salt_models_group = request.GET['salt_models_group']
Salt_models_group.objects.filter(salt_models_group_name = salt_models_group).delete()
return HttpResponse('{"status":1}')
else:
return HttpResponse('{"status":0}')


数据结果存储如下:

![image.png](https://upload-images.jianshu.io/upload_images/6358192-2e6854bcbe9df2d4.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

转载于:https://blog.51cto.com/qdream/2405082

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
运维变更管理流程是IT项目运维资料中的一个重要组成部分。它是指在IT项目运维过程中,对于运维变更的管理步骤和方法。在v1.3版本中,运维变更管理流程有以下几个关键步骤。 首先,运维变更管理流程的第一步是需求识别和评估。在这一步骤中,运维团队会与项目业务负责人沟通,了解需求变更的原因和影响范围,并进行评估,以确定变更是否合理和可行。 第二步是变更规划和设计。在这一步骤中,运维团队会制定变更计划,确定执行过程中所需的资源和时间,并制定详细的变更方案和测试策略。这一步骤的目的是为了确保变更顺利进行,能够满足业务需求。 第三步是变更实施和测试。在这一步骤中,运维团队会按照变更计划进行系统的更新、配置、安装或其他处理,并进行相应的测试,以确保变更不会对系统的稳定性和安全性产生负面影响。这一步骤的重点是确保变更的准确性和可靠性。 第四步是变更评估和审批。在这一步骤中,运维团队会对变更的实施结果进行评估,并进行相应的审批。评估的目的是检查变更是否达到了预期的效果,并在确保变更安全可靠的基础上进行批准。 最后一步是变更记录和文档管理。在这一步骤中,运维团队会将变更的详细记录和文档进行整理和存档,以备将来的参考和回溯。这样可以确保变更过程的可追溯性和可复现性。 通过以上的运维变更管理流程,IT项目运维团队能够有效地管理和控制运维变更的过程,确保变更的安全性、稳定性和可靠性,并提供变更过程的可追溯性和文档管理。这样可以最大程度地降低变更引起的风险和不确定性,确保系统的稳定运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值