堡垒机2.0

 

一、编辑系统环境变量,让用户登录后自动调用脚本

1 vim /etc/profile
2 python /baolei/ssh_login.py
3 # 判断登录用户是否为 root 用户,root用户退出程序不进行logout操作,否则则logout
4 if [ $? != 10 ];then
5         echo "Good Bye!"
6         logout
7 fi

 

二、定时获取最新数据API && 堡垒机程序

  1)、获取最新数据脚本

 1 #!/usr/bin/env python
 2 #-*- coding: UTF-8 -*-
 3 #Author : Derrick.jiang
 4 #Date   : 2015-3-3 PM
 5 import os
 6 os.system('rm -rf /baolei/conf/nodes && wget https://xxx/nodes && mv ./nodes /baolei/conf/')
 7 fp = open("/baolei/conf/nodes", "r")
 8 all = fp.read()
 9 fp.close()
10 fp = open("/baolei/conf/nodes", "w")
11 fp.write(all.replace(r'\n', '\n').replace(r'"', ""))

  2):堡垒机程序

#!/usr/bin/env/python
#-*- coding: UTF-8 -*-
#coding = gbk
#author : derrick.jiang
#Email  : derrick.jiang@maichuang.net
import urllib2
import time
import json
import re
import sys,os
import commandsUSER_PATH = '/etc/passwd'
ACURRENT = commands.getoutput('whoami')
s = open('/baolei/conf/nodes')
q = s.read()
files = q.split('\n\n')r = re.compile(r'^\[')
s = open('/baolei/conf/nodes')
lines = s.readlines()
lines = [l for l in lines if r.match(l)]def check_ip(ipaddr):'Check that the IP is correct'q = ipaddr.split('.')return len(q) == 4 and len(filter(lambda x: x >= 0 and x <= 255,map(int, filter(lambda x: x.isdigit(), q)))) == 4select = []
def select_area():'选择登陆省市'global selectwhile True:os.system('clear')print '___'*15for index, province in enumerate(lines):print "%s. %s" % (index, province.strip())print ''print '~~~'*15print "IP: Enter The Ip Adress:"print "q : QUIT"print '___'*15area = raw_input("Please Select Area: ")if area.isdigit() == True and int(area) < len(files):os.system('clear')breakelif check_ip(area) == True:os.system('clear')os.system('/baolei/tilt/bin/ssh -o StrictHostKeyChecking=no -p port root@%s' %area)elif area == 'q':os.system('clear')sys.exit(0)else:passarea = int(area)select = files[area].split('\n')for i in select:print iprint '~~~'*15print "IP: Enter The Ip Adress:"print "q : QUIT"print "b : BACK"print '___'*15def select_server():'选择登陆的服务器IP'global selectwhile True:i = raw_input("Please Select Server: ")if i.isdigit() == True and int(i) >= 1 and int(i) < len(select):breakelif check_ip(i) == True:os.system('clear')os.system('/baolei/tilt/bin/ssh -o StrictHostKeyChecking=no -p port root@%s' %i)elif i == 'q':os.system('clear')sys.exit(0)elif i == 'b':select_area()else:passi = int(i)IP =  select[i].split()[-1]os.system('/baolei/tilt/bin/ssh -o StrictHostKeyChecking=no -p port root@%s' %IP)def users_name():try:fn = open(USER_PATH).readlines()users = [user.split(':')[0].strip() for user in fn if len(user.split(':')) == 7 and user.split(':')[-1].strip().endswith('sh')][1:] #过滤出非root用户except Exception as e:fn = open('/tmp/error_log', 'a')fn.write(str(e))fn.close()users = []return users
'''CHOOSE USER LOGIN
'''
if ACURRENT in users_name():while True:select_area()select_server()
else:exit(10) #非遍历内容内的用户都返回10 环境变量忽略执行

三、安装tilt交互式日志工具: 详见:http://www.keepbase.com/try-tilt/comment-page-1

四、更改日志保存格式:

 1 import os
 2 import shutil
 3 import time
 4 import commands
 5 now_time = commands.getoutput('date -d "2 minute ago" +%Y-%m-%d')
 6 dir = "/var/log/ssh_log/%s/" %now_time
 7 if os.path.isdir(dir):  # 判断是否存在路径
 8     filelist = []
 9     filelist=os.listdir(dir)
