SSH

SSH - Secure Shell #

Enabling SSH #

sudo apt update && sudo apt install openssh-server
sudo systemctl status ssh
sudo ufw allow ssh

Disabling SSH #

sudo systemctl disable --now ssh

Re-enable SSH #

sudo systemctl enable --now ssh

Disable password authentication in SSH #

sudo nano /etc/ssh/sshd_config
PasswordAuthentication no
sudo systemctl restart ssh

Create an RSA key pair #

ssh-keygen -t rsa

Correct file permissions for ssh keys and config #

ssh-keygen -t rsa -b 4096 -N '' -C "email@gmail.com" -f ~/.ssh/id_rsa
ssh-keygen -t rsa -b 4096 -N '' -C "email@gmail.com" -f ~/.ssh/github_rsa
ssh-keygen -t rsa -b 4096 -N '' -C "email@gmail.com" -f ~/.ssh/mozilla_rsa
chmod 700 ~/.ssh
chmod 644 ~/.ssh/authorized_keys
chmod 644 ~/.ssh/known_hosts
chmod 644 ~/.ssh/config
chmod 600 ~/.ssh/id_rsa
chmod 644 ~/.ssh/id_rsa.pub

chmod 600 ~/.ssh/github_rsa
chmod 644 ~/.ssh/github_rsa.pub

chmod 600 ~/.ssh/mozilla_rsa
chmod 644 ~/.ssh/mozilla_rsa.pub

ssh-agent #

eval "$(ssh-agent -s)"
ssh-add ~/.ssh/id_rsa
ssh-add ~/.ssh/github_rsa
ssh-add ~/.ssh/mozilla_rsa

Convert OpenSSH keys to Putty (.ppk) #

sudo apt install putty-tools
puttygen -t rsa -C ~/.ssh/id_rsa -o ~/.ssh/id_rsa.ppk

or

cd ~/.ssh/
puttygen id_rsa -o id_rsa.ppk

Custom cert #

ssh demo@ip-adress.my -i ~/.ssh/id_demo

.ssh/config #

Host demo
    HostName ip-adress.my
    User demo
    Port 7654
    IdentityFile ~/.ssh/id_demo
    LogLevel INFO
    Compression yes

Copy the public key file to your account on the remote system #

ssh-copy-id -i ~/.ssh/id_rsa.pub <server-user>@<server-public-ip-address>

with non-standard SSH Port #

ssh -o StrictHostKeyChecking=no deploy@${HOST} -p ${PORT} 'rm -rf site_${BUILD_NUMBER} && mkdir site_${BUILD_NUMBER}'

SSH tunnel to forward port #

ssh <host> -L<local_port>:<target_host>:<target_port>

# Example:
ssh <host> -L5306:localhost:3306
mysql -u<mysql_user> -p<mysql_pass> --protocol=tcp --port=5306 -hlocalhost <mysql_database>
Edit Edit this page