Mac下安裝配置Kerberos了解一下。
創(chuàng)新互聯(lián)主營吳中網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app開發(fā)定制,吳中h5小程序設(shè)計搭建,吳中網(wǎng)站營銷推廣歡迎吳中等地區(qū)企業(yè)咨詢
公司強迫開發(fā)人員全部使用mbp,我很不爽,因為mac下面使用mit的kerberos簡直是災(zāi)難,申請用普通筆記本裝linux也不批。
MacOSX是閉源系統(tǒng),安裝配置開源的東西都很麻煩。是的,port和brew很方便,但是有些需要的C語言開發(fā)頭文件貌似是不軟鏈的,而且源碼編譯還有一堆的依賴要編譯,比如kerberos源碼依賴openssl頭文件,而openssl頭文件也得編譯安裝。當然用sudo硬拷過去也行,但是你知道拷哪些嗎?我是已經(jīng)煩透了。
這里面有兩說,如果只是單純用kadmin, kinit,當然homebrew就夠了,不過我是要用kerberos頭文件來編譯python的某個kerberos庫,這就討厭了,brew安裝其實是有頭文件源碼的,但是沒有做軟鏈到/usr/local/include,所以編譯的時候是找不到頭文件的。只能手工軟鏈到/usr/local/include
brew install krb5 cd /usr/local/include ln -sf ../Cellar/krb5/1.16.1/include/* ./ cd /usr/local/lib ln -sf ../Cellar/krb5/1.16.1/lib/* ./
這是準備開發(fā)環(huán)境的過程
然后配置,由于沒什么人在mac上做kerberos相關(guān)的開發(fā)和使用,所以怎么在mac上配置kerberos我是直接科學上網(wǎng),搜到MIT的官方文檔,MIT Kerberos MAC配置,配置文件與Linux不同,是放置在/User/xianglei/Library/Preferences/edu.mit.Kerberos 里面,搞這么復(fù)雜,其實就是人家 linux 的 /etc/krb5.conf 。
[libdefaults] default_realm = EXAMPLE.COM DNS_lookup_kdc = false dns_lookup_realm = false ticket_lifetime = 1296000 renew_lifetime = 2592000 forwardable = true default_tgs_enctypes = rc4-hmac default_tkt_enctypes = rc4-hmac permitted_enctypes = rc4-hmac udp_preference_limit = 1 kdc_timeout = 3000 [kdcdefaults] kdc_ports = 88 kdc_tcp_ports = 88 [realms] EXAMPLE.COM = { kdc = 192.168.130.128 admin_server = 192.168.130.128 #master_key_type = aes256-cts acl_file = /var/kerberos/krb5kdc/kadm5.acl dict_file = /usr/share/dict/words admin_keytab = /var/kerberos/krb5kdc/kadm5.keytab supported_enctypes = aes256-cts:normal aes128-cts:normal des3-hmac-sha1:normal arcfour-hmac:normal des-hmac-sha1:normal des-cbc-md5:normal des-cbc-crc:normal max_renewable_life = 30d }
這段是 /User/xianglei/Library/Preferences/edu.mit.Kerberos 的內(nèi)容,kdc server和 kadmin server的IP地址是我本機的虛機。
kinit xianglei/admin@EXAMPLE.COM's password: Encryption type arcfour-hmac-md5(23) used for authentication is weak and will be deprecated
kinit登錄驗證沒有出現(xiàn)問題,報了一個廢棄警告,rc4-hmac太弱雞了,將會被廢棄。
然而,mac下的 kadmin 登錄出問題了
kadmin kadmin: kadm5_init_with_password: init_sec_context failed with 851968/-1765328377
只會報這種segment fault,經(jīng)過科學引擎搜索(百度就別想了,中文我就沒見過幾篇寫Kerberos的。)最后結(jié)論是Mac上實現(xiàn)的Kerberos與MIT的Kerberos中間傳輸數(shù)據(jù)的協(xié)議格式不一致導(dǎo)致的。解決方法是這樣。用kinit -S參數(shù)直接從kdc獲取ticket,替代使用krbtgt/EXAMPLE.COM的中間方式。
kinit -S kadmin/admin xianglei/admin@EXAMPLE.COM xianglei/admin@EXAMPLE.COM's password: Encryption type arcfour-hmac-md5(23) used for authentication is weak and will be deprecated kadmin kadmin> ? stash, kstash stash dump dump [dump-file] od-dump od-dump [dump-file] init init realm... load load file merge merge file add, ank, add_new_key add principal... passwd, cpw, change_password passwd principal... delete, del, del_entry delete principal... del_enctype del_enctype principal enctype... add_enctype add_enctype principal enctype... ext_keytab ext_keytab principal... get, get_entry get principal... rename rename from to modify modify principal privileges, privs privileges list list principal... verify-password-quality, pwq verify-password-quality principal password check check [realm] lock lock unlock unlock help, ? help [command] exit, quit exit
然后直接可以進kadmin了,相當于直接用kadmin.local方式。
然后聊一下在Mac下做Kerberos相關(guān)C語言開發(fā)。起因是因為甲方爸爸購買的Cloudera 企業(yè)版快到期了,爸爸說:兒子你技術(shù)實力這么強,加上中美貿(mào)易戰(zhàn),爸爸兜里沒錢買不起CDH企業(yè)版了,兒子要不你自己先維護吧。我們乙方兒子能說啥,咬咬牙,好吧。
不過爸爸那邊的企業(yè)版里面有Kerberos,到期以后維護Hadoop倒還沒啥,Kerberos keytab管理和分發(fā)功能企業(yè)版到期就不能用了,所以得盡快開發(fā)一套Kerberos的管理替代原來Cloudera Manager的這個功能。所以我打算用Python寫了一個界面來自動化創(chuàng)建管理所有Hadoop相關(guān)的Keytab,但是Python雖然有不少kerberos的使用庫,卻沒有admin管理的的庫,最后終于找到了一個 PyPI 上的包,結(jié)果bug太多,好幾年前發(fā)布的,也不維護了,編譯各種報錯,7裝不了,ubuntu裝不了。只好先用調(diào)用命令行的方式對付著,昨天有空把admin的C代碼好好閱讀修改了一下,重新發(fā)布了一個包。所以昨天就用到了Kerberos的C開發(fā),所以我才吐槽Mac垃圾,啥源碼都沒有,然后還他媽不兼容MIT。gcc還得單裝,默認是clang。
好吧,前面已經(jīng)把brew安裝的動態(tài)庫和include頭文件做了軟鏈到/usr/local/lib和/usr/local/include了,然后修改過的源碼直接就可以編譯了,但是由于調(diào)取Mac本身的動態(tài)庫,所以管理員認證協(xié)議仍然不一樣,所以在Mac下雖然可以編譯通過,但使用時仍然會報Segment Fault,不過unbuntu,centos7等等其他linux發(fā)行版下的編譯算是修好了。
對我這種碼農(nóng)來說,最好的開發(fā)環(huán)境不是Mac,也不是Windows,就給一破筆記本,裝個ubuntu或者arch就太好了,軟件開發(fā)得保證POSIX可移植性和兼容性啊。對于隨便升級個什么系統(tǒng)補丁都能宕機的服務(wù),我表示強烈鄙視。
擴展功能并修復(fù)bug后開源的 python-kadmV 代碼放在github上面,相比于幾年前發(fā)布的原版,除了修復(fù)了不少編譯error,還增加了 principal 改名的功能和創(chuàng)建 keytab 的功能,完全使用C語言編寫的Python包,使用kerberos原生庫編譯安裝,再也無需subprocess調(diào)用命令行了。
我自己覺得改完了,相對原版功能還是比較強大的,可以直接在python里addprinc, delprinc, listprincs, renprinc, ktadd, 對于principal可以get和set各種屬性,比如重置密碼,設(shè)置隨機密碼,設(shè)置過期時間等等,基本跟直接用kadmin命令行差不多了。我原來封裝的調(diào)用命令行的kadmin類已經(jīng)完全用這個包替代了,毫無壓力。
同時也發(fā)布在了pypi上,需要的小朋友可以直接
pip install python-kadmv
不過這篇博客里的經(jīng)驗可能除了python庫,對于絕大多數(shù)人可能沒什么用。絕大多數(shù)人都不會用到kerberos,甚至更不會去基于kerberos做開發(fā),甚至更不會在Mac上做Kerberos開發(fā)。
Fuck Apple
網(wǎng)站標題:Kerberos學習(四)
文章鏈接:http://m.newbst.com/article0/ispoio.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、網(wǎng)站維護、品牌網(wǎng)站制作、網(wǎng)站改版、網(wǎng)站設(shè)計、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)