Я написал сценарий, который загружает и устанавливает anaconda3 и некоторые другие зависимости, а затем устанавливает пару модулей python с помощью pip3
.
Проблема в том, что мой source ~/.bashrc
, похоже, не работает, и поэтому pip3
не распознается. Если я использую exec bash
, остальные команды после этой команды не выполняются.
Что мне делать?
Кстати, это мой скрипт :
#!/bin/bash
## Bash script for setting up a PX4 development environment on Ubuntu LTS (16.04 and above).
## It can be used for installing simulators (only) or for installing the preconditions for Snapdragon Flight or Raspberry Pi.
##
## Installs:
## - Common dependencies and tools for all targets (including: Ninja build system, latest versions of cmake, git, anaconda3, pyulog)
## - jMAVSim simulator dependencies
## - PX4/Firmware source (to ~/src/Firmware/)
# Preventing sudo timeout https://serverfault.com/a/833888
trap "exit" INT TERM; trap "kill 0" EXIT; sudo -v || exit $?; sleep 1; while true; do sleep 60; sudo -nv; done 2>/dev/null &
# Ubuntu Config
echo "Remove modemmanager"
sudo apt-get remove modemmanager -y
echo "Add user to dialout group for serial port access (reboot required)"
sudo usermod -a -G dialout $USER
# Update CMake and Git
# Installing latest version of cmake (ref https://askubuntu.com/questions/355565/#865294 )
echo "Installing latest version of CMake"
sudo apt update && \
sudo apt install -y software-properties-common lsb-release && \
sudo apt clean all
wget -O - https://apt.kitware.com/keys/kitware-archive-latest.asc 2>/dev/null | gpg --dearmor - | sudo tee /etc/apt/trusted.gpg.d/kitware.gpg >/dev/null
sudo apt-add-repository "deb https://apt.kitware.com/ubuntu/ $(lsb_release -cs) main"
sudo apt update
sudo apt install kitware-archive-keyring
sudo rm /etc/apt/trusted.gpg.d/kitware.gpg
sudo apt update
sudo apt install cmake
# Installing the latest version of git
echo "Installing the latest version of git"
sudo add-apt-repository -y ppa:git-core/ppa
sudo apt-get update
sudo apt-get install git -y
# Install anaconda3
type conda >/dev/null 2>&1 || { echo >&2 "Installing anaconda3 (python 3.8.8)"; wget https://repo.anaconda.com/archive/Anaconda3-2021.05-Linux-x86_64.sh; bash ./Anaconda3-2021.05-Linux-x86_64.sh;}
source ~/.bashrc
. ~/.bashrc
# Common dependencies
echo "Installing common dependencies"
sudo apt-get update -y
sudo apt-get install git zip cmake build-essential genromfs ninja-build exiftool astyle -y
# make sure xxd is installed, dedicated xxd package since Ubuntu 18.04 but was squashed into vim-common before
which xxd || sudo apt install xxd -y || sudo apt-get install vim-common --no-install-recommends -y
# Required python packages
pip3 install argparse empy toml numpy
pip3 install pandas jinja2 pyserial pyyaml
pip3 install pyulog
# jMAVSim simulator dependencies
echo "Installing jMAVSim simulator dependencies"
sudo apt-get install ant openjdk-8-jdk openjdk-8-jre -y
Мне пришлось использовать eval
для успешного исходника ~ / .bashrc
. Я сделал это:
eval "$(cat ~/.bashrc | tail -n +10)"
Цитата из здесь :
Это поведение специфично для Ubuntu (и, вероятно, наиболее производных дистрибутивов), поскольку по умолчанию
~ / .bashrc
файл начинается с короткого замыкания , Ubuntu 18.04, для примера:
# Если не работает в интерактивном режиме, ничего не делайте case $ - in {{1 }} * i *) ;; *) return ;; esac
... Это остановит оценку файла, если он выполняется в { {1}} неинтерактивная оболочка, как в случае вашего сценария, поскольку все сценарии выполняются в неинтерактивной оболочке, и впоследствии каждый исходный файл унаследует это свойство.
и все прошло нормально. Похоже, поскольку скрипты работают в неинтерактивном режиме, поиск bashrc
не имеет никакого эффекта из-за проверки в начале bashrc (по крайней мере, в дистрибутивах на основе ubuntu). поэтому, используя eval, мы можем обойти это.
Попробуйте запустить следующий код после source ~ / .bashrc
, что заставит Bash забыть все запомненные полные пути:
$ hash -r
хэш [-r] [-p имя_файла] [-dt] [имя]
Каждый раз, когда вызывается хеш, он запоминает полные имена путей команд, указанных в качестве аргументов имени, поэтому их не нужно искать for при последующих вызовах. [...] Параметр -r заставляет оболочку забыть все запомненные местоположения.