Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/centic9/generate-and-send-ssh-key
Script to automate the setup of ssh-public/private-key authentication to avoid some common pitfalls
https://github.com/centic9/generate-and-send-ssh-key
Last synced: 21 days ago
JSON representation
Script to automate the setup of ssh-public/private-key authentication to avoid some common pitfalls
- Host: GitHub
- URL: https://github.com/centic9/generate-and-send-ssh-key
- Owner: centic9
- License: apache-2.0
- Created: 2015-10-07T10:50:18.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2024-05-06T23:25:31.000Z (7 months ago)
- Last Synced: 2024-10-17T05:09:09.096Z (about 1 month ago)
- Language: Shell
- Homepage:
- Size: 36.1 KB
- Stars: 197
- Watchers: 6
- Forks: 76
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
## What
This is a small script to perform all the tasks that are necessary to create a private/public keypair for
ssh-authentication for password-less connecting to a remote server. Additionally it performs some checks and
adjusts file-permissions both locally and on the remote server to avoid some common pitfalls.## Why
Because I failed every time I tried to do this manually.
## How
### Preconditions
You need to be able to connect to the remote server with ssh and a username and password.
### Grab it
git clone https://github.com/centic9/generate-and-send-ssh-key.git
### Run it
The script expects some commandline arguments which specify which key should be transferred/created and
where it should be sent to:-u (--user) , default: $USER
-f (--file) , default: ~/.ssh/id_test
-h (--host) , default: host
-p (--port) , default:
-k (--keysize) , default: 2048
-t (--keytype) , default: rsa
-P(--passphrase) , default:You should at least set `--user`, `--file`, and `--host`.
cd generate-and-send-ssh-key
./generate-and-send-ssh-key.sh --user bob --host myhostThis will ask for the password of the target host at least once, probably twice, if the permissions are not set correctly yet.
If the key-file does not exist yet, a new key will be generated.
### Enjoy
Now you should be able to connect to the machine via ```ssh -i $FILENAME $USER@$HOST```.
If you use the filename
```~/.ssh/id_rsa``` you can omit the "-i" argument to ssh.## Support this project
If you find this tool useful and would like to support it, you can [Sponsor the author](https://github.com/sponsors/centic9)
## Caveat
This script will remove write access to your home-directory for "group" and "other" on the remote server because
ssh-public/private key authentication will not work otherwise.So if there are processes running as different user,
writing data to this directory may fail for them after this script is run.## Related documents
* http://linux.die.net/man/1/ssh-copy-id
* https://en.wikipedia.org/wiki/Ssh-keygen
* http://www.openbsd.org/cgi-bin/man.cgi/OpenBSD-current/man1/ssh-keygen.1?query=ssh-keygen&sec=1
* http://www.thegeekstuff.com/2008/11/3-steps-to-perform-ssh-login-without-password-using-ssh-keygen-ssh-copy-id/
* http://askubuntu.com/questions/4830/easiest-way-to-copy-ssh-keys-to-another-machine
* http://www.daveperrett.com/articles/2010/09/14/ssh-authentication-refused/## Documentation on SSH login issues
* How to tackle slow login: https://jrs-s.net/2017/07/01/slow-ssh-logins/
* Slow SSH logins? Try to restart services `systemd-logind` and `dbus` on the ssh server#### Licensing
Copyright 2015-2022 Dominik Stadler
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at [http://www.apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0)Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.