mirror of
https://git.savannah.gnu.org/git/parallel.git
synced 2024-12-29 08:07:54 +00:00
770 lines
27 KiB
Bash
770 lines
27 KiB
Bash
#!/bin/bash
|
|
|
|
# SPDX-FileCopyrightText: 2002-2024 Ole Tange, http://ole.tange.dk and Free Software and Foundation, Inc.
|
|
#
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
install_packages() {
|
|
# After first run, set this:
|
|
# export INSTALL=echo
|
|
INSTALL=${INSTALL:-"sudo apt -y install"}
|
|
|
|
# The testsuite depends on this:
|
|
test_pkgs="imagemagick expect pv zenity"
|
|
test_pkgs="$test_pkgs autossh sshpass lsh-client lsh-utils jq"
|
|
test_pkgs="$test_pkgs libpod-simple-perl libtext-csv-perl"
|
|
test_pkgs="$test_pkgs libtest-nowarnings-perl pod2pdf"
|
|
test_pkgs="$test_pkgs xemacs21"
|
|
test_pkgs="$test_pkgs gawk lua5.3 clisp php-cli nodejs guile-3.0 fsharp"
|
|
test_pkgs="$test_pkgs mono-csharp-shell octave openjdk-11-jdk-headless tcl"
|
|
test_pkgs="$test_pkgs racket libevent-dev python-is-python3"
|
|
test_pkgs="$test_pkgs xterm libc6-i386 libcrypt1:i386 virtualbox"
|
|
test_pkgs="$test_pkgs torsocks net-tools"
|
|
test_pkgs="$test_pkgs reiserfsprogs btrfs-progs exfatprogs f2fs-tools"
|
|
test_pkgs="$test_pkgs xfsprogs"
|
|
|
|
test_snap_pkgs="groovy julia"
|
|
|
|
# Debian package
|
|
packaging_pkgs="dpkg-dev build-essential debhelper osc cvs automake"
|
|
packaging_pkgs="$packaging_pkgs python3-m2crypto alien python3-pip"
|
|
|
|
# Shebang Tools
|
|
shebang_pkgs="gnuplot octave ruby r-base-core"
|
|
|
|
# SQL Tools
|
|
sql_pkgs="libdbd-pg-perl libdbd-sqlite3-perl libdbd-csv-perl"
|
|
sql_pkgs="$sql_pkgs libdbd-mysql-perl rlwrap"
|
|
|
|
# Compression
|
|
compression_pkgs="zstd clzip lz4 lzop pigz pixz gzip plzip pbzip2"
|
|
compression_pkgs="$compression_pkgs lzma xz-utils lzip bzip2 lbzip2 lrzip"
|
|
compression_pkgs_missing="pxz"
|
|
|
|
# Shells
|
|
# (csh = bsd-csh that is broken)
|
|
# (ash ksh93 gone)
|
|
shell_pkgs="dash fdclone fish fizsh ksh ksh93u+m mksh posh rc rush sash"
|
|
shell_pkgs="$shell_pkgs tcsh yash zsh busybox-static"
|
|
|
|
# Databases
|
|
database_pkgs="postgresql mysql-server influxdb influxdb-client"
|
|
|
|
# Build Tools
|
|
build_pkgs="bison libxxhash-dev libzstd-dev liblz4-dev libssl-dev"
|
|
build_pkgs="$build_pkgs python3-cmarkgfm libpod-pom-view-restructured-perl"
|
|
build_pkgs="$build_pkgs graphviz yodl libreoffice"
|
|
|
|
# Alternatives
|
|
alt_database="sqlite sqlite3"
|
|
sudo dpkg --add-architecture i386; sudo apt update
|
|
if $INSTALL $test_pkgs $packaging_pkgs $shebang_pkgs $sql_pkgs \
|
|
$compression_pkgs $shell_pkgs $database_pkgs $build_pkgs ; then
|
|
# OK
|
|
true
|
|
else
|
|
echo Packages missing
|
|
return 1
|
|
fi
|
|
if sudo parallel -j1 snap install --classic ::: $test_snap_pkgs; then
|
|
# OK
|
|
true
|
|
else
|
|
echo Packages missing: $test_snap_pkgs
|
|
return 1
|
|
fi
|
|
if parallel -j1 --tag --halt now,success=1 $INSTALL ::: $alt_database ; then
|
|
# OK
|
|
true
|
|
else
|
|
echo Cannot install: "$alt_database"
|
|
return 1
|
|
fi
|
|
if \vagrant --help >/dev/null ; then
|
|
# OK
|
|
true
|
|
else
|
|
# Version 2.3.7 is the last under a free license
|
|
wget -m https://releases.hashicorp.com/vagrant/2.3.7/vagrant_2.3.7-1_amd64.deb
|
|
sudo dpkg -i releases.hashicorp.com/vagrant/2.3.7/vagrant_2.3.7-1_amd64.deb
|
|
fi
|
|
sudo apt install python3-sphinx-rtd-theme || pip install sphinx-rtd-theme
|
|
echo zh_HK BIG5-HKSCS | sudo tee -a /etc/locale.gen
|
|
sudo locale-gen zh_HK
|
|
sudo apt update &
|
|
}
|
|
|
|
install_sqlite2() {
|
|
mkdir /tmp/sqlite2
|
|
cd /tmp/sqlite2
|
|
git clone https://github.com/sqlite/sqlite
|
|
cd sqlite
|
|
git checkout cc83b6e071ba69943f175a038d2625ae3d6abf47
|
|
# New GCC needs <stdlib.h>, so add that
|
|
perl -i -pe \
|
|
's/echo (.#include <stdio.h>)(.)/printf $1\\n#include <stdlib.h>\\n$2/' \
|
|
Makefile.in
|
|
./configure --prefix=/usr/local && make -j && sudo make install
|
|
}
|
|
|
|
install_oracle_client() {
|
|
# https://salsa.debian.org/perl-team/modules/packages/libdbd-oracle-perl/blob/master/debian/README.Debian
|
|
# sql oracle:// && return 0
|
|
(cd /tmp
|
|
|
|
get_rpm_install_deb() {
|
|
glob="$1"
|
|
url="$oracleurl/$2"
|
|
testglob="$3"
|
|
if [ ! -e `echo $glob*rpm` ] ; then
|
|
wget $url
|
|
fi
|
|
if [ ! -e `echo $glob*deb` ] ; then
|
|
echo Convert `echo $glob*rpm` to deb
|
|
fakeroot alien `echo $glob*rpm`
|
|
fi
|
|
if [ ! -e `echo $testglob` ] ; then
|
|
echo Install `echo $glob*deb`
|
|
sudo dpkg -i `echo $glob*deb`
|
|
fi
|
|
}
|
|
|
|
oracleurl=https://download.oracle.com/otn_software/linux/instantclient/19600
|
|
client=oracle-instantclient19.6
|
|
ver=19.6.0.0.0-1.x86_64.rpm
|
|
get_rpm_install_deb 'oracle-instantclient*devel' $client-devel-$ver /usr/share/doc/oracle-instantclient*-devel/copyright
|
|
get_rpm_install_deb 'oracle-instantclient*basic' $client-basic-$ver /usr/share/oracle/*/client*/doc/BASIC_README
|
|
get_rpm_install_deb 'oracle-instantclient*sqlplus' $client-sqlplus-$ver /usr/lib/oracle/*/client*/bin/sqlplus
|
|
)
|
|
|
|
echo Add this to .bashrc:
|
|
ORACLE_HOME=`echo /usr/lib/oracle/*/client*`
|
|
echo ORACLE_HOME=$ORACLE_HOME
|
|
if grep -q ORACLE_HOME=/ ~/.bashrc; then
|
|
perl -i.old -pe "s:ORACLE_HOME=/.*:ORACLE_HOME=$ORACLE_HOME:" ~/.bashrc
|
|
else
|
|
echo ORACLE_HOME=$ORACLE_HOME >> ~/.bashrc
|
|
echo 'PATH=$PATH:$ORACLE_HOME/bin' >> ~/.bashrc
|
|
echo 'export ORACLE_HOME' >> ~/.bashrc
|
|
echo 'export ORACLE_SID=XE' >> ~/.bashrc
|
|
fi
|
|
# libaio
|
|
sudo apt install libaio1 || sudo apt install libaio1t64
|
|
sudo ln -s libaio.so.1t64 /usr/lib/x86_64-linux-gnu/libaio.so.1
|
|
perl -MCPAN -e 'install DBD::Oracle'
|
|
# TODO set up vagrant oracle server
|
|
git clone https://github.com/oracle/vagrant-projects.git
|
|
(
|
|
cd vagrant-projects/OracleDatabase/23.4.0-Free
|
|
echo export VM_ORACLE_PWD=`goodpasswd` >> ~/.passwords
|
|
echo export 'ORACLE_PWD=$VM_ORACLE_PWD' >> ~/.passwords
|
|
. ~/.passwords
|
|
vagrant up
|
|
)
|
|
# test it works:
|
|
sql --showtables oracle://SYSTEM:$VM_ORACLE_PWD@/FREE
|
|
}
|
|
|
|
setup_databases() {
|
|
# DATABASES
|
|
setup_postgres() {
|
|
echo '# Create PostgreSQL'
|
|
(echo; echo "listen_addresses = '*'") |
|
|
sudo tee -a /etc/postgresql/*/main/postgresql.conf
|
|
sudo service postgresql restart
|
|
|
|
# Drop database and user if needed
|
|
sudo su - postgres -c 'dropdb '$(whoami)
|
|
sudo su - postgres -c 'dropuser '$(whoami)
|
|
sudo su - postgres -c 'createdb '$(whoami)
|
|
sudo su - postgres -c 'createuser '$(whoami)
|
|
sudo su - postgres -c "sql pg:/// \"ALTER USER \\\"`whoami`\\\" WITH PASSWORD '$(whoami)';\""
|
|
sudo su - postgres -c "psql -d $(whoami) -c 'GRANT CREATE ON SCHEMA public TO \"$(whoami)\";'"
|
|
sql pg://// 'create table __test_foo_socket(i int)'
|
|
sql pg://$me:$me@// 'create table __test_foo(i int)'
|
|
sql pg://// 'drop table __test_foo_socket' &&
|
|
sql pg://$me:$me@// 'drop table __test_foo' &&
|
|
echo OK: PostgreSQL
|
|
}
|
|
|
|
setup_mysql() {
|
|
mysqlrootpass=${mysqlrootpass:-b+Ydjq4ejT4E}
|
|
dburl=mysql://root:"$mysqlrootpass"@/mysql
|
|
me=$(whoami)
|
|
echo '# Create MySQL'
|
|
sudo su mysql mysqladmin create $me
|
|
# Default Debian way of getting "root" access
|
|
sudo mysql --defaults-file=/etc/mysql/debian.cnf mysql <<< "ALTER USER 'root'@'localhost' IDENTIFIED BY '$mysqlrootpass';"
|
|
|
|
# Drop database and user if needed
|
|
sudo sql "$dburl" "DROP DATABASE $me;DROP USER '$me'@'localhost';"
|
|
sudo sql "$dburl" "CREATE DATABASE $me;"
|
|
sudo sql "$dburl" "CREATE USER '$me'@'localhost' IDENTIFIED WITH auth_socket;"
|
|
sudo sql "$dburl" "ALTER USER '$me'@'localhost' IDENTIFIED BY '$me';"
|
|
sudo sql "$dburl" "GRANT ALL PRIVILEGES ON $me.* TO '$me'@'localhost';"
|
|
sudo sql "$dburl" "FLUSH PRIVILEGES;"
|
|
|
|
|
|
# Drop database and user if needed
|
|
sql mysql://// 'create table __test_foo_socket(i int)'
|
|
sql mysql://$me:$me@// 'create table __test_foo(i int)'
|
|
sql mysql://// 'drop table __test_foo_socket' &&
|
|
sql mysql://$me:$me@// 'drop table __test_foo' &&
|
|
echo OK: MySQL
|
|
}
|
|
setup_postgres &&
|
|
setup_mysql
|
|
}
|
|
|
|
setup_virtual_box_network() {
|
|
echo "Adding IP-range to virtualbox"
|
|
sudo mkdir -p /etc/vbox
|
|
sudo touch /etc/vbox/networks.conf
|
|
(cat; echo '* 172.27.27.0/24') < /etc/vbox/networks.conf | uniq |
|
|
sudo tee /etc/vbox/networks.conf
|
|
}
|
|
|
|
add_server_to_hosts() {
|
|
add_ssh_key_to_authorized() {
|
|
(cat vagrant/authorized_keys; cat ~/.ssh/*.pub) |
|
|
uniq > vagrant/authorized_keys.$$
|
|
mv vagrant/authorized_keys.$$ vagrant/authorized_keys
|
|
# Problem:
|
|
# https://developer.hashicorp.com/vagrant/docs/v2.4.0/vagrantfile/ssh_settings
|
|
# says:
|
|
#
|
|
# (non-interactive SSH connections use the internal SSH
|
|
# communicator which is unaffected by this setting).
|
|
#
|
|
# We need to force Ruby's Net::SSH to use ~/.ssh/config
|
|
# or -oKexAlgorithms=diffie-hellman-group1-sha1
|
|
#
|
|
# VAGRANT_PREFER_SYSTEM_BIN=1 ought to fix it, but does not.
|
|
|
|
|
|
# Fix:
|
|
# could not settle on kex algorithm
|
|
# Server kex preferences: diffie-hellman-group-exchange-sha1,diffie-hellman-group1-sha1
|
|
# Client kex preferences: ecdh-sha2-nistp521,ecdh-sha2-nistp384,ecdh-sha2-nistp256,diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha1>
|
|
#debug2: KEX algorithms: curve25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,sntrup761x25519-sha512@openssh.com,diffie-hellman-group-exchange-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512,diffie-hellman-group14-sha256,diffie-hellman-group1-sha1,ext-info-c
|
|
#debug2: host key algorithms: ssh-dss,ssh-ed25519-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp521-cert-v01@openssh.com,sk-ssh-ed25519-cert-v01@openssh.com,sk-ecdsa-sha2-nistp256-cert-v01@openssh.com,rsa-sha2-512-cert-v01@openssh.com,rsa-sha2-256-cert-v01@openssh.com,ssh-ed25519,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521,sk-ssh-ed25519@openssh.com,sk-ecdsa-sha2-nistp256@openssh.com,rsa-sha2-512,rsa-sha2-256
|
|
#debug2: ciphers ctos: aes128-ctr,aes192-ctr,aes256-ctr,aes256-cbc,aes192-cbc,aes128-cbc,3des-cbc
|
|
#debug2: ciphers stoc: aes128-ctr,aes192-ctr,aes256-ctr,aes256-cbc,aes192-cbc,aes128-cbc,3des-cbc
|
|
#debug2: MACs ctos: umac-64-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-sha2-512-etm@openssh.com,hmac-sha1-etm@openssh.com,umac-64@openssh.com,umac-128@openssh.com,hmac-sha2-256,hmac-sha2-512,hmac-sha1
|
|
#debug2: MACs stoc: umac-64-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-sha2-512-etm@openssh.com,hmac-sha1-etm@openssh.com,umac-64@openssh.com,umac-128@openssh.com,hmac-sha2-256,hmac-sha2-512,hmac-sha1
|
|
#
|
|
|
|
# Fix: .ssh/config
|
|
#Host centos3 127.0.0.1
|
|
# KexAlgorithms +diffie-hellman-group1-sha1
|
|
# Ciphers +3des-cbc,aes128-cbc,aes192-cbc,aes256-cbc
|
|
# HostKeyAlgorithms +ssh-rsa,ssh-dss
|
|
# sshpass -p vagrant ssh -v -p 50136 vagrant@127.0.0.1
|
|
}
|
|
|
|
insert_in_etc_hosts() {
|
|
ip=$1
|
|
host=$2
|
|
if grep -q $1 /etc/hosts && grep -q $2 /etc/hosts ; then
|
|
# skip
|
|
true
|
|
else
|
|
echo "$@" |
|
|
sudo tee -a /etc/hosts
|
|
fi
|
|
}
|
|
export -f insert_in_etc_hosts
|
|
add_single_vagrant_to_etc_hosts() {
|
|
vagrant_ip() {
|
|
cd vagrant/*/$1
|
|
# .vagrant can contain dirt
|
|
rm -rf .vagrant
|
|
grep 172 Vagrantfile | grep -v '#' |
|
|
perl -pe 's/.*(172.27[\.0-9]+).*/$1/';
|
|
}
|
|
insert_in_etc_hosts $(vagrant_ip $1) "$@"
|
|
}
|
|
export -f add_single_vagrant_to_etc_hosts
|
|
|
|
add_ssh_key_to_authorized
|
|
insert_in_etc_hosts 127.1.2.3 server
|
|
|
|
insert_in_etc_hosts 127.0.0.2 lo
|
|
parallel add_single_vagrant_to_etc_hosts {} parallel-server{#} ::: centos9 freebsd13 freebsd14 rhel8 centos3
|
|
}
|
|
|
|
vagrant_up() {
|
|
parallel -j0 --ll --tag 'cd {//};vagrant up' ::: vagrant/*/*/Vagrantfile
|
|
# After this you should be able to 'vagrant ssh'
|
|
}
|
|
|
|
vagrant_centos3() {
|
|
echo 'Centos3 can only use an RSA key'
|
|
if [ -e ~/.ssh/id_rsa ] ; then
|
|
# OK
|
|
true
|
|
else
|
|
ssh-keygen -P '' -t rsa -f ~/.ssh/id_rsa
|
|
fi
|
|
cat ~/.ssh/id_rsa.pub >> vagrant/authorized_keys
|
|
(
|
|
# Centos3 only works with some weak ciphers
|
|
echo
|
|
echo 'Host *'
|
|
echo ' GSSAPIAuthentication no'
|
|
echo ' KexAlgorithms +diffie-hellman-group1-sha1'
|
|
echo ' Ciphers +3des-cbc,aes128-cbc,aes192-cbc,aes256-cbc'
|
|
echo ' HostKeyAlgorithms +ssh-rsa,ssh-dss'
|
|
echo ' PubkeyAcceptedKeyTypes +ssh-rsa,ssh-dss'
|
|
|
|
) >> ~/.ssh/config
|
|
(
|
|
echo KexAlgorithms +diffie-hellman-group1-sha1,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha1
|
|
echo Ciphers +3des-cbc,aes128-cbc,aes192-cbc,aes256-cbc,aes128-ctr,aes192-ctr,aes256-ctr,aes128-gcm@openssh.com,aes256-gcm@openssh.com,chacha20-poly1305@openssh.com
|
|
echo HostKeyAlgorithms +ssh-rsa,ssh-dss
|
|
echo PubkeyAcceptedKeyTypes +ssh-rsa,ssh-dss
|
|
echo MaxStartups 100:30:1000
|
|
) | sudo tee /etc/ssh/sshd_config.d/parallel.conf
|
|
sudo /etc/init.d/ssh restart
|
|
(
|
|
cd vagrant/*/centos3 && vagrant up
|
|
(cat ../../authorized_keys | vagrant ssh -c "cat >>.ssh/authorized_keys";
|
|
vagrant ssh -c "sudo /sbin/ifconfig eth1 172.27.27.3")
|
|
ssh-keygen -R centos3
|
|
stdout wssh -oStrictHostKeyChecking=accept-new vagrant@centos3 echo OK: ssh centos3 started and works
|
|
stdout ssh parallel@lo 'cat .ssh/id*pub' |
|
|
ssh vagrant@centos3 "cat >>.ssh/authorized_keys"
|
|
ssh vagrant@centos3 'yes n | ssh-keygen -t rsa -f .ssh/id_rsa -N "";echo '
|
|
ssh vagrant@centos3 'cat .ssh/id*pub' |
|
|
stdout ssh parallel@lo "cat >>.ssh/authorized_keys"
|
|
ssh vagrant@centos3 ssh -oStrictHostKeyChecking=no parallel@172.27.27.1 echo OK: ssh vagrant@centos3 ssh parallel@172.27.27.1 works
|
|
)
|
|
}
|
|
|
|
add_key_to_auth_key() {
|
|
sshaddvagrant() {
|
|
ssh-keygen -f ~/.ssh/known_hosts -R $1
|
|
cat ~/.ssh/*.pub | (cd vagrant/*/$1 && vagrant ssh -c 'cat >>.ssh/authorized_keys')
|
|
sshpass -p vagrant ssh-copy-id -o StrictHostKeyChecking=accept-new vagrant@$1
|
|
ssh vagrant@$1 echo vagrant@$1 OK
|
|
}
|
|
export -f sshaddvagrant
|
|
sshaddlocal() {
|
|
ssh-keygen -f ~/.ssh/known_hosts -R $1
|
|
ssh-copy-id -o StrictHostKeyChecking=accept-new $1
|
|
ssh $1 echo $1 OK
|
|
}
|
|
export -f sshaddlocal
|
|
ipv6() {
|
|
ifconfig | perl -nE '/inet6 ([0-9a-f:]+) .*(host|global)/ and say $1'
|
|
}
|
|
vagrant_names=$(ls vagrant/*/*/Vagrantfile| perl -pe 's:.*/(.*)/Vagrantfile:$1:')
|
|
ipv6=$(ipv6)
|
|
ips="172.27.27.1 127.0.0.1 ::1 $ipv6"
|
|
|
|
cat ~/.ssh/*pub >> ~/.ssh/authorized_keys
|
|
parallel --tag --timeout 20 sshaddvagrant ::: $vagrant_names parallel-server{1..4}
|
|
parallel --tag --timeout 20 sshaddlocal ::: $ips lo localhost
|
|
parallel --tag --timeout 5 ssh vagrant@{} echo ssh vagrant@{} OK ::: $vagrant_names parallel-server{1..4}
|
|
parallel ssh vagrant@{} 'echo "PATH=\$PATH:\$HOME/bin" >> .bashrc' ::: $vagrant_names
|
|
parallel --tag --timeout 5 ssh {} echo ssh {} OK ::: $ips lo localhost
|
|
}
|
|
|
|
install_rsync_on_vagrant() {
|
|
parallel --tag ssh vagrant@{} "'
|
|
sudo apt install rsync || sudo yum install -y rsync || sudo pkg install -y rsync;
|
|
sudo apt install perl || sudo yum install -y perl || sudo pkg install -y perl;
|
|
'" ::: parallel-server{1..4} centos3
|
|
}
|
|
|
|
shellsplus() {
|
|
shells="bash sh csh ash dash tcsh zsh ksh ksh93 fish fizsh mksh"
|
|
shells="$shells posh rc sash yash nopathbash nopathcsh"
|
|
shellsplus="parallel $shells"
|
|
parallel -k echo ::: $shellsplus
|
|
}
|
|
|
|
create_shell_logins() {
|
|
# SHELLS
|
|
echo '# Create shell logins'
|
|
touch ~/.zshrc
|
|
del_add_user() {
|
|
shell="$1"
|
|
append-if-not-exists() {
|
|
file="$1"
|
|
shift
|
|
string="$@"
|
|
if grep -qF "$string" "$file"; then
|
|
# It is there already
|
|
echo "$string is already in $file"
|
|
else
|
|
echo "$string" | sudo tee -a "$file"
|
|
fi
|
|
}
|
|
SSHPASS=`goodpasswd`
|
|
export SSHPASS
|
|
append-if-not-exists /etc/shells $(which $shell ||
|
|
which ${shell#"nopath"})
|
|
sudo killall -u $shell
|
|
sudo deluser $shell && sudo mv /home/$shell /tmp/$shell.$RANDOM
|
|
sudo groupdel $shell
|
|
if echo $shell | grep -qE "parallel|withpassword"; then
|
|
# User parallel+withpassword should have /bin/bash
|
|
loginshell=/bin/bash
|
|
else
|
|
# Other users should have `which $shell` with nopath removed
|
|
loginshell=$(which $shell || which ${shell#"nopath"})
|
|
fi
|
|
sudo adduser --shell $loginshell --disabled-password --gecos "$shell for parallel,,," $shell &&
|
|
echo "$shell:$SSHPASS" | sudo chpasswd &&
|
|
sshpass -e ssh-copy-id $shell@lo &&
|
|
echo "$shell created"
|
|
}
|
|
export -f del_add_user
|
|
|
|
echo '# (Re-)create user'
|
|
# Racecondition: if multiple adds a group it will the same group ID
|
|
(shellsplus; echo withpassword) |
|
|
parallel --lb --halt soon,fail=1 --timeout 1000% --retries 5 --tag -j1 del_add_user ||
|
|
(echo Creation failed: $?; false)
|
|
# Homedir must be readable by others
|
|
umask 0002
|
|
(shellsplus; echo withpassword) | sudo parallel chmod +rX ~{}
|
|
}
|
|
|
|
copy_ssh_keys() {
|
|
make_sshkey() {
|
|
shell="$1"
|
|
echo Add server keys for lo and server &&
|
|
ssh $shell@lo 'rm -f .ssh/id_rsa;
|
|
ssh-keyscan lo >>.ssh/known_hosts;
|
|
ssh-keyscan server >> .ssh/known_hosts' &&
|
|
echo Do ssh-keygen &&
|
|
echo | ssh -t $shell@lo ssh-keygen -b 1024 -f .ssh/id_rsa &&
|
|
echo Do ssh $shell@lo 'cat .ssh/id_rsa.pub >> .ssh/authorized_keys' &&
|
|
ssh $shell@lo 'cat .ssh/id_rsa.pub | tee -a .ssh/authorized_keys' |
|
|
ssh parallel@lo 'cat >> .ssh/authorized_keys' &&
|
|
ssh $shell@lo "echo ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAxg+dh+BL1myqo6A+pHcQCKVV5v7cewdkN8xGtMDqm7xGgh+e5A44W7qKViIx641d6yoWb012XzDz2MKetG4Kosoma8Z/qkS27p6901RmI3ap2JFffzBESlpQtW1FyxQPlMyBfrd4ONy8xW6R/gEkjC3yOcXCQO2494/c46ouXs5gtE84Cusr3RsopR4bI7oloH1GQZ4vsHSFSakq8IwcujaSh1mmribMONLb2TjDpmE7tAY+yfOVWHPQ2J+EU1//Go60EZfSRKOu81oxW7SJ2uGgWfWcs2T1lRtT8Yh+TwVTz8UFV75kVtpZ10x5baN+ncsSpaBK+8sFLfoMvA9yQQ'==' tange@freebsd71.tange.dk >> .ssh/authorized_keys" &&
|
|
echo Do env_parallel --install &&
|
|
ssh $shell@lo 'mkdir -p .parallel;
|
|
touch .parallel/will-cite;
|
|
env_parallel --install' &&
|
|
echo OK make_sshkey $shell &&
|
|
echo >&2 &&
|
|
echo OK make_sshkey $shell >&2 &&
|
|
echo
|
|
}
|
|
export -f make_sshkey
|
|
|
|
echo '# Make and copy sshkey'
|
|
shellsplus | parallel --timeout 20 --retries 5 --tag -j5 make_sshkey
|
|
|
|
ssh_a_to_b() {
|
|
ssh $1@lo ssh $2@lo echo OK ||
|
|
(echo failed && false)
|
|
}
|
|
export -f ssh_a_to_b
|
|
echo "# copy id from X to X"
|
|
shellsplus | parallel --timeout 10 --tag ssh_a_to_b {} {}
|
|
|
|
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
|
|
|
|
echo '# copy id from any X to any Y'
|
|
parallel --bar -j3 --timeout 7 --retries 10 --tag \
|
|
ssh_copy_id {1}@lo {2}@lo ::: $(shellsplus) ::: $(shellsplus)
|
|
echo '# Test the copying went well'
|
|
parallel --bar -j2 --timeout 9 --retries 10 --tag \
|
|
ssh_a_to_b ::: $(shellsplus) ::: $(shellsplus)
|
|
|
|
echo '# change paths to no path'
|
|
(
|
|
ssh nopathbash@lo 'echo > .bashrc PATH=/bin:/usr/bin'
|
|
ssh nopathbash@lo 'echo > .profile 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 nopathcsh@lo 'echo >> .tcshrc setenv PATH /bin:/usr/bin'
|
|
ssh nopathcsh@lo 'echo >> .login setenv PATH /bin:/usr/bin'
|
|
ssh nopathbash@lo 'echo $PATH; echo NOT OK | parallel echo' ||
|
|
echo Great - this should FAIL: parallel should not be found
|
|
ssh nopathcsh@lo 'echo $PATH; echo NOT OK | parallel echo' ||
|
|
echo Great - this should FAIL: parallel should not be found
|
|
)
|
|
}
|
|
|
|
parallel_versions() {
|
|
install_version() {
|
|
rm -r /tmp/parallel-$1
|
|
(git clone . /tmp/parallel-$1 || git clone .. /tmp/parallel-$1) &&
|
|
cd /tmp/parallel-$1 &&
|
|
git checkout $1 &&
|
|
sudo cp src/parallel /usr/local/bin/parallel-$1
|
|
}
|
|
export -f install_version
|
|
git tag | grep -E '^20[0-9][0-9][0-9][0-9][0-9][0-9]$' | parallel install_version
|
|
}
|
|
|
|
lsh_setup() {
|
|
server=centos3
|
|
user=vagrant
|
|
ssh-keyscan $server >>~/.ssh/known_hosts
|
|
ssh-copy-id $user@$server
|
|
|
|
# SHELLS: lsh-client against openssh server
|
|
$INSTALL lsh-client
|
|
(
|
|
cd
|
|
mkdir -p .lsh
|
|
rm -f ".lsh/yarrow-seed-file"
|
|
lsh-make-seed -o ".lsh/yarrow-seed-file"
|
|
# TODO need to enter 'y' here
|
|
lsh --sloppy-host-authentication \
|
|
--capture-to ~/.lsh/host-acls -l $user $server echo Added host-auth
|
|
rm -f .lsh/identity .lsh/identity.pub
|
|
lsh-keygen | lsh-writekey -c none
|
|
export_key_to_local_users() {
|
|
lsh-export-key --openssh < ~/.lsh/identity.pub |
|
|
ssh -l $1 $2 'cat >>.ssh/authorized_keys'
|
|
}
|
|
export -f export_key_to_local_users
|
|
# lsh: Protocol error: No common key exchange method.
|
|
# It seems
|
|
# $ lsh --list-algorithms
|
|
# Supported hostkey algorithms: ssh-dss, spki, none
|
|
#
|
|
# $ nmap --script ssh2-enum-algos -sV -p 22 lo
|
|
# | server_host_key_algorithms: (4)
|
|
# | rsa-sha2-512
|
|
# | rsa-sha2-256
|
|
# | ecdsa-sha2-nistp256
|
|
# | ssh-ed25519
|
|
# |
|
|
#
|
|
export_key_to_local_users $user $server
|
|
)
|
|
lsh -l $user $server echo lsh $user $server OK
|
|
}
|
|
|
|
add_freebsd() {
|
|
echo "# Add public keys to old servers"
|
|
# freebsd7 is no longer supported as virtualbox
|
|
# ssh freebsd7 cat .ssh/id_rsa.pub |
|
|
# ssh parallel@localhost 'cat >>.ssh/authorized_keys'
|
|
|
|
echo Add:
|
|
echo HostkeyAlgorithms +ssh-dss
|
|
echo to .ssh/config if you get
|
|
echo no matching host key type found. Their offer: ssh-dss
|
|
echo
|
|
echo Add to /etc/ssh/sshd_config
|
|
echo Ciphers aes128-ctr,aes192-ctr,aes256-ctr,aes256-cbc,aes192-cbc,aes128-cbc,3des-cbc
|
|
echo KexAlgorithms diffie-hellman-group-exchange-sha256,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,curve25519-sha256@libssh.org,diffie-hellman-group1-sha1,diffie-hellman-group14-sha1,diffie-hellman-group-exchange-sha1
|
|
echo
|
|
echo If you get:
|
|
echo Unable to negotiate with server port 22: no matching cipher found.
|
|
echo Their offer: aes128-cbc,3des-cbc,blowfish-cbc,cast128-cbc,arcfour,aes192-cbc,aes256-cbc,rijndael-cbc@lysator.liu.se
|
|
echo add this to .ssh/config
|
|
echo Ciphers +aes256-cbc
|
|
}
|
|
|
|
tmux_versions() {
|
|
(cd /tmp
|
|
git clone https://github.com/tmux/tmux.git
|
|
listtags() {
|
|
(cd tmux;
|
|
git tag)
|
|
}
|
|
make_one() {
|
|
rsync -a --delete tmux/ tmux$1/
|
|
cd tmux$1
|
|
git reset --hard
|
|
git checkout $1
|
|
bash ./autogen.sh;
|
|
./configure &&
|
|
make -j2 &&
|
|
sudo cp tmux /usr/local/bin/tmux-$1
|
|
}
|
|
export -f make_one
|
|
echo '# Building tmux'
|
|
listtags |
|
|
stdout parallel --lb --tag '/usr/local/bin/tmux-{} -V || make_one {}'
|
|
listtags |
|
|
parallel -k -v /usr/local/bin/tmux-{} -V
|
|
)
|
|
}
|
|
|
|
bash_versions() {
|
|
echo You may have to kill conftest
|
|
(cd /tmp
|
|
git clone https://git.savannah.gnu.org/git/bash.git
|
|
listtags() {
|
|
(cd bash;
|
|
git tag | grep -v -- '-.*-' | grep -v bash-4.1.11)
|
|
}
|
|
make_one() {
|
|
rsync -a --delete bash/ $1/
|
|
cd $1
|
|
git reset --hard
|
|
git checkout $1
|
|
LDFLAGS=-static ./configure &&
|
|
make -j2 &&
|
|
sudo cp bash /usr/local/bin/$1
|
|
}
|
|
export -f make_one
|
|
echo '# Building bash'
|
|
listtags |
|
|
stdout parallel --lb --tag \
|
|
'/usr/local/bin/{} --version || make_one {}'
|
|
listtags |
|
|
parallel -k -v --tag '/usr/local/bin/{} --version'
|
|
)
|
|
}
|
|
|
|
rsync_versions() {
|
|
(cd /tmp
|
|
git clone https://github.com/WayneD/rsync
|
|
listtags() {
|
|
(cd rsync;
|
|
git tag | grep -v -- '-.*-' | grep -v pre)
|
|
}
|
|
make_one() {
|
|
configure_make_install() {
|
|
./configure && make -j2 &&
|
|
sudo cp rsync /usr/local/bin/rsync-$1
|
|
}
|
|
configure_make_proto_install() {
|
|
./configure && make proto && make -j2 &&
|
|
sudo cp rsync /usr/local/bin/rsync-$1
|
|
}
|
|
edit_configure.in() {
|
|
perl -i.bak -pe '
|
|
$printed++ || print "AC_DEFINE([HAVE_LONGLONG], [], [long long support])\n",
|
|
"AC_DEFINE([HAVE_UTIMBUF], [], [utimbuf is available])\n",
|
|
"AC_DEFINE([HAVE_FNMATCH], [], [dummy])\n";
|
|
s/AC_DEFINE_UNQUOTED.HAVE_REMSH, .HAVE_REMSH.*/AC_DEFINE_UNQUOTED(HAVE_REMSH, \$HAVE_REMSH,[dummy])/;
|
|
s/AC_DEFINE.HAVE_ERRNO_DECL.,/AC_DEFINE(HAVE_ERRNO_DECL,[1],[dummy]),/;
|
|
s/AC_CHECK_FUNC\((.*), , AC_LIBOBJ\((.*)\)\)/AC_CHECK_FUNC($1, , [AC_LIBOBJ($2)])/;
|
|
s/AC_CHECK_FUNCS\((.*), , AC_LIBOBJ\((.*)\)\)/AC_CHECK_FUNCS($1, , [AC_LIBOBJ($2)])/;
|
|
s/AC_DEFINE.HAVE_FNMATCH.,/AC_DEFINE(HAVE_FNMATCH,[1],[dummy]),/;' configure.in
|
|
}
|
|
build-older() {
|
|
# rsync-mbp_bk_export0 rsync-v1.6.4 rsync-v1.6.5
|
|
# rsync-v1.6.6 rsync-v1.6.7 rsync-v1.6.8 rsync-v1.6.9
|
|
# rsync-v1.7.0 rsync-v1.7.1 rsync-v1.7.2 rsync-v1.7.3
|
|
# rsync-v1.7.4 rsync-v2.0.0 rsync-v2.0.1 rsync-v2.0.2
|
|
# rsync-v2.0.3 rsync-v2.0.4 rsync-v2.0.5 rsync-v2.0.6
|
|
# rsync-v2.0.7 rsync-v2.0.8 rsync-v2.0.9 rsync-v2.0.10
|
|
# rsync-v2.0.11 rsync-v2.0.12 rsync-v2.0.13 rsync-v2.0.14
|
|
# rsync-v2.0.15 rsync-v2.0.16 rsync-v2.0.17 rsync-v2.0.18
|
|
# rsync-v2.0.19 rsync-v2.1.0 rsync-v2.1.1 rsync-v2.2.0
|
|
# rsync-v2.2.1 rsync-v2.3.0 rsync-v2.3.1 rsync-v2.3.2
|
|
# rsync-v2.4.0 rsync-v2.4.1 rsync-v2.4.2 rsync-v2.4.3
|
|
# rsync-v2.4.4 rsync-v2.4.5 rsync-v2.4.6 rsync-v2.5.1
|
|
# rsync-v2.5.2 rsync-v2.5.3 rsync-v2.5.4 rsync-v2.5.5
|
|
# rsync-v2.5.5.rc1 rsync-v2.5.6 rsync-v2.6.0 rsync-v2.6.1
|
|
# rsync-v2.6.2 rsync-v2.6.3 rsync-v2.6.4 rsync-v2.6.5
|
|
# rsync-v2.6.6 rsync-v2.6.7 rsync-v2.6.8 rsync-v2.6.9
|
|
edit_configure.in
|
|
mkdir -p lib
|
|
touch lib/addrinfo.h lib/getopt.h
|
|
autoreconf -fiv
|
|
# strlcat strlcpy
|
|
perl -i -pe 's/void (strlc..)/void _$1/' util.c
|
|
# Force FNM_CASEFOLD to be set
|
|
export CFLAGS='-Wno-incompatible-pointer-types -D_GNU_SOURCE=1'
|
|
configure_make_proto_install $1
|
|
}
|
|
build-v3.0.0() {
|
|
# rsync-v3.0.0 rsync-v3.0.1 rsync-v3.0.2 rsync-v3.0.3
|
|
# rsync-v3.0.4 rsync-v3.0.5 rsync-v3.0.6 rsync-v3.0.7
|
|
# rsync-v3.0.8 rsync-v3.0.9 rsync-v3.1.0 rsync-v3.1.1
|
|
# rsync-v3.1.2 rsync-v3.1.3 rsync-v3.2.0 rsync-v3.2.1
|
|
# rsync-v3.2.2 rsync-v3.2.3 rsync-v3.2.4 rsync-v3.2.5
|
|
# rsync-v3.2.6 rsync-v3.2.7 rsync-v3.3.0
|
|
configure_make_install $1
|
|
}
|
|
rsync -a --delete rsync/ rsync-$1/
|
|
cd rsync-$1
|
|
git reset --hard
|
|
git checkout $1
|
|
|
|
build-v3.0.0 $1 || build-older $1
|
|
}
|
|
export -f make_one
|
|
echo '# Building rsync'
|
|
listtags |
|
|
stdout parallel --lb --tag \
|
|
'/usr/local/bin/rsync-{} --version || make_one {}'
|
|
listtags |
|
|
parallel -k -v --tag '/usr/local/bin/rsync-{} --version'
|
|
)
|
|
}
|
|
|
|
install_tangetools() {
|
|
(
|
|
git clone https://git.data.coop/tange/tangetools
|
|
cd tangetools &&
|
|
make &&
|
|
sudo make install
|
|
)
|
|
}
|
|
|
|
misc() {
|
|
parallel --record-env
|
|
|
|
# Build locale for LC_ALL=zh_HK.big5hkscs perl -e 1
|
|
sudo locale-gen zh_HK
|
|
|
|
p=$(goodpasswd)
|
|
echo withpassword:$p | sudo chpasswd
|
|
echo "export withpassword=$p" >> ~/.passwords
|
|
|
|
|
|
echo TODO
|
|
echo ssh til egen IP-adresse 192.168.100.94 ipv6 addr
|
|
echo sshd_config
|
|
echo HostKeyAlgorithms +ssh-rsa
|
|
echo PubkeyAcceptedAlgorithms +ssh-rsa
|
|
echo KexAlgorithms +diffie-hellman-group1-sha1,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha1
|
|
echo Ciphers +3des-cbc,aes128-cbc,aes192-cbc,aes256-cbc,aes128-ctr,aes192-ctr,aes256-ctr,aes128-gcm@openssh.com,aes256-gcm@openssh.com,chacha20-poly1305@openssh.com
|
|
echo MaxStartups 100:30:1000
|
|
echo
|
|
echo strlncopy -> rsync
|
|
echo sqlite2
|
|
echo
|
|
echo 'set $withpassword'
|
|
echo 'set $mysqlrootpassword in .passwords'
|
|
echo '/usr/local/bin/parallel-20120822'
|
|
echo 'permission of ~shell/ must be +rx'
|
|
echo '~/.sql/aliases'
|
|
echo 'python install python-is-python3'
|
|
}
|
|
|
|
run() {
|
|
install_packages &&
|
|
install_tangetools &&
|
|
install_sqlite2 &&
|
|
(install_oracle_client; # 20240622 broken
|
|
true) &&
|
|
setup_databases &&
|
|
setup_virtual_box_network &&
|
|
add_server_to_hosts &&
|
|
vagrant_up &&
|
|
vagrant_centos3 &&
|
|
add_key_to_auth_key &&
|
|
create_shell_logins &&
|
|
copy_ssh_keys &&
|
|
lsh_setup &&
|
|
add_freebsd &&
|
|
parallel_versions &&
|
|
tmux_versions &&
|
|
bash_versions &&
|
|
rsync_versions &&
|
|
misc
|
|
}
|