mirror of
https://git.savannah.gnu.org/git/parallel.git
synced 2025-01-10 16:47:55 +00:00
105 lines
3.6 KiB
Bash
105 lines
3.6 KiB
Bash
#!/bin/bash
|
|
|
|
mysqlrootpass=${mysqlrootpass:+FoOo}
|
|
|
|
# The testsuite depends on this:
|
|
|
|
sudo aptitude install imagemagick expect autossh
|
|
|
|
# DEBIAN package
|
|
sudo aptitude install dpkg-dev build-essential debhelper
|
|
# SHEBANG TOOLS
|
|
sudo aptitude install gnuplot octave ruby r-base-core
|
|
# SQL TOOLS
|
|
sudo aptitude install libdbd-pg-perl libdbd-sqlite3-perl
|
|
# Compression
|
|
sudo aptitude install pxz pixz
|
|
|
|
# To configure zsh
|
|
echo Configure zsh and exit
|
|
zsh
|
|
|
|
# DATABASES
|
|
sudo aptitude install postgresql mysql-server
|
|
echo '# Create PostgreSQL'
|
|
sudo su - postgres -c 'createdb '`whoami`
|
|
sudo su - postgres -c 'createuser '`whoami`
|
|
sudo su - postgres -c "sql pg:/// \"ALTER USER \\\"`whoami`\\\" WITH PASSWORD '`whoami`';\""
|
|
|
|
echo '# Create MySQL'
|
|
sudo su - mysql mysqladmin create `whoami`
|
|
sql mysql://root:"$mysqlrootpass"@/mysql "DROP DATABASE `whoami`;DROP USER '`whoami`'@'localhost';"
|
|
sql mysql://root:"$mysqlrootpass"@/mysql "CREATE DATABASE `whoami`;CREATE USER '`whoami`'@'localhost' IDENTIFIED BY '`whoami`'; GRANT ALL ON `whoami`.* TO '`whoami`'@'localhost';"
|
|
|
|
# SHELLS
|
|
sudo aptitude install ash csh fdclone fish fizsh ksh mksh pdksh posh rush sash tcsh yash zsh
|
|
|
|
SSHPASS=`goodpasswd`
|
|
export SSHPASS
|
|
shells="bash sh csh ash tcsh zsh ksh fish fizsh mksh pdksh posh rc sash yash nopathbash nopathcsh"
|
|
create_shell_user() {
|
|
shell="$1"
|
|
sudo deluser $shell && sudo mv /home/$shell /tmp/$shell.$RANDOM
|
|
sudo groupdel $shell
|
|
sudo adduser --disabled-password --gecos "$shell for parallel,,," $shell &&
|
|
echo "$shell:$SSHPASS" | sudo chpasswd &&
|
|
sshpass -e ssh-copy-id $shell@lo &&
|
|
echo "ssh-keyscan" &&
|
|
ssh $shell@lo 'ssh-keyscan -t rsa lo >> .ssh/known_hosts' &&
|
|
ssh $shell@lo 'ssh-keyscan -t rsa server >> .ssh/known_hosts' &&
|
|
echo "chsh" &&
|
|
sudo chsh -s $(which $shell || which ${shell#"nopath"}) $shell &&
|
|
echo | ssh -t $shell@lo ssh-keygen &&
|
|
ssh $shell@lo 'cat .ssh/id_rsa.pub >> .ssh/authorized_keys' &&
|
|
ssh $shell@lo cat .ssh/id_rsa.pub | ssh parallel@lo 'cat >> .ssh/authorized_keys' &&
|
|
ssh $shell@lo env_parallel --install
|
|
}
|
|
export -f create_shell_user
|
|
parallel -u --timeout 15 --retries 2 --tag -j1 create_shell_user ::: $shells
|
|
# sh fails if not run by itself
|
|
parallel -u --timeout 15 --retries 2 --tag -j1 create_shell_user ::: sh
|
|
parallel -j10 ssh {}@lo ssh {}@lo echo {} OK ::: $shells
|
|
|
|
(
|
|
ssh parallel@lo 'ssh-keyscan -t rsa lo >> .ssh/known_hosts'
|
|
ssh parallel@lo 'cat .ssh/id_rsa.pub >> .ssh/authorized_keys'
|
|
)
|
|
ssh_copy_id() {
|
|
from="$1"
|
|
to="$2"
|
|
ssh $from cat .ssh/id_rsa.pub | ssh $to 'cat >> .ssh/authorized_keys'
|
|
}
|
|
export -f ssh_copy_id
|
|
shellsplus="parallel $shells"
|
|
parallel --bar -j200% --timeout 3 --retries 10 --tag ssh_copy_id {1}@lo {2}@lo ::: $shellsplus ::: $shellsplus
|
|
parallel -j10 --retries 3 --tag ssh {1}@lo ssh {2}@lo echo OK ::: $shellsplus ::: $shellsplus
|
|
|
|
# change paths to no path
|
|
(
|
|
ssh nopathbash@lo 'echo >> .bashrc PATH=/bin:/usr/bin'
|
|
# Remove env_parallel from .profile
|
|
ssh nopathbash@lo 'perl -i.bak -pe s/.*env_parallel.*// .profile .bashrc'
|
|
ssh nopathcsh@lo 'echo >> .cshrc setenv PATH /bin:/usr/bin'
|
|
ssh nopathbash@lo 'echo $PATH'
|
|
ssh nopathcsh@lo 'echo $PATH'
|
|
)
|
|
|
|
ssh-copy-id localhost
|
|
|
|
# SHELLS: lsh-client against openssh server
|
|
sudo aptitude install lsh-client
|
|
cd
|
|
mkdir .lsh
|
|
lsh-make-seed -o ".lsh/yarrow-seed-file"
|
|
lsh --sloppy-host-authentication --capture-to ~/.lsh/host-acls lo echo Added host-auth
|
|
lsh-keygen | lsh-writekey -c none
|
|
lsh-export-key --openssh < ~/.lsh/identity.pub | lsh localhost 'cat >>.ssh/authorized_keys'
|
|
lsh-export-key --openssh < ~/.lsh/identity.pub | ssh csh@localhost 'cat >>.ssh/authorized_keys'
|
|
|
|
|
|
parallel --record-env
|
|
|
|
|
|
sudo cp /usr/bin/tmux /usr/local/bin/tmux1.8
|
|
|