關於 SSH Server 的整體設定

2022-09-02 19:45:10 字數 4716 閱讀 7860

1 # 1

. 關於 ssh server 的整體設定,包含使用的 port 啦,以及使用的密碼演算方式

2 port 22          # ssh 預設使用 22

這個 port,您也可以使用多的 port !

3# 亦即重複使用 port 這個設定專案即可!

4 protocol 2,1        # 選擇的 ssh 協議版本,可以是 1 也可以是 2

,5               # 如果要同時支援兩者,就必須要使用 2,1

這個分隔了!

6 #listenaddress 0.0.0.0

# 監聽的主機適配卡!舉個例子來說,如果您有兩個 ip,

7               # 分別是 192.168.0.100 及 192.168.2.20

,那麼只想要

8               # 開放 192.168.0.100

時,就可以寫如同下面的樣式:

9 listenaddress 192.168.0.100 # 只監聽來自 192.168.0.100

這個 ip 的ssh聯機。

10# 如果不使用設定的話,則預設所有介面均接受 ssh

11 pidfile /var/run/sshd.pid      # 可以放置 sshd 這個 pid 的檔案!左列為預設值

12 logingracetime 600

# 當使用者連上 ssh server 之後,會出現輸入密碼的畫面,

13# 在該畫面中,在多久時間內沒有成功連上 ssh server ,

14# 就斷線!時間為秒!

15 compression yes      # 是否可以使用壓縮指令?當然可以?!

1617 # 2

. 說明主機的 private key 放置的檔案,預設使用下面的檔案即可!

18 hostkey /etc/ssh/ssh_host_key    # ssh version 1

使用的私鑰

19 hostkey /etc/ssh/ssh_host_rsa_key  # ssh version 2

使用的 rsa 私鑰

20 hostkey /etc/ssh/ssh_host_dsa_key  # ssh version 2

使用的 dsa 私鑰

2122 # 2.1 關於 version 1

的一些設定!

23 keyregenerationinterval 3600     # 由前面聯機的說明可以知道, version 1

會使用

24# server 的 public key ,那麼如果這個 public

25# key 被偷的話,豈不完蛋?所以需要每隔一段時間

26# 來重新建立一次!這裡的時間為秒!

27 serverkeybits 768

# 沒錯!這個就是 server key 的長度!

28 # 3

. 關於登入檔案的訊息資料放置與 daemon 的名稱!

29syslogfacility auth         # 當有人使用 ssh 登入系統的時候,ssh會記錄資

30# 訊,這個資訊要記錄在什麼 daemon name 底下?

31                    # 預設是以 auth 來設定的,即是 /var/log/secure

32# 裡面!什麼?忘記了!回到 linux 基礎去翻一下

33# 其它可用的 daemon name 為:daemon,user,auth,

34# local0,local1,local2,local3,local4,local5,

35loglevel info            # 登入記錄的等級!嘿嘿!任何訊息!

36# 同樣的,忘記了就回去參考!

37 # 4

. 安全設定專案!極重要!

38 # 4.1

登入設定部分

39permitrootlogin no     # 是否允許 root 登入!預設是允許的,但是建議設定成 no!

40userlogin no        # 在 ssh 底下本來就不接受 login 這個程式的登入!

41strictmodes yes      # 當使用者的 host key 改變之後,server 就不接受聯機,

42# 可以抵擋部分的木馬程式!

43 #rsaauthentication yes   # 是否使用純的 rsa 認證!?僅針對 version 1

!44 pubkeyauthentication yes  # 是否允許 public key ?當然允許啦!只有 version 2

45 authorizedkeysfile .ssh/authorized_keys

46# 上面這個在設定若要使用不需要密碼登入的賬號時,那麼那個

47# 賬號的存放檔案所在檔名!

48 # 4.2

認證部分

49rhostsauthentication no  # 本機系統不止使用 .rhosts ,因為僅使用 .rhosts 太

50# 不安全了,所以這裡一定要設定為 no !

51 ignorerhosts yes      # 是否取消使用 ~/.ssh/.rhosts 來做為認證!當然是!

52 rhostsrsaauthentication no # 這個選項是專門給 version 1

