Linux编译安装OpenSSH-9.4p1 |
发表者:admin分类:应用服务2023-08-14 17:02:23 阅读[415] |
OpenSSH-9.4p1
Introduction to OpenSSH
The OpenSSH package contains ssh clients and the sshd daemon. This is useful for encrypting authentication and subsequent traffic over a network. The ssh and scp commands are secure implementations of telnet and rcp respectively.
Note
Development versions of BLFS may not build or run some packages properly if LFS or dependencies have been updated since the most recent stable versions of the books.
Package Information
Download (HTTP): https://ftp.openbsd.org/pub/OpenBSD/OpenSSH/portable/openssh-9.4p1.tar.gz
Download MD5 sum: 4bbd56a7ba51b0cd61debe8f9e77f8bb
Download size: 1.7 MB
Estimated disk space required: 45 MB (add 22 MB for tests)
Estimated build time: 0.2 SBU (Using parallelism=4; running the tests takes about 20 minutes, irrespective of processor speed)
OpenSSH Dependencies
Optional
GDB-13.2 (for tests), Linux-PAM-1.5.3, Xorg Applications (or Xorg build environment, see Command Explanations), MIT Kerberos V5-1.21.1, Which-2.21 (for tests), libedit, LibreSSL Portable, OpenSC, and libsectok
Optional Runtime (Used only to gather entropy)
Net-tools-2.10, and Sysstat-12.7.2
Editor Notes: https://wiki.linuxfromscratch.org/blfs/wiki/OpenSSH
Installation of OpenSSH
OpenSSH runs as two processes when connecting to other computers. The first process is a privileged process and controls the issuance of privileges as necessary. The second process communicates with the network. Additional installation steps are necessary to set up the proper environment, which are performed by issuing the following commands as the root
user:
install -v -g sys -m700 -d /var/lib/sshd && groupadd -g 50 sshd && useradd -c 'sshd PrivSep' \ -d /var/lib/sshd \ -g sshd \ -s /bin/false \ -u 50 sshd
Install OpenSSH by running the following commands:
./configure --prefix=/usr \ --sysconfdir=/etc/ssh \ --with-privsep-path=/var/lib/sshd \ --with-default-path=/usr/bin \ --with-superuser-path=/usr/sbin:/usr/bin \ --with-pid-dir=/run && make
To test the results, issue: make -j1 tests.
Now, as the root
user:
make install && install -v -m755 contrib/ssh-copy-id /usr/bin && install -v -m644 contrib/ssh-copy-id.1 \ /usr/share/man/man1 && install -v -m755 -d /usr/share/doc/openssh-9.4p1 && install -v -m644 INSTALL LICENCE OVERVIEW README* \ /usr/share/doc/openssh-9.4p1
Command Explanations
--sysconfdir=/etc/ssh
: This prevents the configuration files from being installed in /usr/etc
.
--with-default-path=/usr/bin
and --with-superuser-path=/usr/sbin:/usr/bin
: These set PATH
consistent with LFS and BLFS Shadow package.
--with-pid-dir=/run
: This prevents OpenSSH from referring to deprecated /var/run
.
--with-pam
: This parameter enables Linux-PAM support in the build.
--with-xauth=$XORG_PREFIX/bin/xauth
: Set the default location for the xauth binary for X authentication. The environment variable XORG_PREFIX
should be set following Xorg build environment. This can also be controlled from sshd_config
with the XAuthLocation keyword. You can omit this switch if Xorg is already installed.
--with-kerberos5=/usr
: This option is used to include Kerberos 5 support in the build.
--with-libedit
: This option enables line editing and history features for sftp.
Configuring OpenSSH
Config Files
~/.ssh/*
, /etc/ssh/ssh_config
, and /etc/ssh/sshd_config
There are no required changes to any of these files. However, you may wish to view the /etc/ssh/
files and make any changes appropriate for the security of your system. One recommended change is that you disable root
login via ssh. Execute the following command as the root
user to disable root
login via ssh:
echo "PermitRootLogin no" >> /etc/ssh/sshd_config
If you want to be able to log in without typing in your password, first create ~/.ssh/id_rsa and ~/.ssh/id_rsa.pub with ssh-keygen and then copy ~/.ssh/id_rsa.pub to ~/.ssh/authorized_keys on the remote computer that you want to log into. You'll need to change REMOTE_USERNAME and REMOTE_HOSTNAME for the username and hostname of the remote computer and you'll also need to enter your password for the ssh-copy-id command to succeed:
ssh-keygen && ssh-copy-id -i ~/.ssh/id_rsa.pubREMOTE_USERNAME
@REMOTE_HOSTNAME
Once you've got passwordless logins working it's actually more secure than logging in with a password (as the private key is much longer than most people's passwords). If you would like to now disable password logins, as the root
user:
echo "PasswordAuthentication no" >> /etc/ssh/sshd_config && echo "KbdInteractiveAuthentication no" >> /etc/ssh/sshd_config
If you added Linux-PAM support and you want ssh to use it then you will need to add a configuration file for sshd and enable use of LinuxPAM. Note, ssh only uses PAM to check passwords, if you've disabled password logins these commands are not needed. If you want to use PAM, issue the following commands as the root
user:
sed 's@d/login@d/sshd@g' /etc/pam.d/login > /etc/pam.d/sshd && chmod 644 /etc/pam.d/sshd && echo "UsePAM yes" >> /etc/ssh/sshd_config
Additional configuration information can be found in the man pages for sshd, ssh and ssh-agent.
Boot Script
To start the SSH server at system boot, install the /etc/rc.d/init.d/sshd
init script included in the blfs-bootscripts-20230714 package.
make install-sshd
Contents
Short Descriptions
is a file copy program that acts like rcp except it uses an encrypted protocol | |
is an FTP-like program that works over the SSH1 and SSH2 protocols | |
is an rlogin/rsh-like client program except it uses an encrypted protocol | |
is a daemon that listens for ssh login requests | |
is a tool which adds keys to the ssh-agent | |
is an authentication agent that can store private keys | |
is a script that enables logins on remote machines using local keys | |
is a key generation tool | |
is a utility for gathering public host keys from a number of hosts |
转载请标明出处【Linux编译安装OpenSSH-9.4p1】。
《www.micoder.cc》
虚拟化云计算,系统运维,安全技术服务.
Tags: | [阅读全文...] |
最新评论