10     for i in filelist:
11         NewFile = i.replace("-baolei-tilt-bin-ssh -o StrictHostKeyChecking=no -p port ","-")
12         shutil.move(dir+i,dir+NewFile)
13 else:
14     print ("Directory is not exit,please check dir...")
15     time.sleep(1)
16     exit()

五、将获取API脚本和更改日志名称脚本加入计划任务,定时执行:

0 4 * * * root python /baolei/wgetnewapi.py &> /dev/null
* * * * * root python /baolei/change_logname.py &> /dev/null

六、将所有程序和日志写入文件夹权限设置为允许所有用户访问。

七、在所有用户 ~/.ssh/目录下面放入可以远程至server端的私钥

==========================================================================

日志记录格式为:%D-%m-%d/username-date-user@IP   如:2015-04-22/Kevin-15:53:24-root@192.168.1.2

==========================================================================

转载于:https://www.cnblogs.com/cpy-devops/p/4447721.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/376048.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flex中利用ByteArray与BitmapData互相转换实现图片的二进制保存与复原

Flex中利用ByteArray与BitmapData互相转换实现图片的二进制保存与复原 近 日在项目当中需要将图片保存到共享对象当中&#xff0c;开始用了俩天的时间做了对象的序列化&#xff0c;并以BitmapData的形式进行了图片的序列化保存共享&#xff0c;因为系统 没有提供更好的接口所以…

java8自定义收集器_使用自定义收集器进行Java 8分组?

我有以下课程。class Person {String name;LocalDate birthday;Sex gender;String emailAddress;public int getAge() {return birthday.until(IsoChronology.INSTANCE.dateNow()).getYears();}public String getName() {return name;}}我希望能够按年龄分组&#xff0c;然后收…

poj 1862 Stripies/优先队列

原题链接&#xff1a;http://poj.org/problem?id1862 简单题&#xff0c;贪心优先队列主要练习一下stl大根堆 写了几种实现方式写成类的形式还是要慢一些。。。 手打的heap&#xff1a; 1&#xff1a; 1 #include<cstdio>2 #include<cstdlib>3 #include<cmath&…

java url下载ics_使用Microsoft Graph API处理外部(Internet / .ics)日历URL

在新的Graph API中&#xff0c;是否可以根据外部.ics日历网址为用户创建新日历&#xff1f;我d like to do is to use a daemon to inject a link to an external calendar into the list of calendars a user has if they don已经有了这样一个链接 . 这将有效地复制用户可以在…

命令行生成jar文件

1.打开cmd&#xff0c;进入编译完后所有类的当前目录 命令行 jar -cvf javaname.jar *.class 这时已经生成了 javaname.jar 不过如果有多个类&#xff0c;双击打不开 2.解压javaname.jar 进入META-INF&#xff0c;编辑MANIFEST.MF: 尾行写入Main-Class:&#xff08;&…

Github链接地址

https://github.com/kzj1/test转载于:https://www.cnblogs.com/lalal/p/4456923.html

java foreach和for循环区别_java相关:老生常谈foreach(增强for循环)和for的区别

java相关&#xff1a;老生常谈foreach(增强for循环)和for的区别发布于 2020-8-18|复制链接下面小妖就为大家带来一篇老生常谈foreach(增强for循环)和for的区别。小妖觉得挺不错的&#xff0c;现在就分享给大家&#xff0c;也给大家做个参考。一起跟随小妖过来看看吧首先说一下f…

关于事件冒泡和捕获的问题

由于习惯于jquery的方便操作&#xff0c;往往让我们慢慢淡忘了原生js应有的功能和属性&#xff0c;今天重温一下事件冒泡和捕获问题。 冒泡&#xff1a;从内向外&#xff0c;如&#xff1a;div > body > html (不同浏览器稍有不同) 捕获&#xff1a;从外向内&#xff0c;…

root无法运行命令解决办法

今天运行一个命令wget(wg再使用tab键无法使用)&#xff0c;如下提示 -bash: /usr/bin/wget: 权限不够 [rootwww /]# ls -Z /usr/bin/wget-rw-r--r--. root root system_u:object_r:bin_t:s0 /usr/bin/wget发现没有执行权限 chmod x /usr/bin/wget -bash: /usr/bin/wget: …

