zabbix使用LDAP認(rèn)證,并定時(shí)導(dǎo)入ldap用戶到zabbix

前言:公司用openldap搭了一套ldap認(rèn)證系統(tǒng),用于統(tǒng)一內(nèi)部各個(gè)系統(tǒng)的賬戶,避免每次添加或刪除用戶還得一個(gè)個(gè)登陸上去操作汰规,使賬戶密碼統(tǒng)一,能減輕很多工作和保證安全性物邑,今天是想把ldap與zabbix進(jìn)行結(jié)合溜哮。

一滔金、配置zabbix

安裝php-ldap模塊
php需要這個(gè)模塊來(lái)進(jìn)行l(wèi)dap認(rèn)證,安裝方法網(wǎng)上都有這里不多述茂嗓;

> /usr/local/php/bin/php -m|grep ldap
ldap

zabbix頁(yè)面配置

zabix-ldap

LDAP host:訪問(wèn)DC的地址餐茵。格式:ldap://ip地址
Port:默認(rèn)389
Base DN: dc=tencent,dc=com,也就是域名(tencent.com)
Search attribute: uid,屬性值述吸,網(wǎng)上有填sAMAccountName忿族。

Bind DN: cn=Admin, ou=People, dc=tencent, dc=com。 cn就是在DC中創(chuàng)建的LDAPuser用戶蝌矛, ou就是LDAPuser屬于哪個(gè)ou道批,dc=tencent和dc=com不在解釋。

Bind password:xxxx 入撒,改密碼為L(zhǎng)DAPuser用戶的密碼
Login:Admin
User password:在DC中創(chuàng)建Admin用戶的密碼

點(diǎn)擊"Test"屹徘。如果沒(méi)有報(bào)什么錯(cuò)誤,就可以點(diǎn)擊"Save"⌒平穑現(xiàn)在ZABBIX的LDAP認(rèn)證方式就已經(jīng)配置完成了噪伊。

二、python導(dǎo)入ldap用戶

上述配置完成后已經(jīng)把ldap和zabbix打通了氮唯,用戶登錄zabbix時(shí)鉴吹,會(huì)先到ldap認(rèn)證,判斷用戶是否有效惩琉;但是zabbix不會(huì)把ldap的用戶同步過(guò)了豆励,你要登錄,得先在zabbix上創(chuàng)建和ldap內(nèi)同名的用戶才行瞒渠,這個(gè)顯得很被動(dòng)了良蒸,于是寫個(gè)腳本,定時(shí)往zabbix數(shù)據(jù)庫(kù)插入用戶伍玖,這樣就免去手工創(chuàng)建的用戶的煩惱嫩痰。下面是腳本:(環(huán)境是python2.6)

ldap命令看到的數(shù)據(jù)

dn: cn=xiao.deng,ou=People,dc=weimob,dc=com
givenName:: 6YKT5pmT
dn: cn=chenhao.ma,ou=People,dc=weimob,dc=com
givenName:: 6ams5pmo5piK
dn: cn=ying.liu,ou=People,dc=weimob,dc=com
givenName:: 5YiY6aKW
...

cn是zabbix的alias字段,givenName需要base64解碼成中文名

> cat insert_sql.py 
#!/usr/bin/env python
# -*- coding:utf-8 -*-

import pymysql
import commands
import re
import base64
import sys

# 避免中文亂碼
reload(sys)
sys.setdefaultencoding('utf-8')

ldap_list='/usr/local/zabbix/sh/ldap.list'

# 先從ldap服務(wù)器把用戶數(shù)據(jù)導(dǎo)入文件
ldap_users=commands.getoutput("ldapsearch -x -LLL -H ldap://1.1.1.1 -b dc=weimob,dc=com givenName|sed '1,12'd|sed '/^$/d'|egrep -v 'ou=Group|ou=machines'> %s" % ldap_list)

# 因?yàn)閦abbix的表沒(méi)有自增id窍箍,所以每次操作都會(huì)記錄下id串纺,并遞增
idfile = '/usr/local/zabbix/sh/userid'

# 處理元數(shù)據(jù),把文件里的每行數(shù)據(jù)轉(zhuǎn)化成方便使用的格式
def get_item(fobj):
    item = ['', '', '']
    for no,line in enumerate(fobj):
        #print no,line
        slot = no % 2
        item[slot] = line.rstrip()
        if slot == 1:
            yield item

def insert_user():
    conn = pymysql.connect(host='2.2.2.2', port=3306, user='zabbix', passwd='zabbix', db='zabbix', charset='utf8')
    cur = conn.cursor()
    fs = open(idfile,'r')
    n = int(fs.read())
    fs.close()
    with open(ldap_list) as fobj:
        for item in get_item(fobj):
            n += 1
            try:
                s='{0}{1}{2}'.format(*item)
                l = re.search('cn=(.*),ou.*:: (.*)',s)
                name = base64.b64decode(l.group(2))
                alias = l.group(1)
                search = cur.execute("""select * from users where alias = %s""", (alias, ))
                if not search:
                    sql = "insert into users(userid,name,alias) values ('%s','%s','%s');" % (n,name,alias)
                    insert = cur.execute(sql)
                    if sql:
                        print "User %s Add Succed!" % alias
                        print sql
            except AttributeError as e:
                print e
    conn.commit()   #這步很必要椰棘,不然插入的數(shù)據(jù)不生效
    cur.close()
    conn.close()
    fe = open(idfile,'w')
    fe.write(str(n))
    fe.close()

if __name__ == '__main__':
    insert_user()

執(zhí)行

> python insert_sql.py
User ying.liu Add Succed!
insert into users(userid,name,alias) values ('2691','劉穎','ying.liu');

再去user下看纺棺,可以看到新增了很多用戶

Paste_Image.png

登錄下,認(rèn)證是成功的邪狞,接下來(lái)祷蝌,你可以對(duì)用戶進(jìn)行分組和授權(quán)了


~ zabbix使用ldap認(rèn)證完成

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市帆卓,隨后出現(xiàn)的幾起案子巨朦,更是在濱河造成了極大的恐慌米丘,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件罪郊,死亡現(xiàn)場(chǎng)離奇詭異蠕蚜,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)悔橄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門靶累,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人癣疟,你說(shuō)我怎么就攤上這事挣柬。” “怎么了睛挚?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵邪蛔,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我扎狱,道長(zhǎng)侧到,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任淤击,我火速辦了婚禮匠抗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘污抬。我一直安慰自己汞贸,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布印机。 她就那樣靜靜地躺著矢腻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪射赛。 梳的紋絲不亂的頭發(fā)上多柑,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音咒劲,去河邊找鬼顷蟆。 笑死,一個(gè)胖子當(dāng)著我的面吹牛腐魂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播逐纬,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼蛔屹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了豁生?” 一聲冷哼從身側(cè)響起兔毒,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤漫贞,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后育叁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體迅脐,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年豪嗽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了谴蔑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡龟梦,死狀恐怖隐锭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情计贰,我是刑警寧澤钦睡,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布,位于F島的核電站躁倒,受9級(jí)特大地震影響荞怒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜秧秉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一褐桌、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧福贞,春花似錦撩嚼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至拇舀,卻和暖如春逻族,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背骄崩。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工是辕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人瞳步。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓术奖,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親脱惰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子搏嗡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容