堡壘機(jī)

目錄

一、堡壘機(jī)介紹
二置蜀、搭建簡易堡壘機(jī)思路
三镣煮、搭建簡易堡壘機(jī) - 安裝jailkit實現(xiàn)chroot
四姐霍、搭建簡易堡壘機(jī) - 日志審計
五、jumpserver介紹
六典唇、安裝jumpserver
七邮弹、使用jumpserver
八、用戶管理
九蚓聘、資產(chǎn)管理
十、客戶端登錄jumpserver

一盟劫、堡壘機(jī)介紹

在一個特定網(wǎng)絡(luò)環(huán)境下夜牡,為了保障網(wǎng)絡(luò)和數(shù)據(jù)不受外界入侵和破壞,而運用各種技術(shù)手段實時收集和監(jiān)控網(wǎng)絡(luò)環(huán)境中每一個組成部分的系統(tǒng)狀態(tài)、安全事件塘装、網(wǎng)絡(luò)活動急迂,以便集中報警、及時處理及審計定責(zé)蹦肴。
我們又把堡壘機(jī)叫做跳板機(jī)僚碎,簡易的跳板機(jī)功能簡單,主要核心功能是遠(yuǎn)程登錄服務(wù)器和日志審計阴幌。
比較優(yōu)秀的開源軟件jumpserver勺阐,認(rèn)證、授權(quán)矛双、審計渊抽、自動化、資產(chǎn)管理议忽。
商業(yè)堡壘機(jī):齊治懒闷,Citrix XenApp

二、搭建簡易堡壘機(jī)思路

具備堡壘機(jī)的條件是栈幸,該機(jī)器有公網(wǎng)和私網(wǎng)愤估,其中私網(wǎng)和機(jī)房其他機(jī)器互通,公網(wǎng)則是用于公司外部辦公
設(shè)計堡壘機(jī)思路
跳板機(jī)安全設(shè)置(iptables端口限制速址、登錄限制sshd_config)不使用密碼認(rèn)證而用用密鑰認(rèn)證
用戶玩焰、命令權(quán)限限制(jailkit) http://blog.chinaunix.net/uid-28310119-id-3503318.html
客戶機(jī)器日志審計
http://www.68idc.cn/help/server/linux/2014042190951.html

三、搭建簡易堡壘機(jī) - 安裝jailkit實現(xiàn)chroot

wget https://olivier.sessink.nl/jailkit/jailkit-2.19.tar.bz2
tar jxvf jailkit-2.19.tar.bz2
cd jailkit-2.19
./configure && make && make install
mkdir /home/jail
jk_init -v -j /home/jail/ basicshell
jk_init -v -j /home/jail/ editors
jk_init -v -j /home/jail/ netutils
jk_init -v -j /home/jail/ ssh
mkdir /home/jail/usr/sbin
cp /usr/sbin/jk_lsh /home/jail/usr/sbin/jk_lsh
useradd lisi
passwd lisi
jk_jailuser -m -j /home/jail lisi
vim /home/jail/etc/passwd //把lisi那一行的/usr/sbin/jk_lsh改為/bin/bash

#下載安裝jailkit
[root@minglinux-01 /usr/local/src] wget https://olivier.sessink.nl/jailkit/jailkit-2.19.tar.bz2
[root@minglinux-01 /usr/local/src] tar jxvf jailkit-2.19.tar.bz2 
[root@minglinux-01 /usr/local/src] cd jailkit-2.19/
[root@minglinux-01 /usr/local/src/jailkit-2.19] ./configure 
[root@minglinux-01 /usr/local/src/jailkit-2.19] make && make install

#創(chuàng)建虛擬系統(tǒng)的根目錄壳繁,chroot到該目錄下
[root@minglinux-01 /usr/local/src/jailkit-2.19] mkdir /home/jail
#分別執(zhí)行以下命令震捣,目的是將一些基礎(chǔ)指令和庫文件搞到/home/jail里面去
[root@minglinux-01 /usr/local/src/jailkit-2.19] jk_init -v -j /home/jail/ basicshell
[root@minglinux-01 /usr/local/src/jailkit-2.19] jk_init -v -j /home/jail/ editors
[root@minglinux-01 /usr/local/src/jailkit-2.19] jk_init -v -j /home/jail/ netutils
[root@minglinux-01 /usr/local/src/jailkit-2.19] jk_init -v -j /home/jail/ ssh

#拷貝虛擬系統(tǒng)shell
[root@minglinux-01 /usr/local/src/jailkit-2.19] mkdir /home/jail/usr/sbin
[root@minglinux-01 /usr/local/src/jailkit-2.19] cp /usr/sbin/jk_lsh /home/jail/usr/sbin/jk_lsh

