1000+ DevOps Bash Scripts - AWS, GCP, Kubernetes, Docker, CI/CD, APIs, SQL, PostgreSQL, MySQL, Hive, Impala, Kafka, Hadoop, Jenkins, GitHub, GitLab, BitBucket, Azure DevOps, TeamCity, Spotify, MP3, LDAP, Code/Build Linting, pkg mgmt for Linux, Mac, Python, Perl, Ruby, NodeJS, Golang, Advanced dotfiles: .bashrc, .vimrc, .gitconfig, .screenrc, tmux..
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Hari Sekhon 90377ddabc updated sync_to_repo.sh 5 years ago
.aws/shell added .aws/shell/awsshellrc 5 years ago
.bash.d updated aliases.sh 5 years ago
.circleci updated config.yml 5 years ago
.config added .config/pycodestyle 5 years ago
.git-templates/git-secrets/hooks added .git-templates 5 years ago
.github simplified github workflows 5 years ago
.sdkman/etc added .sdkman/etc/config 5 years ago
Library/Containers/net.sourceforge.cruisecontrol.CCMenu/Data/Library/Preferences reordered 5 years ago
lib updated cloudera_manager.sh 5 years ago
setup updated portage-packages-desktop.txt 5 years ago
sql renamed aws_athena_cloudtrail.sql to aws_athena_cloudtrail_ddl.sql 5 years ago
yamllint updated config 5 years ago
.Xdefaults added .Xdefaults 5 years ago
.Xmodmap added .Xmodmap 5 years ago
.ansible.cfg updated .ansible.cfg 5 years ago
.appveyor.yml updated .appveyor.yml 5 years ago
.bash_profile updated .bash_profile 5 years ago
.bashrc updated .bashrc 5 years ago
.cirrus.yml updated .cirrus.yml 5 years ago
.customize_environment updated .customize_environment 5 years ago
.drone.yml updated .drone.yml 5 years ago
.editorconfig merged older editconfig in 5 years ago
.gemrc added .gemrc 5 years ago
.gitconfig updated .gitconfig 5 years ago
.gitignore updated .gitignore 5 years ago
.gitlab-ci.yml updated .gitlab-ci.yml 5 years ago
.inputrc updated .inputrc 5 years ago
.mdlrc updated .mdlrc 5 years ago
.my.cnf added .my.cnf 5 years ago
.perlcritic_forbidden_modules added .perlcritic_forbidden_modules 5 years ago
.perlcriticrc updated .perlcriticrc 5 years ago
.pylintrc added .pylintrc 5 years ago
.sawsrc added .sawsrc 5 years ago
.screenrc updated .screenrc 5 years ago
.sonarcloud.properties updated .sonarcloud.properties 5 years ago
.tmux.conf updated .tmux.conf 5 years ago
.toprc updated .toprc 5 years ago
.travis.yml updated .travis.yml 5 years ago
.vimrc updated .vimrc 5 years ago
.zprofile added .zprofile 5 years ago
.zshrc updated .zshrc 5 years ago
DOCKER_STATUS.md updated DOCKER_STATUS.md 5 years ago
GIT_STATUS.md updated GIT_STATUS.md 5 years ago
LICENSE updated LICENSE 8 years ago
Makefile updated Makefile 5 years ago
Makefile.in updated Makefile.in 5 years ago
README.md updated README.md 5 years ago
STATUS.md updated STATUS.md 5 years ago
apk_install_packages.sh updated apk_install_packages.sh 5 years ago
apk_remove_packages.sh moved apk-remove-packages.sh to apk_remove_packages.sh 5 years ago
apt_install_packages.sh updated apt_install_packages.sh 5 years ago
apt_remove_packages.sh updated apt_remove_packages.sh 5 years ago
aws_account_summary.sh updated aws_account_summary.sh 5 years ago
aws_cloudtrails_cloudwatch.sh updated aws_cloudtrails_cloudwatch.sh 5 years ago
aws_cloudtrails_event_selectors.sh added aws_cloudtrails_event_selectors.sh 5 years ago
aws_cloudtrails_s3_accesslogging.sh updated aws_cloudtrails_s3_accesslogging.sh 5 years ago
aws_cloudtrails_s3_kms.sh updated aws_cloudtrails_s3_kms.sh 5 years ago
aws_cloudtrails_status.sh added aws_cloudtrails_status.sh 5 years ago
aws_config_all_types.sh added aws_config_all_types.sh 5 years ago
aws_config_recording.sh added aws_config_recording.sh 5 years ago
aws_harden_password_policy.sh added aws_harden_password_policy.sh 5 years ago
aws_iam_generate_credentials_report_wait.sh updated aws_iam_generate_credentials_report_wait.sh 5 years ago
aws_kms_key_rotation_enabled.sh renamed aws_kms_keys_rotation_enabled.sh to aws_kms_key_rotation_enabled.sh 5 years ago
aws_meta.sh updated aws_meta.sh 5 years ago
aws_password_policy.sh updated aws_password_policy.sh 5 years ago
aws_policies_attached_to_users.sh updated aws_policies_attached_to_users.sh 5 years ago
aws_policies_granting_full_access.sh updated aws_policies_granting_full_access.sh 5 years ago
aws_policies_unattached.sh updated aws_policies_unattached.sh 5 years ago
aws_s3_access_logging.sh updated aws_s3_access_logging.sh 5 years ago
aws_spot_when_terminated.sh updated aws_spot_when_terminated.sh 5 years ago
aws_ssm_put_param.sh updated aws_ssm_put_param.sh 5 years ago
aws_users.sh updated aws_users.sh 5 years ago
aws_users_access_key_age.sh updated aws_users_access_key_age.sh 5 years ago
aws_users_access_key_age_report.sh updated aws_users_access_key_age_report.sh 5 years ago
aws_users_access_key_last_used.sh updated aws_users_access_key_last_used.sh 5 years ago
aws_users_access_key_last_used_report.sh added aws_users_access_key_last_used_report.sh 5 years ago
aws_users_last_used_report.sh switched to use aws_iam_generate_credentials_report_wait.sh 5 years ago
aws_users_mfa_active_report.sh added password_enabled field 5 years ago
aws_users_mfa_serials.sh added aws_users_mfa_serials.sh 5 years ago
aws_users_pw_last_used.sh updated aws_users_pw_last_used.sh 5 years ago
azure-pipelines.yml updated azure-pipelines.yml 5 years ago
beeline.sh updated beeline.sh 5 years ago
beeline_zk.sh updated beeline_zk.sh 5 years ago
bitbucket-pipelines.yml updated bitbucket-pipelines.yml 5 years ago
brew_install_packages.sh updated brew_install_packages.sh 5 years ago
center.sh updated center.sh 5 years ago
check_all.sh updated check_all.sh 5 years ago
check_ansible_playbooks.sh updated check_ansible_playbooks.sh 5 years ago
check_aws_no_git_credentials.sh updated check_aws_no_git_credentials.sh 5 years ago
check_bash_arrays.sh updated check_bash_arrays.sh 5 years ago
check_bash_duplicate_defs.sh updated check_bash_duplicate_defs.sh 5 years ago
check_bash_syntax.sh updated check_bash_syntax.sh 5 years ago
check_cson.sh updated check_cson.sh 5 years ago
check_docker_clean.sh updated check_docker_clean.sh 5 years ago
check_docker_compose.sh updated check_docker_compose.sh 5 years ago
check_dockerfiles.sh updated check_dockerfiles.sh 5 years ago
check_duplicate_dependencies.sh updated check_duplicate_dependencies.sh 5 years ago
check_duplicate_packages.sh updated check_duplicate_packages.sh 5 years ago
check_git_commit_authors.sh updated check_git_commit_authors.sh 5 years ago
check_git_no_merge_remnants.sh updated check_git_no_merge_remnants.sh 5 years ago
check_gradle_build.sh updated check_gradle_build.sh 5 years ago
check_json.sh updated check_json.sh 5 years ago
check_makefile.sh updated check_makefile.sh 5 years ago
check_maven_pom.sh updated check_maven_pom.sh 5 years ago
check_no_tabs.sh updated check_no_tabs.sh 5 years ago
check_non_executable_scripts.sh updated check_non_executable_scripts.sh 5 years ago
check_perl_syntax.sh updated check_perl_syntax.sh 5 years ago
check_python3_compat.sh renamed python3.sh -> check_python3_compat.sh 7 years ago
check_python_asserts.sh updated check_python_asserts.sh 5 years ago
check_python_exception_pass.sh updated check_python_exception_pass.sh 5 years ago
check_python_find_quit.sh updated check_python_find_quit.sh 5 years ago
check_python_pep8.sh updated check_python_pep8.sh 5 years ago
check_python_pylint.sh updated check_python_pylint.sh 5 years ago
check_pytools.sh updated check_pytools.sh 5 years ago
check_ruby_syntax.sh updated check_ruby_syntax.sh 5 years ago
check_sbt_build.sh updated check_sbt_build.sh 5 years ago
check_ssh_keys_encrypted.sh updated check_ssh_keys_encrypted.sh 5 years ago
check_tests_run_qualified.sh updated check_tests_run_qualified.sh 5 years ago
check_tld_chars.sh updated check_tld_chars.sh 5 years ago
check_travis_yml.sh updated check_travis_yml.sh 5 years ago
check_whitespace.sh updated check_whitespace.sh 5 years ago
check_yaml.sh updated check_yaml.sh 5 years ago
cloudera_manager_api.sh updated cloudera_manager_api.sh 5 years ago
cloudera_manager_impala_queries.sh updated cloudera_manager_impala_queries.sh 5 years ago
cloudera_manager_impala_queries_ddl.sh added cloudera_manager_impala_queries_ddl.sh 5 years ago
cloudera_manager_impala_queries_exceptions.sh updated cloudera_manager_impala_queries_exceptions.sh 5 years ago
cloudera_manager_impala_queries_failed.sh added cloudera_manager_impala_queries_failed.sh 5 years ago
cloudera_manager_impala_queries_metadata.sh updated cloudera_manager_impala_queries_metadata.sh 5 years ago
cloudera_manager_impala_queries_metadata_errors.sh updated cloudera_manager_impala_queries_metadata_errors.sh 5 years ago
cloudera_manager_impala_queries_metadata_refresh.sh renamed cloudera_manager_impala_queries_refresh_metadata.sh to cloudera_manager_impala_queries_metadata_refresh.sh 5 years ago
cloudera_manager_yarn_apps.sh updated cloudera_manager_yarn_apps.sh 5 years ago
cloudera_manager_yarn_apps_failed.sh added cloudera_manager_yarn_apps_failed.sh 5 years ago
codefresh.yml updated codefresh.yml 5 years ago
csv_header_indices.sh updated csv_header_indices.sh 5 years ago
curl_auth.sh updated curl_auth.sh 5 years ago
decomment.sh added decomment.sh 5 years ago
docker_clean.sh updated docker_clean.sh 5 years ago
docker_generate_status_page.sh updated docker_generate_status_page.sh 5 years ago
docker_mount_build_exec.sh updated docker_mount_build_exec.sh 5 years ago
elasticsearch_decommission_node.sh updated elasticsearch_decommission_node.sh 5 years ago
exec_interactive.sh moved exec-interactive.sh to exec_interactive.sh 5 years ago
find_duplicate_lines.sh updated find_duplicate_lines.sh 5 years ago
find_hanging_mount_point.sh updated find_hanging_mount_point.sh 5 years ago
gce_is_preempted.sh updated gce_is_preempted.sh 5 years ago
gce_meta.sh updated gce_meta.sh 5 years ago
gce_when_preempted.sh updated gce_when_preempted.sh 5 years ago
generate_status_page.sh updated generate_status_page.sh 5 years ago
git_clean_repos.sh updated git_clean_repos.sh git_pull_make_repos.sh git_update_repos.sh 5 years ago
git_for_each_branch.sh updated git_for_each_branch.sh 5 years ago
git_merge_all.sh updated git_merge_all.sh 5 years ago
git_merge_master.sh updated git_merge_master.sh 5 years ago
git_merge_master_pull.sh updated git_merge_master_pull.sh 5 years ago
git_pull_make_repos.sh updated git_pull_make_repos.sh 5 years ago
git_update_repos.sh updated git_update_repos.sh 5 years ago
git_update_repos_submodules.sh updated git_update_repos_submodules.sh 5 years ago
github_api.sh updated github_api.sh 5 years ago
github_generate_status_page.sh updated github_generate_status_page.sh 5 years ago
github_get_user_ssh_public_key.sh updated github_get_user_ssh_public_key.sh 5 years ago
github_get_user_ssh_public_key_api.sh updated github_get_user_ssh_public_key_api.sh 5 years ago
github_workflow_runs.sh updated github_workflow_runs.sh 5 years ago
github_workflows.sh updated github_workflows.sh 5 years ago
github_workflows_status.sh added github_workflows_status.sh 5 years ago
golang_get_install.sh updated golang_get_install.sh 5 years ago
golang_get_install_if_absent.sh updated golang_get_install_if_absent.sh 5 years ago
hadolint.yaml added hadolint.yaml 5 years ago
hadoop_random_node.sh updated hadoop_random_node.sh 5 years ago
hdfs_checksum.sh added see also note and link to hadoop_hdfs_files_native_checksums.jy 5 years ago
hdfs_checksum_crc.sh added see also note and link to hadoop_hdfs_files_native_checksums.jy 5 years ago
hdfs_checksum_crc_parallel.sh added see also note and link to hadoop_hdfs_files_native_checksums.jy 5 years ago
hdfs_checksum_parallel.sh added see also note and link to hadoop_hdfs_files_native_checksums.jy 5 years ago
hdfs_file_size.sh updated hdfs_file_size.sh 5 years ago
hdfs_file_size_including_replicas.sh updated hdfs_file_size_including_replicas.sh 5 years ago
hdfs_find_replication_factor_1.sh updated hdfs_find_replication_factor_1.sh 5 years ago
hdfs_set_replication_factor_3.sh added hdfs_set_replication_factor_3.sh 5 years ago
hive_foreach_table.sh updated hive_foreach_table.sh 5 years ago
hive_list_databases.sh added FILTER support 5 years ago
hive_list_tables.sh updated hive_list_tables.sh 5 years ago
hive_tables_column_counts.sh added hive_tables_column_counts.sh 5 years ago
hive_tables_locations.sh updated hive_tables_locations.sh 5 years ago
hive_tables_metadata.sh updated hive_tables_metadata.sh 5 years ago
hive_tables_row_counts.sh updated hive_tables_row_counts.sh 5 years ago
impala_foreach_table.sh updated impala_foreach_table.sh 5 years ago
impala_list_databases.sh added FILTER support 5 years ago
impala_list_tables.sh updated impala_list_tables.sh 5 years ago
impala_shell.sh updated impala_shell.sh 5 years ago
impala_tables_column_counts.sh updated impala_tables_column_counts.sh 5 years ago
impala_tables_locations.sh updated impala_tables_locations.sh 5 years ago
impala_tables_metadata.sh updated impala_tables_metadata.sh 5 years ago
impala_tables_row_counts.sh updated impala_tables_row_counts.sh 5 years ago
k8s_api.sh updated k8s_api.sh 5 years ago
kafka_acls.sh updated kafka_acls.sh 5 years ago
kafka_cli_jaas.conf moved kafka_wrappers/kafka_cli_jaas.conf to . 5 years ago
kafka_configs.sh updated kafka_configs.sh 5 years ago
kafka_console_consumer.sh updated kafka_console_consumer.sh 5 years ago
kafka_console_producer.sh updated kafka_console_producer.sh 5 years ago
kafka_consumer_groups.sh updated kafka_consumer_groups.sh 5 years ago
kafka_consumer_perf_test.sh updated kafka_consumer_perf_test.sh 5 years ago
kafka_producer_perf_test.sh updated kafka_producer_perf_test.sh 5 years ago
kafka_topics.sh updated kafka_topics.sh 5 years ago
ldap_group_recurse.sh updated ldap_group_recurse.sh 5 years ago
ldap_user_recurse.sh updated ldap_user_recurse.sh 5 years ago
ldapsearch.sh updated ldapsearch.sh 5 years ago
nodejs_npm_install.sh updated nodejs_npm_install.sh 5 years ago
nodejs_npm_install_if_absent.sh updated nodejs_npm_install_if_absent.sh 5 years ago
perl_cpanm_install.sh updated perl_cpanm_install.sh 5 years ago
perl_cpanm_install_if_absent.sh updated perl_cpanm_install_if_absent.sh 5 years ago
perl_find_duplicate_cpan_requirements.sh updated perl_find_duplicate_cpan_requirements.sh 5 years ago
perl_find_library_executable.sh updated perl_find_library_executable.sh 5 years ago
perl_find_library_path.sh updated perl_find_library_path.sh 5 years ago
perl_find_unused_cpan_modules.sh updated perl_find_unused_cpan_modules.sh 5 years ago
perl_generate_fatpacks.sh updated perl_generate_fatpacks.sh 5 years ago
perl_generate_par_binaries.sh added perl_generate_par_binaries.sh 5 years ago
perlpath.sh added perlpath.sh 5 years ago
pygmentize.sh updated pygmentize.sh 5 years ago
python_compile.sh updated python_compile.sh 5 years ago
python_find_duplicate_pip_requirements.sh updated python_find_duplicate_pip_requirements.sh 5 years ago
python_find_library_executable.sh updated python_find_library_executable.sh 5 years ago
python_find_library_path.sh updated python_find_library_path.sh 5 years ago
python_find_unused_pip_modules.sh updated python_find_unused_pip_modules.sh 5 years ago
python_module_to_import_name.sh updated python_module_to_import_name.sh 5 years ago
python_pip_install.sh updated python_pip_install.sh 5 years ago
python_pip_install_if_absent.sh updated python_pip_install_if_absent.sh 5 years ago
python_pip_reinstall_all_modules.sh added python_pip_reinstall_all_modules.sh 5 years ago
python_pyinstaller.sh updated python_pyinstaller.sh 5 years ago
pythonpath.sh added pythonpath.sh 5 years ago
random_select.sh updated random_select.sh 5 years ago
retry.sh updated retry.sh 5 years ago
ruby_gem_install.sh updated ruby_gem_install.sh 5 years ago
ruby_gem_install_if_absent.sh updated ruby_gem_install_if_absent.sh 5 years ago
run_latest_tests.sh added run_latest_tests.sh 7 years ago
run_tests.sh updated run_tests.sh 5 years ago
scalastyle_config.xml added scalastyle_config.xml 5 years ago
scan_duplicate_macs.sh updated scan_duplicate_macs.sh 5 years ago
shippable.yml updated shippable.yml 5 years ago
split.sh updated split.sh 5 years ago
ssl_get_cert.sh updated ssl_get_cert.sh 5 years ago
ssl_verify_cert.sh updated ssl_verify_cert.sh 5 years ago
sync_ci_to_adjacent_repos.sh renamed sync_ci_to_adjcent_repos.sh to sync_ci_to_adjacent_repos.sh 5 years ago
sync_to_repo.sh updated sync_to_repo.sh 5 years ago
update_gitignore.io.sh updated update_gitignore.io.sh 5 years ago
vault_pass.sh updated vault_pass.sh 5 years ago
wercker.yml updated wercker.yml 5 years ago
wercker_api_app.sh updated wercker_api_app.sh 5 years ago
wercker_api_runs.sh added wercker_api_runs.sh 5 years ago
wercker_api_workflows.sh added wercker_api_workflows.sh 5 years ago
wercker_app_id.sh added wercker_app_id.sh 5 years ago
yum_install_packages.sh updated yum_install_packages.sh 5 years ago
yum_remove_packages.sh moved yum-remove-packages.sh to yum_remove_packages.sh 5 years ago
zookeeper_client.sh renamed zookeeper-client.sh to zookeeper_client.sh 5 years ago
zookeeper_shell.sh updated zookeeper_shell.sh 5 years ago

