CentOS Stream 9 configures sshd_ Configure AllowUsers to implement SSH access control
1, Description of several popular versions of CentOS
data:image/s3,"s3://crabby-images/66992/66992a0a50a9e0a2de394ff8b2cc8e252b14ff58" alt=""
data:image/s3,"s3://crabby-images/27ed4/27ed4ed04963559e6afbb13096c8ff0c69c6fc51" alt=""
(the picture can be zoomed in)
CentOS Linux and CentOS Stream
data:image/s3,"s3://crabby-images/41b34/41b3498e0bda1a087ef269ed24bea1159b2ded04" alt=""
(the picture can be zoomed in)
- CentOS Linux currently has two major versions
-- CentOS Linux 7
-- CentOS Linux 8
data:image/s3,"s3://crabby-images/99fe0/99fe0bb397821a5fb901eeec024433429ea00e4f" alt=""
(the picture can be zoomed in)
- CentOS Stream currently has two major versions
-- CentOS Stream 8
-- CentOS Stream 9
data:image/s3,"s3://crabby-images/79519/79519afd872e2c634d852ee30bd73c689a852df2" alt=""
(the picture can be zoomed in)
2, CentOS Stream 9 system installation experience
data:image/s3,"s3://crabby-images/1adc5/1adc5e2859b496f47b99ba7a204a98de2280567b" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/db443/db443f628512c7642144a52dd07ef99f8a9dbc30" alt=""
(the picture can be zoomed in)
1. Screenshot of installation process
data:image/s3,"s3://crabby-images/8fbd7/8fbd7c933ad79f9c52a2802f27558783defd92fa" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/a0e49/a0e4973cc871ad1489e31aee7980f87319b7bbb6" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/312c8/312c80ba72d4cb27a303119872a5352470c4b250" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/e929f/e929f9d60d4cf4b171f83878492ef00015038998" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/e352c/e352c32c8e57d951a9b8739e0e572e7f2e9b36fd" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/84447/84447996fba07420a825fa5b542c0f9ff98f8ed7" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/1d02d/1d02d1231ce79136df6bc55a4d1694e495dfce9c" alt=""
(the picture can be zoomed in)
2. Close SELINUX after installation
getenforce setenforce 0 sed -i 's/^SELINUX=.*$/SELINUX=disabled/' /etc/selinux/config cat /etc/selinux/config
data:image/s3,"s3://crabby-images/baccf/baccf43297181b977431f8980d9c02573ce5e323" alt=""
(the picture can be zoomed in)
Let's get to the point
3, CentOS Stream 9 configures sshd_ Configure AllowUsers to implement SSH access control
1. CentOS Stream 9 does not have / etc / hosts by default allow
In CentOS Stream 9 system
ll /etc/hosts.allow ldd /usr/sbin/sshd
You can find no libwrap so. 0 library file
data:image/s3,"s3://crabby-images/b428f/b428f092335df01b4fc435f97635d10b2cd6b834" alt=""
(the picture can be zoomed in)
There is no / etc / hosts.in the system Allow and / etc / hosts Deny file
Compare CentOS7 system
data:image/s3,"s3://crabby-images/f3cf0/f3cf076c388df12f5e534ef10738294ba1961ebc" alt=""
Refer to the following two articles for details
Using tcp_wrapper implements IP access control of SSH login
On the problem of bypassing fortress machines in enterprise network security
2,man sshd_config
man sshd_config view AllowUsers parameter configuration description
AllowUsers This keyword can be followed by a list of user name patterns, separated by spaces. If specified, login is allowed only for user names that match one of the patterns. Only user names are valid; a numerical user ID is not recognized. By default, login is allowed for all users. If the pattern takes the form USER@HOST then USER and HOST are separately checked, restricting logins to particular users from particular hosts. HOST criteria may additionally contain addresses to match in CIDR ad‐ dress/masklen format. The allow/deny users directives are processed in the follow‐ ing order: DenyUsers, AllowUsers.
data:image/s3,"s3://crabby-images/396ac/396acb2511fb664db1314f6211c2d58aef47d0c5" alt=""
(the picture can be zoomed in)
3. SSH access control configuration steps and Practice
vi /etc/ssh/sshd_config Add the following line, only 192 are allowed.168.31.100+root User login AllowUsers root@192.168.31.100 systemctl restart sshd
data:image/s3,"s3://crabby-images/19a50/19a5048875fd0e8a7dfdd01614285b31433a51a0" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/4eb3c/4eb3cfedce0315aa6a53ca0cf1b181cfaa830bc3" alt=""
(the picture can be zoomed in)
Authentication: 192.168.31.232 try SSH login to CentOS Stream 9 192.168.31.192
Entering the correct password will also prompt login failure
data:image/s3,"s3://crabby-images/ae4f9/ae4f99fe9d1daa0fb3d093b5139a8c529e554c78" alt=""
(the picture can be zoomed in)
Viewing logs on the CentOS Stream 9 server
tail -f /var/log/secure You can see the following log Jan 24 21:07:47 localhost sshd[1447]: User root from 192.168.31.232 not allowed because not listed in AllowUsers
data:image/s3,"s3://crabby-images/65173/65173e60b51e9d25a3bfbe65c327aadf6e1dbd78" alt=""
(the picture can be zoomed in)
In this way, SSH access control can be realized
When the line AllowUsers is commented out and the sshd service is restarted, you can log in normally
data:image/s3,"s3://crabby-images/11f16/11f16544c69e9216fb26e55efc0b98d4d5913fb9" alt=""
(the picture can be zoomed in)
data:image/s3,"s3://crabby-images/9d4fa/9d4fae6f93e4d549da0d216991e53bb3fa3c456f" alt=""
(the picture can be zoomed in)
Tips:
CentOS Linux 8 will no longer support / etc / hosts Allow and / etc / hosts deny
1,CentOS Linux 8
2,CentOS Stream 9
3,CentOS Stream 8
The above three systems can realize SSH access control according to the method in this paper