java类编写sql_用JavaBean编写SQL Server数据库连接类

以下为引用的内容&#xff1a;//类conn.db.conndb.javapackage conn.db;import java.sql.*;public class conndb {Connection conn;ResultSet rs;private int count;public conndb() {try {Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");} catch (Exception ex) {}…

ASP.NET中Request.ApplicationPath、Request.FilePath、Request.Path、.Request.MapPath、

1.Request.ApplicationPath->当前应用的目录 Jsp中, ApplicationPath指的是当前的application(应用程序)的目录,ASP.NET中也是这个意思。 对应的--例如我的服务器上有两个web应用域名都是mockte.com 一个映射到目录mockte.com/1/ 另一个影射到 http://mockte.com/2/ …

java timezone id_java.util.TimeZone.setID()方法实例

全屏setID(String ID)方法被用于设置时区ID。这不会改变的时区对象中的任何其他数据。声明以下是java.util.TimeZone.setID()方法的声明。public void setID(String ID)参数ID--这是新的时区ID。返回值NA异常NA例子下面的例子显示java.util.TimeZone.setID()方法的使用package …

c语言中赋值截断

在c语言中进行变量赋值的时候&#xff0c;如果将字节多的数据类型赋给一个占字节少的变量类型&#xff0c;会发生“截断”。 发生这种情况的原因是&#xff1a;在赋值过程中只将占字节较长的变量的地位赋给占字节较少的变量。 如&#xff1a; int i345&#xff1b; char c‘…

创建一个自己的GitHub,创建自己的开源项目

作者是一个大学在读学生&#xff0c;自己在平时的学习中&#xff0c;GitHub上的开源项目给自己提供了很大的帮助。GitHub是目前使用最广泛的分布式项目管理软件&#xff0c;GitHub上面托管了许多非常优秀的开源项目。我觉得每一个从事IT行业都应该有一个属于自己的GitHub。下面…

设计模式之行为型(1)-职责链模式(Chain)

设计模式之行为型(1)-职责链模式(Chain)转载于:https://www.cnblogs.com/lihuali/p/7493415.html

php apache win7,win7安装apache+php

转自百度经验1 系统环境与软件1php5.5.6 下载链接&#xff1a;http://windows.php.net/download/#php-5.5推荐 V11 x64&#xff0c;也就是64bit的。2apache2.4&#xff0c;下载链接&#xff1a;http://www.apachelounge.com/download/同样是推荐 V11&#xff0c;64位的。3前面提…

photoshop 常用快捷键大全

一、文件新建 CTRLN打开 CTRLO 打开为 ALTCTRLO关闭 CTRLW保存 CTRLS 另存为 CTRLSHIFTS另存为网页格式 CTRLALTS打印设置 CTRLALTP页面设置 CTRLSHIFTP打印 CTRLP退出 CTRLQ 二、编辑撤消 CTRLZ向前一步 CTRLSHIFTZ向后一步 CTRLALTZ退取 CTRLSHIFTF剪切 CTRLX复制 CTRLC合并…

Ubuntu如何安装setuptools

首先百度setuptools&#xff0c;基本第一个就是官网的结果然后我们看到有两个这样的文件第一个不用想了&#xff0c;如果你要使用第一个的话&#xff0c;还要首先安装wheel。我们这里直接用鼠标选中第二个zip文件&#xff0c;然后右键&#xff0c;复制链接。然后在我们的Ubuntu…

Spring MVC 文件上传下载

本文基于Spring MVC 注解&#xff0c;让Spring跑起来。 (1) 导入jar包&#xff1a;ant.jar、commons-fileupload.jar、connom-io.jar。 (2) 在src/context/dispatcher.xml中添加 <bean id"multipartResolver" class"org.springframework.web.multipart.comm…

.php y=mp4,PHP输出MP4视频流函数

function GetMp4File($file) {$size filesize($file);header(“Content-type: video/mp4”);header(“Accept-Ranges: bytes”);if(isset($_SERVER[‘HTTP_RANGE’])){header(“HTTP/1.1 206 Partial Content”);list($name, $range) explode(“”, $_SERVER[‘HTTP_RANGE’]…