README.md

Hari Sekhon - DevOps Bash Tools

Codacy Badge CodeFactor Quality Gate Status Maintainability Rating GitHub stars GitHub forks Reliability Rating Security Rating

Linux Mac Docker DockerHub Pulls DockerHub Build Automated Docker Build Status

Travis CI AppVeyor Drone CircleCI Codeship Status for HariSekhon/DevOps-Bash-tools Shippable Codefresh Wercker

Azure DevOps Pipeline BitBucket Pipeline GitLab Pipeline Repo on GitHub Repo on GitLab Repo on BitBucket

CI Mac CI Ubuntu CI Ubuntu 14.04 CI Ubuntu 16.04 CI Ubuntu 18.04 CI Debian CI Debian 8 CI Debian 9 CI Debian 10 CI CentOS CI CentOS 6 CI CentOS 7 CI CentOS 8 CI Fedora CI Alpine CI Alpine 3 CI Python 2.7 CI Python 3.6

150+ Shell Scripts, Advanced Bash environment & Utility Code Library used by all my other GitHub repos 200+ CI builds.

Contains:

  • Scripts for fast advanced systems administration including auto-populating required switches
  • Scripts for CI builds, forming a drop-in framework of standard checks
  • Bash environment enhancements
    • advanced .bashrc + .bash.d/*.sh - tonnes of advanced customizations and functions like pass which prompts for a password (star echo'd to screen) and stores it in the shell environment ram, which several scripts can then use to curl APIs without re-entering the password each time, nor exposing passwords on the CLI or in audit logs from command logging
    • advanced configuration files for common tools like vim, screen, tmux, installs the best sysadmin packages like those above plus AWS CLI, GCloud SDK, jq and many others, adds dynamic Git and shell behaviour enhancements, colouring, functions, aliases and automatic pathing of many common installation locations for many major languages like Python, Perl, Ruby, NodeJS, Golang...
  • Utility library used in many scripts here and sourced from other repos, using the 2 libraries
    • .bash.d/ - interactive library (huge)
    • lib/ - script library

For more advanced Systems Administration scripts in other languages, see the repos listed at the bottom of the page.

These scripts can be used straight from the git clone, but see setup benefits of make install next.

Hari Sekhon

Cloud & Big Data Contractor, United Kingdom

(ex-Cloudera, former Hortonworks Consultant)

https://www.linkedin.com/in/harisekhon

(you're welcome to connect with me on LinkedIn)

Quick Setup

make install
  • Adds sourcing to .bashrc/.bash_profile to automatically inherit all .bash.d/*.sh environment enhancements for all technologies (see Inventory Overview below)
  • Symlinks all .* config files to $HOME for git, vim, top, htop, screen, tmux, editorconfig, Ansible etc.
  • Installs OS package dependencies for all scripts (detects the OS and installs the right RPMs, Debs, Apk or Mac HomeBrew packages)
  • Installs Python packages including AWS CLI

make install effectively does make system-packages bash python aws, but if you want to pick and choose from different sections, see Individual Setup Parts below.

Inventory Overview

  • Scripts - Linux / Mac systems administration scripts:

    • installation scripts for various OS packages (RPM, Deb, Apk) for various Linux distros (Redhat RHEL / CentOS / Fedora, Debian / Ubuntu, Alpine)
    • install if absent scripts for Python, Perl, Ruby, NodeJS and Golang packages - good for minimizing the number of source code installs by first running the OS install scripts and then only building modules which aren't already detected as installed (provided by system packages), speeding up builds and reducing the likelihood of compile failures
    • install scripts for Jython and build tools like Gradle and SBT for when Linux distros don't provide packaged versions or where the packaged versions are too old
    • Git branch management
    • utility scripts used from other scripts
  • .* - dot conf files for lots of common software eg. advanced .vimrc, .gitconfig, massive .gitignore, .editorconfig, .screenrc, .tmux.conf etc.

    • .vimrc - contains many awesome vim tweaks, plus hotkeys for linting lots of different file types in place, including Python, Perl, Bash / Shell, Dockerfiles, JSON, YAML, XML, CSV, INI / Properties files, LDAP LDIF etc without leaving the editor!
    • .screenrc - fancy screen configuration including advanced colour bar, large history, hotkey reloading, auto-blanking etc.
    • .tmux.conf - fancy tmux configuration include advanced colour bar and plugins, settings, hotkey reloading etc.
    • Git:
      • .gitconfig - advanced Git configuration
      • .gitignore - extensive Git ignore of trivial files you shouldn't commit
      • enhanced Git diffs
      • protections against committing AWS access keys & secrets keys, merge conflict unresolved files
  • .bashrc - shell tuning and sourcing of .bash.d/*.sh

  • .bash.d/*.sh - thousands of lines of advanced bashrc code, aliases, functions and environment variables for:

    • Linux & Mac
    • SCM - Git, Mercurial, Svn
    • AWS
    • GCP
    • Docker
    • Kubernetes
    • Kafka
    • Vagrant
    • automatic GPG and SSH agent handling for handling encrypted private keys without re-entering passwords, and lazy evaluation to only prompt key load the first time SSH is called
    • and lots more - see .bash.d/README for a more detailed list
    • run make bash to link .bashrc/.bash_profile and the .* dot config files to your $HOME directory to auto-inherit everything
  • lib/*.sh - Bash utility libraries full of functions for Docker, environment, CI detection (Travis CI, Jenkins), port and HTTP url availability content checks etc. Sourced from all my other GitHub repos to make setting up Dockerized tests easier.

  • setup/install_*.sh - various simple to use installation scripts for common technologies like Ansible, Terraform, MiniKube and MiniShift (Kubernetes / Redhat OpenShift/OKD dev VMs), Maven, Gradle, SBT, EPEL, RPMforge, Homebrew, Travis CI, Parquet Tools etc.

  • aws*.sh - various AWS scripts for EC2 metadata, Spot Termination, SSM Parameter Store secret put from prompt, IAM Credential Reports on IAM users without MFA, old access keys and passwords, old user accounts that haven't logged in or used an access key recently, show password policy / set hardened password policy, show unattached IAM policies, show account summary to check various details including root account MFA enabled and no access keys, KMS keys rotation status, CloudTrail & Config status etc.

  • gce*.sh - Google Cloud scripts for GCE metadata API and pre-emption

  • curl_auth.sh - wraps curl to send your username and password from environment variables or interactive prompt through a ram file descriptor to avoid using the -u/--user which might otherwise expose your credentials in the process list or OS audit log files. Used by other API querying scripts

  • k8s_api.sh - finds Kubernetes API and runs your curl arguments against it, auto-getting authorization token and populating Authorization: Bearer header

  • ldapsearch.sh - wraps ldapsearch inferring settings from environment, can use environment variables for overrides

  • ldap_user_recurse.sh / ldap_group_recurse.sh - recurse Active Directory LDAP users upwards to find all parent groups, or groups downwards to find all nested users (useful for debugging LDAP integration and group-based permissions)

  • cloudera_manager_impala_queries*.sh - queries Cloudera Manager for recent Impala queries, failed queries, exceptions, DDL statements, metadata stale errors, metadata refresh calls etc.

  • cloudera_manager_yarn_apps.sh - queries Cloudera Manager for recent Yarn apps

  • beeline.sh - connects to HiveServer2 via beeline, auto-populating Kerberos and SSL settings, zookeepers for HiveServer2 HA discovery if the environment variable $HIVE_HA is set or using the $HIVESERVER_HOST environment variable so you can connect with no arguments (prompts for HiveServer2 address if you haven't set $HIVESERVER_HOST or $HIVE_HA)

    • beeline_zk.sh - connects to HiveServer2 HA via beeline, auto-populating SSL and ZooKeeper service discovery settings (specify $HIVE_ZOOKEEPERS environment variable to override). Automatically called by beeline.sh if either $HIVE_ZOOKEEPERS or $HIVE_HA is set (the latter parses hive-site.xml for the ZooKeeper addresses)
    • hive_foreach_table.sh - executes a SQL query against every table, replacing {db} and {table} in each iteration eg. select count(*) from {table}
    • hive_*.sh - various scripts using beeline.sh to list databases, tables, for all tables: row counts, DDL metadata field extraction, table locations etc.
  • impala_shell.sh - connects to Impala via impala-shell, parsing the Hadoop topology map and selecting a random datanode to connect to its Impalad. This is mostly for convenience to shorten commands and while it acts as a poor man's load balancer, you might want to instead use my real load balancer HAProxy config for Impala (and many other Big Data & NoSQL technologies). Optional environment variables $IMPALA_HOST (eg. point to HAProxy load balancer) and IMPALA_SSL=1 (or use regular impala-shell --ssl argument pass through)

    • impala_foreach_table.sh - executes a SQL query against every table, replacing {db} and {table} in each iteration eg. select count(*) from {table}
    • impala_*.sh - various scripts using impala_shell.sh to list databases, tables, for all tables: row counts, DDL metadata field extraction, table locations etc.
  • kafka_*.sh - scripts to make Kafka CLI usage easier including auto-setting Kerberos to source TGT from environment and auto-populating broker and zookeeper addresses. These are auto-added to the $PATH when .bashrc is sourced. For something similar for Solr, see solr_cli.pl in the DevOps Perl Tools repo.

  • zookeeper_client.sh - wraps zookeeper-client, auto-finds the zookeeper quorum from /etc/**/*-site.xml to make it faster and easier to connect

  • zookeeper_shell.sh - wraps Kafka's zookeeper-shell, auto-populating the zookeeper quorum from the environment to make it faster and easier to connect

  • hdfs_checksum*.sh - walks an HDFS directory tree and outputs HDFS native checksums, MD5-of-MD5 or the portable externally comparable CRC32, in serial or in parallel to save time

  • hdfs_find_replication_factor_1.sh / hdfs_set_replication_factor_3.sh - finds HDFS files with replication factor 1 / sets HDFS files with replication factor <=2 to replication factor 3 to repair replication safety and avoid no replica alarms during maintenance operations (see also Python API version in the DevOps Python Tools repo)

  • hdfs_file_size.sh / hdfs_file_size_including_replicas.sh - quickly differentiate HDFS files raw size vs total replicated size

  • check_*.sh - extensive collection of generalized tests that can be applied to any repo (these run against all my GitHub repos via CI)

  • git*.sh - various useful Git scripts like iterating all branches executing command arguments, submodule handling, merging master updates to all branches

  • github*.sh - various useful GitHub scripts for querying the GitHub API including:

    • github_api.sh - querying the GitHub API while inferring github repo from local remotes and authenticating if github access token is available in environment or remote url, this is used as a base for several other scripts that use the GitHub API
    • fetching GitHub users public SSH keys for quick local installation
    • generating a STATUS.md page by merging all the README.md headers for all a user's non-forked GitHub repos or a given list of any repos etc.
  • perl*.sh - various Perl utilities including scripts to generate fatpacks (self-contained programs with all CPAN modules built-in), find the Perl library base, find where a Perl CLI tool is installed (system vs user, useful when it gets installed to a place that isn't in your $PATH, where which won't help), print the perl module search path, find unused CPAN modules in project, find duplicate CPAN modules between projects and sub-projects, bulk install file lists of CPAN modules, install CPAN packages only when not present in perl path (either OS packages or CPAN) to avoid needless installations, saving time and reducing build failures

  • python*.sh - various Python utilities including scripts to byte-compile, find the Python library base, find where a Python CLI tool is installed (system vs user, useful when it gets installed to a place that isn't in your $PATH, where which won't help), print the module search path, find unused pip modules in projects, find duplicate pip modules between projects and sub-projects, convert Python module names to import names, bulk install file lists of packages, install packages only when not present in python path (either OS or pip - avoids pip installing packages provided by OS, speeds up builds and reduces build failures

    • all builds across all my GitHub repos now make system-packages before make pip / make cpan to shorten how many packages need installing, reducing chances of build failures
  • Programming language linting:

    • Python (syntax, pep8, byte-compiling, reliance on asserts which can be disabled at runtime, except/pass etc.)
    • Perl
    • Java
    • Scala
    • Ruby
    • Bash / Shell
    • Misc (whitespace, custom enforced checks like not calling quit() in Python programs etc.)
  • Build System & CI linting:

  • Data format validation using programs from my DevOps Python Tools repo:

    • CSV
    • JSON
    • Avro
    • Parquet
    • INI / Properties files (Java)
    • LDAP LDIF
    • XML
    • YAML

Currently utilized in the following GitHub repos:

  • DevOps Python Tools - 80+ DevOps CLI tools for AWS, Hadoop, HBase, Spark, Log Anonymizer, Ambari Blueprints, AWS CloudFormation, Linux, Docker, Spark Data Converters & Validators (Avro / Parquet / JSON / CSV / INI / XML / YAML), Elasticsearch, Solr, Travis CI, Pig, IPython

  • The Advanced Nagios Plugins Collection - 450+ programs for Nagios monitoring your Hadoop & NoSQL clusters. Covers every Hadoop vendor's management API and every major NoSQL technology (HBase, Cassandra, MongoDB, Elasticsearch, Solr, Riak, Redis etc.) as well as message queues (Kafka, RabbitMQ), continuous integration (Jenkins, Travis CI) and traditional infrastructure (SSL, Whois, DNS, Linux)

  • DevOps Perl Tools - 25+ DevOps CLI tools for Hadoop, HDFS, Hive, Solr/SolrCloud CLI, Log Anonymizer, Nginx stats & HTTP(S) URL watchers for load balanced web farms, Dockerfiles & SQL ReCaser (MySQL, PostgreSQL, AWS Redshift, Snowflake, Apache Drill, Hive, Impala, Cassandra CQL, Microsoft SQL Server, Oracle, Couchbase N1QL, Dockerfiles, Pig Latin, Neo4j, InfluxDB), Ambari FreeIPA Kerberos, Datameer, Linux...

  • HAProxy-configs - 80+ HAProxy Configs for Hadoop, Big Data, NoSQL, Docker, Elasticsearch, SolrCloud, HBase, Cloudera, Hortonworks, MapR, MySQL, PostgreSQL, Apache Drill, Hive, Presto, Impala, ZooKeeper, OpenTSDB, InfluxDB, Prometheus, Kibana, Graphite, SSH, RabbitMQ, Redis, Riak, Rancher etc.

  • Dockerfiles - 50+ DockerHub public images for Docker & Kubernetes - Hadoop, Kafka, ZooKeeper, HBase, Cassandra, Solr, SolrCloud, Presto, Apache Drill, Nifi, Spark, Mesos, Consul, Riak, OpenTSDB, Jython, Advanced Nagios Plugins & DevOps Tools repos on Alpine, CentOS, Debian, Fedora, Ubuntu, Superset, H2O, Serf, Alluxio / Tachyon, FakeS3

  • Perl Lib - Perl utility library

  • PyLib - Python utility library

  • Lib-Java - Java utility library

  • Nagios Plugin Kafka - Kafka Nagios Plugin written in Scala with Kerberos support

Pre-built Docker images are available for those repos (which include this one as a submodule) and the "docker available" icon above links to an uber image which contains all my github repos pre-built. There are Centos, Alpine, Debian and Ubuntu versions of this uber Docker image containing all repos.

Individual Setup Parts

Optional, only if you don't do the full make install.

Install only OS system package dependencies and AWS CLI via Python Pip (doesn't symlink anything to $HOME):

make

Adds sourcing to .bashrc and .bash_profile and symlinks dot config files to $HOME (doesn't install OS system package dependencies):

make link

undo via

make unlink

Install only OS system package dependencies (doesn't include AWS CLI or Python packages):

make system-packages

Install AWS CLI:

make aws

Install generically useful Python CLI tools and modules (includes AWS CLI, autopep8 etc):

make python

Full Help

> make help

 Usage:

  Common Options:

    make help                   show this message
    make build                  installs all dependencies - OS packages and any language libraries via native tools eg. pip, cpanm, gem, go etc that are not available via OS packages
    make system-packages        installs OS packages only (detects OS via whichever package manager is available)
    make test                   run tests
    make clean                  removes compiled / generated files, downloaded tarballs, temporary files etc.

    make submodules             initialize and update submodules to the right release (done automatically by build / system-packages)

    make cpan                   install any modules listed in any cpan-requirements.txt files if not already installed

    make pip                    install any modules listed in any requirements.txt files if not already installed

    make python-compile         compile any python files found in the current directory and 1 level of subdirectory
    make pycompile

    make github                 open browser at github project
    make readme                 open browser at github's README
    make github-url             print github url and copy to clipboard

    make ls-files               print list of files in project
    make ls-code                print list of code files, excluding READMEs and other peripheral files
    make wc                     show line counts of the files and grand total
    make wc-code                show line counts of only code files and total

  Repo specific options:

    make install                builds all script dependencies, installs AWS CLI, symlinks all config files to $HOME and adds sourcing of bash profile

    make link                   symlinks all config files to $HOME and adds sourcing of bash profile
    make unlink                 removes all symlinks pointing to this repo's config files and removes the sourcing lines from .bashrc and .bash_profile

    make python-desktop         installs all Python Pip packages for desktop workstation listed in setup/pip-packages-desktop.txt
    make perl-desktop           installs all Perl CPAN packages for desktop workstation listed in setup/cpan-packages-desktop.txt
    make ruby-desktop           installs all Ruby Gem packages for desktop workstation listed in setup/gem-packages-desktop.txt
    make golang-desktop         installs all Golang packages for desktop workstation listed in setup/go-packages-desktop.txt
    make nodejs-desktop         installs all NodeJS packages for desktop workstation listed in setup/npm-packages-desktop.txt

    make desktop                installs all of the above + many desktop OS packages listed in setup/

    make mac-desktop            all of the above + installs a bunch of major common workstation software packages like Ansible, Terraform, MiniKube, MiniShift, SDKman, Travis CI, CCMenu, Parquet tools etc.
    make linux-desktop

    make ls-scripts             print list of scripts in this project, ignoring code libraries in lib/ and .bash.d/
    make wc-scripts             show line counts of the scripts and grand total
    make wc-scripts2            show line counts of only scripts and total

    make vim                    installs Vundle and plugins
    make tmux                   installs TMUX plugin for kubernetes context
    make ccmenu                 installs and (re)configures CCMenu to watch this and all other major HariSekhon GitHub repos
    make status                 open the Github Status page of all my repos build statuses across all CI platforms

    make aws                    installs AWS CLI tools
    make gcp                    installs GCloud SDK
    make gcp-shell              sets up GCP Cloud Shell: installs core packages and links configs
                                (future boots then auto-install system packages via .customize_environment hook)
make: *** [help] Error 3

(make help exits with error code 3 like most of my programs to differentiate from build success to make sure a stray help argument doesn't cause silent build failure with exit code 0)

Stargazers over time

Stargazers over time