用的,使用 rhosts 檔案在

53               # /etc/hosts.equiv配合 rsa 演算方式來進行認證!不要使用

54 hostbasedauthentication no # 這個專案與上面的專案類似,不過是給 version 2

使用的!

55 ignoreuserknownhosts no  # 是否忽略家目錄內的 ~/.ssh/known_hosts 這個檔案所記錄

56# 的主機內容?當然不要忽略,所以這裡就是 no 啦!

57 passwordauthentication yes # 密碼驗證當然是需要的!所以這裡寫 yes ?!

58permitemptypasswords no  # 若上面那一項如果設定為 yes 的話,這一項就最好設定

59# 為 no ,這個專案在是否允許以空的密碼登入!當然不許!

60challengeresponseauthentication yes # 挑戰任何的密碼認證!所以,任何 login.conf

61# 規定的認證方式,均可適用!

62#pamauthenticationviakbdint yes # 是否啟用其它的 pam 模組!啟用這個模組將會

63# 導致 passwordauthentication 設定失效!

6465 # 4.3

與 kerberos 有關的引數設定!因為我們沒有 kerberos 主機,所以底下不用設定!

66#kerberosauthentication no

67#kerberosorlocalpasswd yes

68#kerberosticketcleanup yes

69#kerberostgtpassing no

7071 # 4.4 底下是有關在 x-window 底下使用的相關設定!

72x11forwarding yes

73 #x11displayoffset 10

74#x11uselocalhost yes

75 # 4.5

登入後的專案:

76printmotd no # 登入後是否顯示出一些資訊呢?例如上次登入的時間、地點等

77# 等,預設是 yes ,但是,如果為了安全,可以考慮改為 no !

78printlastlog yes     # 顯示上次登入的資訊!可以啊!預設也是 yes !

79keepalive yes       # 一般而言,如果設定這專案的話,那麼 ssh server 會傳送

80# keepalive 的訊息給 client 端,以確保兩者的聯機正常!

81# 在這個情況下,任何一端死掉後, ssh 可以立刻知道!而不會

82# 有殭屍程式的發生!

83useprivilegeseparation yes # 使用者的許可權設定專案!就設定為 yes 吧!

84 maxstartups 10

# 同時允許幾個尚未登入的聯機畫面?當我們連上 ssh ,

85# 但是尚未輸入密碼時,這個時候就是我們所謂的聯機畫面啦!

86# 在這個聯機畫面中,為了保護主機,所以需要設定最大值,

87# 預設最多十個聯機畫面,而已經建立聯機的不計算在這十個當中

88 # 4.6

關於使用者抵擋的設定專案:

89 denyusers *# 設定受抵擋的使用者名稱,如果是全部的使用者,那就是全部

90# 擋吧!若是部分使用者,可以將該賬號填入!例如下列!

91denyusers test

92denygroups test      # 與 denyusers 相同!僅抵擋幾個群組而已!

93 # 5

. 關於 sftp 服務的設定專案!

94 subsystem sftp /usr/lib/ssh/sftp-server

補充:gssapicleanupcredentials

是否在使用者退出登入後自動銷毀使用者憑證快取。預設值是」yes」。僅用於ssh-2。

Ubuntu下SSH Server的安裝和設定

1 安裝 openssh server sudo apt get install openssh server 2 重啟伺服器 sudo etc init.d ssh restart 如 果這一步報錯 could not load host key etc ssh ssh host dsa key ...

ubuntu中ssh server的安裝與開機啟動

ssh程式分為有客戶端程式openssh client和服務端程式openssh server。如果需要ssh登陸到別的電腦,需要安裝openssh client,該程式ubuntu是預設安裝的。而如果需要從遠端連線到本機,則需要安裝openssh server,該程式需要自己安裝。sudo apt...

ubuntu中ssh server的安裝與開機啟動

ubuntu中ssh server的安裝與開機啟動 ssh程式分為有客戶端程式openssh client和服務端程式openssh server。如果需要ssh登陸到別的電腦,需要安裝openssh client,該程式ubuntu是預設安裝的。而如果需要從遠端連線到本機,則需要安裝openssh...