05. Remote Access - some exercises for ssh and parallel-ssh
Chapter 5 gives some examples for ssh and parallel-ssh (pssh...). As a note, in Debian/Ubuntu etc. pssh etc. has been renamed to:
parallel-ssh
parallel-scp
parallel-slurp
etc.
I have 5 VMs running on my PC - master, worker1...worker4. The workers are Ubuntu 18.04 servers, so they use the /etc/netplan/...yaml file for network configuration. I had already manually configured all of them, except for the ~/.ssh/config file.
I created a ~/.ssh/config file on the host with the following content:
Host master
HostName 192.168.0.130
User student
Host worker1
HostName 192.168.0.131
User student
Host worker2
HostName 192.168.0.132
User student
Host worker3
HostName 192.168.0.133
User student
Host worker4
HostName 192.168.0.134
User student
I then ran the following script as an exercise:
#!/bin/bash # Exercise using parallel-scp and parallel-ssh # # ips.txt contains the IP addresses of the hosts, one per line # -h hostfile -- provides list of hosts (IP addresses) # -i inline -- print output inline on localhost # # This script does the following: # 1. Copies the ~.ssh/config file on LOCALHOST to the remote hosts # specified in ips.txt. # 2. Shows the remote config files using cat. # 3. Deletes the remote config files. # 4. Shows the remote config files using cat - this gives an error. # 5. Copies again the ~.ssh/config file on LOCALHOST to the remote hosts. # 6. Shows the remote config files using cat. parallel-scp -h ips.txt ~/.ssh/config /home/heiko/.ssh/ parallel-ssh -ih ips.txt cat ~/.ssh/config parallel-ssh -ih ips.txt rm ~/.ssh/config parallel-ssh -ih ips.txt cat ~/.ssh/config parallel-scp -h ips.txt ~/.ssh/config /home/heiko/.ssh/ parallel-ssh -ih ips.txt cat ~/.ssh/config
Since I already defined aliases for all my VMs, I could also use the aliases inside ips.txt:
worker1 worker2 worker3 worker4
The following is an exercise using parallel-slurp to copy remote files to the local host under ~/outdir:
#!/bin/bash # # Copy /etc/netplan/0....yaml files on remote hosts to local host: parallel-slurp -L ~/outdir -h remhosts.txt /etc/netplan/0* . # Copy the /etc/hosts and /etc/hostname files to local host: parallel-slurp -L ~/outdir -h remhosts.txt /etc/hosts . parallel-slurp -L ~/outdir -h remhosts.txt /etc/hostname .
Using the aliases, these files are then neatly stored in folders worker1...worker4.
I wonder if I could use pscp / parallel-scp to copy configuration stanzas to remote hosts and then manually change e.g. the IP. I'm talking specifically about the /etc/netplan/...yaml config file where I would have to change just the IP.
If I understand correctly, the IP would only change with the "netplan apply" command?
Comments
-
Thank you for the suggestion !
1 -
Just as a footnote, the text already says names may be different, and I just checked on RHEL-8:
c8:/home/coop/Desktop>rpm -qil pssh | grep bin /usr/bin/pnuke /usr/bin/prsync /usr/bin/pscp.pssh /usr/bin/pslurp /usr/bin/pssh c8:/home/coop/Desktop>
1 -
Thanks for the response. I was trying to find out if pssh etc. were actually used for sysadmin tasks and tried to figure out a practical use case. As my experience = inexperience, I probably come up with all kinds of strange ideas on how to use commands.
My post was by no means a critique, just my way of thinking and the hope that someone sets me straight, or confirms the possible use case.
0
Categories
- All Categories
- 177 LFX Mentorship
- 177 LFX Mentorship: Linux Kernel
- 754 Linux Foundation IT Professional Programs
- 374 Cloud Engineer IT Professional Program
- 170 Advanced Cloud Engineer IT Professional Program
- 74 DevOps IT Professional Program - Discontinued
- 5 DevOps & GitOps IT Professional Program
- 100 Cloud Native Developer IT Professional Program
- 7.6K Training Courses & Learning Paths
- 2 AI & ML Training
- 1 Blockchain & Decentralized Identity Training
- 5 Cloud & Containers Training
- 1 Cybersecurity Training
- 2 DevOps & Site-Reliability Training
- 1 Linux Kernel Development Training
- 1 Networking Training
- 2 Open Source Best Practice Training
- 2 System Administration Training
- 1 System Engineering Training
- 1 Web & Application Development Training
- 794 Hardware
- 202 Drivers
- 68 I/O Devices
- 37 Monitors
- 95 Multimedia
- 173 Networking
- 91 Printers & Scanners
- 89 Storage
- 769 Linux Distributions
- 81 Debian
- 68 Fedora
- 22 Linux Mint
- 13 Mageia
- 24 openSUSE
- 150 Red Hat Enterprise
- 31 Slackware
- 13 SUSE Enterprise
- 356 Ubuntu
- 465 Linux System Administration
- 31 Cloud Computing
- 73 Command Line/Scripting
- Github systems admin projects
- 98 Linux Security
- 78 Network Management
- 101 System Management
- 46 Web Management
- 111 Mobile Computing
- 19 Android
- 77 Development
- 1.2K New to Linux
- 1K Getting Started with Linux
- 393 Off Topic
- 121 Introductions
- 182 Small Talk
- 29 Study Material
- 976 Programming and Development
- 310 Kernel Development
- 648 Software Development
- 990 Software
- 382 Applications
- 182 Command Line
- 5 Compiling/Installing
- 68 Games
- 317 Installation
- Archived
- 2 LFD140 Class Forum
- 1.4K LFS258 Class Forum
Upcoming Training
-
August 20, 2018
Kubernetes Administration (LFS458)
-
August 20, 2018
Linux System Administration (LFS301)
-
August 27, 2018
Open Source Virtualization (LFS462)
-
August 27, 2018
Linux Kernel Debugging and Security (LFD440)