#在源系統(tǒng)創(chuàng)建用戶
[root@minglinux-01 /usr/local/src/jailkit-2.19] useradd lisi  #123456
[root@minglinux-01 /usr/local/src/jailkit-2.19] passwd lisi
更改用戶 lisi 的密碼 。
新的 密碼:
無效的密碼: 密碼少于 8 個字符
重新輸入新的 密碼:
passwd:所有的身份驗證令牌已經(jīng)成功更新闹炉。

#在虛擬系統(tǒng)創(chuàng)建用戶
[root@minglinux-01 /usr/local/src/jailkit-2.19] jk_jailuser -m -j /home/jail/ lisi

#修改虛擬系統(tǒng)passwd
[root@minglinux-01 /usr/local/src/jailkit-2.19] vim /home/jail/etc/passwd
#把zhalixi那一行的/usr/sbin/jk_lsh改為/bin/bash蒿赢,這樣lisi才可以登錄
  1 root:x:0:0:root:/root:/bin/bash
  2 lisi:x:1021:1021::/home/lisi:/bin/bash

#使用用戶lisi登錄到虛擬系統(tǒng),查看系統(tǒng)信息
[lisi@minglinux-01 ~]$ ls
[lisi@minglinux-01 ~]$ ls -l /
total 0
lrwxrwxrwx 1 root root   7 Mar 14 06:14 bin -> usr/bin
drwxr-xr-x 2 root root  44 Mar 14 06:14 dev
drwxr-xr-x 2 root root 240 Mar 14 06:40 etc
drwxr-xr-x 3 root root  18 Mar 14 06:37 home
lrwxrwxrwx 1 root root   9 Mar 14 06:14 lib64 -> usr/lib64
drwxr-xr-x 7 root root  70 Mar 14 06:22 usr
[lisi@minglinux-01 ~]$ 
Display all 117 possibilities? (y or n)
!          caller     cpio       enable     function   kill       printf     select     then       until
./         case       date       esac       getopts    let        pushd      set        time       vi
:          cat        dd         eval       grep       ln         pwd        sh         times      vim
[          cd         declare    exec       gunzip     local      read       shift      touch      wait
[[         chmod      dirs       exit       gzip       logout     readarray  shopt      trap       wget
]]         command    disown     export     hash       ls         readonly   sleep      true       while
alias      compgen    do         false      help       mapfile    return     source     type       zcat
bash       complete   done       fc         history    mkdir      rm         ssh        typeset    {
bg         compopt    echo       fg         host       mktemp     rmdir      suspend    ulimit     }
bind       continue   egrep      fgrep      if         more       rsync      sync       umask      
break      coproc     elif       fi         in         mv         scp        tar        unalias                                   
builtin    cp         else       for        jobs       popd       sed        test       unset      
[lisi@minglinux-01 ~]$ ls /etc/
bashrc  host.conf  issue    ld.so.conf  nsswitch.conf  profile    resolv.conf  vimrc
group   hosts      ld.so.cache  motd        passwd     protocols  services
#虛擬系統(tǒng)搭建完成
#源系統(tǒng)(跳板機(jī))安全設(shè)置

#1.跳板機(jī)創(chuàng)建authorized_keys文件并放入對應(yīng)客戶端機(jī)器或ssh客戶端密鑰渣触,設(shè)置密鑰登錄
[lisi@minglinux-01 ~]$ vim ssh/authorized_keys 

#2.在跳板機(jī)里設(shè)置只允許密鑰登錄羡棵,即跳板機(jī)需要密鑰認(rèn)證登錄虛擬系統(tǒng)
[root@minglinux-01 /home/jail] vim /etc/ssh/sshd_config 
··· 
 65 PasswordAuthentication no  #將改行該為禁止密碼登錄

#3.跳板機(jī)設(shè)置添加iptables規(guī)則,比如把不需要的端口或服務(wù)全部關(guān)閉

#4.跳板機(jī)設(shè)置限制登錄源ip嗅钻,除了192.168.162.0/24網(wǎng)段外其他ip都不能遠(yuǎn)程登錄跳板機(jī)
[root@minglinux-01 /home/jail] vim /etc/hosts.allow 
11 sshd: 192.168.162.0/24
[root@minglinux-01 /home/jail] vim /etc/hosts.deny 
14 sshd: ALL

四皂冰、搭建簡易堡壘機(jī) - 日志審計

以下操作是需要在所有被登錄機(jī)器上做的
mkdir /usr/local/records
chmod 777 !$
chmod +t !$
vi /etc/profile //添加
if [ ! -d /usr/local/records/${LOGNAME} ]
then
mkdir -p /usr/local/records/${LOGNAME}
chmod 300 /usr/local/records/${LOGNAME}
fi
export HISTORY_FILE="/usr/local/records/${LOGNAME}/bash_history"
export PROMPT_COMMAND='{ date "+%Y-%m-%d %T ##### $(who am i |awk "{print $1" "$2" "$5}") #### $(history 1 | { read x cmd; echo "$cmd"; })"; } >>$HISTORY_FILE'

#開啟minglinux-02作為客戶機(jī),進(jìn)行一些設(shè)置
##設(shè)置僅允許跳板機(jī)ip遠(yuǎn)程登錄
[root@minglinux-02 ~] vim /etc/hosts.allow 
sshd: 192.168.162.130  192.168.162.1  #后面ip是為了方便windows遠(yuǎn)程連接
[root@minglinux-02 ~] vim /etc/hosts.deny 
sshd: ALL
#客戶機(jī)也應(yīng)該創(chuàng)建lisi賬戶來登錄跳板機(jī)比較好养篓,可以加上sudo權(quán)限
#在minglinux-02上設(shè)置日志審計
[root@minglinux-02 ~] mkdir /usr/local/records
[root@minglinux-02 ~] chmod 777 !$
chmod 777 /usr/local/records
[root@minglinux-02 ~] chmod +t !$  #加t權(quán)限防刪除
chmod +t /usr/local/records
[root@minglinux-02 ~] vim /etc/profile
#加入以下內(nèi)容
···
if [ ! -d  /usr/local/records/${LOGNAME} ]  
then
mkdir -p /usr/local/records/${LOGNAME}  #創(chuàng)建與登錄用戶名相同的文件夾
chmod 300 /usr/local/records/${LOGNAME}  #對文件夾設(shè)置300權(quán)限
fi
export HISTORY_FILE="/usr/local/records/${LOGNAME}/bash_history"   #歷史記錄日志變量
export PROMPT_COMMAND='{ date "+%Y-%m-%d %T ##### $(who am i |awk "{print \$1\" \"\$2\" \"\$5}") #### $(history 1 | { read x cmd; echo "$cmd"; })"; } >>$HISTORY_FILE'
···


五秃流、jumpserver介紹

官網(wǎng)www.jumpserver.org
Jumpserver是一款使用Python, Django開發(fā)的開源跳板機(jī)系統(tǒng), 助力互聯(lián)網(wǎng)企業(yè)高效 用戶、資產(chǎn)柳弄、權(quán)限舶胀、審計 管理
Auth 統(tǒng)一認(rèn)證
CMDB 資產(chǎn)管理
統(tǒng)一授權(quán)
日志審計
自動化運維(ansible)

六、安裝jumpserver

參考http://docs.jumpserver.org/zh/docs/step_by_step.html
我記錄一晚上的安裝過程因為關(guān)了一次瀏覽器而丟失了,歷史版本直接回到昨天下午了嚣伐。安裝過程挺長的糖赔,系統(tǒng)最好是干凈一點,我用安裝了rediis轩端、nginx的機(jī)器安裝時出現(xiàn)的問題很難找到答案放典,最后換了干凈點的機(jī)器才安裝成功。

image.png
#啟動命令
source /opt/py3/bin/activate
cd /opt/jumpserver
./jms start all -d
cd /opt/coco
./cocod start -d

#設(shè)置開機(jī)啟動
[root@minglinux-04 ~]# vim /etc/rc.local

#
# It is highly advisable to create own systemd services or udev rules
# to run scripts during boot instead of using this file.
#
# In contrast to previous versions due to parallel execution during boot
# this script will NOT be run after all other services.
#
# Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure
# that this script will be executed during boot.

touch /var/lock/subsys/local
source /opt/py3/bin/activate ; cd /opt/jumpserver ; ./jms start all -d &> /dev/null

七基茵、使用jumpserver

瀏覽器輸入ip:8080 訪問jumpserver
默認(rèn)用戶名是admin奋构,密碼是minglinux
點擊用戶管理,選擇用戶耿导,點擊右側(cè)Administrator的個人信息声怔,然后點更新,設(shè)置密碼
創(chuàng)建用戶組 運維
創(chuàng)建用戶 ming
點擊設(shè)置舱呻,默認(rèn)管理用戶醋火,該用戶為管理員用戶,應(yīng)該有sudo權(quán)限箱吕,需要在每一臺客戶機(jī)上創(chuàng)建該用戶(用戶名自定義芥驳,jump)
在一臺linux機(jī)器上生成一個密鑰對,用來作為該管理用戶的密鑰對
把私鑰粘貼到默認(rèn)密鑰下面
在客戶機(jī)上創(chuàng)建jump用戶茬高,并設(shè)置sudo權(quán)限兆旬,把剛剛生成的密鑰對里面的公鑰放到該客戶機(jī)的jump用戶家目錄.ssh/authorized_keys文件里
資產(chǎn)管理,查看資產(chǎn)組怎栽,添加資產(chǎn)組(如丽猬,dev)
資產(chǎn)管理,查看資產(chǎn)熏瞄,添加資產(chǎn)脚祟,填寫各項信息
授權(quán)管理,系統(tǒng)用戶强饮,添加系統(tǒng)用戶由桌,該用戶為我們登錄所有客戶機(jī)的用戶
授權(quán)規(guī)則,添加規(guī)則邮丰,創(chuàng)建授權(quán)規(guī)則

image.png

八行您、用戶管理

jumpserver用戶用來登錄jumpserver(web界面、ssh登錄)
管理用戶用來自動創(chuàng)建客戶機(jī)上的系統(tǒng)用戶剪廉、批量執(zhí)行命令等操作
客戶機(jī)上的系統(tǒng)用戶娃循,用來通過jumpserver去登錄每一臺客戶機(jī)的用戶

無標(biāo)題.png

九、資產(chǎn)管理

十斗蒋、客戶端登錄jumpserver

普通用戶的密碼以及密鑰下載地址淮野、密鑰密碼都會通過郵件的方式發(fā)送給用戶
瀏覽器登錄普通用戶捧书,可以查看有權(quán)限的主機(jī),也可以在web界面下登錄主機(jī)骤星、上傳和下載文件
xshell創(chuàng)建新的連接
ip為jumpserver的ip,端口為22
用戶名為普通用戶名字
設(shè)置密鑰認(rèn)證
連接后爆哑,出現(xiàn)登錄頁面洞难,數(shù)據(jù)p查看所有被授權(quán)主機(jī)

輸入主機(jī)前面的數(shù)字可以登錄到對應(yīng)的主機(jī)下面

  • 將公鑰拷貝到j(luò)umpserver
image.png

image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市揭朝,隨后出現(xiàn)的幾起案子队贱,更是在濱河造成了極大的恐慌,老刑警劉巖潭袱,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件柱嫌,死亡現(xiàn)場離奇詭異,居然都是意外死亡屯换,警方通過查閱死者的電腦和手機(jī)编丘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來彤悔,“玉大人嘉抓,你說我怎么就攤上這事≡我ぃ” “怎么了抑片?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長杨赤。 經(jīng)常有香客問我敞斋,道長,這世上最難降的妖魔是什么疾牲? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任植捎,我火速辦了婚禮,結(jié)果婚禮上说敏,老公的妹妹穿的比我還像新娘鸥跟。我一直安慰自己,他們只是感情好盔沫,可當(dāng)我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布医咨。 她就那樣靜靜地躺著,像睡著了一般架诞。 火紅的嫁衣襯著肌膚如雪拟淮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天谴忧,我揣著相機(jī)與錄音很泊,去河邊找鬼角虫。 笑死,一個胖子當(dāng)著我的面吹牛委造,可吹牛的內(nèi)容都是我干的戳鹅。 我是一名探鬼主播,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼昏兆,長吁一口氣:“原來是場噩夢啊……” “哼枫虏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起爬虱,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤隶债,失蹤者是張志新(化名)和其女友劉穎煞檩,沒想到半個月后筛欢,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體逐纬,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡潜秋,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年捆昏,在試婚紗的時候發(fā)現(xiàn)自己被綠了纤垂。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片验辞。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡诱建,死狀恐怖稀并,靈堂內(nèi)的尸體忽然破棺而出仅颇,到底是詐尸還是另有隱情,我是刑警寧澤碘举,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布忘瓦,位于F島的核電站,受9級特大地震影響引颈,放射性物質(zhì)發(fā)生泄漏耕皮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一蝙场、第九天 我趴在偏房一處隱蔽的房頂上張望凌停。 院中可真熱鬧,春花似錦售滤、人聲如沸罚拟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赐俗。三九已至,卻和暖如春弊知,著一層夾襖步出監(jiān)牢的瞬間阻逮,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工秩彤, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留叔扼,地道東北人事哭。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像瓜富,于是被迫代替她去往敵國和親鳍咱。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,969評論 2 355

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