0

J'essaie d'automatiser l'amorçage d'instance aws ec2 memcached en exécutant une recette de chef memcached. J'appelle un nom de script shell cache-init.sh à partir de la section UserData de formation au cloud. J'ai étapes suivantes dans mes scripts shell:CHEF: la variable d'environnement HOME (ou HOMEDRIVE et HOMEPATH) doit être définie et pointer vers un répertoire

Je courais AMI RHEL 6.7 Version

!/bin/bash 

init() { 
BINARIES=/root/.binaries 
PROFILE_SCRIPT=/etc/profile.d/instance_profile.sh 
APPLICATION_RELEASE_VERSION="app-v3.0.1" 
CHEF_ZIP="app-chef-${APPLICATION_RELEASE_VERSION}.zip" 
APP_FILES="${CHEF_ZIP}" 
HOME=/root 
} 

# Initializing the script vairables. 
init 

# Create chef folders 
mkdir /root/.chef; 
mkdir /root/.metadata; 

# Disable rhui-lb plugin, this has an issue in RHEL within VPC 
sed -i 's/enabled=1/enabled=0/g' /etc/yum/pluginconf.d/rhui-lb.conf 

# Print all environment varialbes in log 
set > /root/.metadata/metadata.txt 


# Update ${PROFILE_SCRIPT} 
echo "export HOME=${HOME}" >> ${PROFILE_SCRIPT}; 
chmod 644 ${PROFILE_SCRIPT}; 
log 'Added ${PROFILE_SCRIPT}'; 

echo ${HOME} 

# Install chef 
# Set these just for Chef installation 
/usr/bin/curl -L https://www.opscode.com/chef/install.sh | bash -s -- -v 11.16.2-1; 
chef_version=`chef-solo --version`; 
log "Installed Chef Version : $chef_version in /opt/chef " ; 

log "Installing ChefDk" 
/usr/bin/curl -L https://omnitruck.chef.io/install.sh | sudo bash -s -- -c current -P chefdk 

chef-repo=/root/.chef/chef-repo 
memcached_cookbook=${chef-repo}/cookbooks/memcached 
cd ${memcached_cookbook} 


# download and package the dependencies. 
chef exec berks install 
chef exec berks vendor 

log "memcached dependencies downloaded and packaged" 

cp -r berks-cookbooks/runit /root/.chef/itduzzit/cookbooks 
cp -r berks-cookbooks/yum /root/.chef/itduzzit/cookbooks 
cp -r berks-cookbooks/yum-epel /root/.chef/itduzzit/cookbooks 
cp -r berks-cookbooks/packagecloud /root/.chef/itduzzit/cookbooks 

# Clean up the dependencies. 
rm -rf berks-cookbooks 

Après la biges commande d'installation est exécuté, je reçois après erreur:

/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/rb-readline-0.5.3/lib/rbreadline.rb:1097:in <module:RbReadline>: HOME environment variable (or HOMEDRIVE and HOMEPATH) must be set and point to a directory (RuntimeError) 
from /opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/rb-readline- 0.5.3/lib/rbreadline.rb:17:in <top (required)> 
from ... 
from /opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/berkshelf-4.3.2/bin/berks:3:in `<top (required)>' 
from /usr/bin/berks:49:in `load' 
from /usr/bin/berks:49:in `<main>' 

J'ai essayé la mise la variable HOME env en l'exportant au début du script cache-init.sh mais toujours la même erreur. Quand je ssh à la boîte et exécuter le script manuellement, cela fonctionne très bien. J'ai essayé de chercher l'erreur mais je n'ai pas trouvé de solution appropriée. J'apprécierais vraiment toute aide ici.

+0

S'il vous plaît montrer comment vous définissez la variable d'environnement. – coderanger

+0

@coderanger I J'ai mis à jour la question avec mon script – sjaiswal

Répondre

0

Sous init, qui devrait être export HOME=... (et la même chose pour tout le reste. Sans export vous créez une variable bash, mais pas une variable d'environnement.

+0

J'exporte la variable en sauvegardant dans /etc/profile.d/instance_profile.sh en utilisant la commande ci-dessous: 'echo" export HOME = $ {HOME} ">> $ {PROFILE_SCRIPT} ; ' – sjaiswal

+0

Cela n'a aucun effet sur les commandes plus tard dans le même script, et généralement n'a aucun effet sur les services ou d'autres sessions non-interactives du tout – coderanger

+0

Mon problème a été résolu, merci pour votre aide, d'abord comme J'écrivais 'l'exportation HOME =/root dans le fichier/etc/profile.d/instance_profile.sh' dont je me suis rendu compte plus tard qu'il est uniquement généré au démarrage du shell. Depuis que mon script a été directement appelé par le script de formation au cloud, il n'a jamais été source d'erreur. J'ai changé mon script et j'ai explicitement 'exporté HOME =/root' dans le corps du script qui l'a rendu disponible comme variable d'environnement pour la commande berkshelf's berks et corrigé le problème. Appréciez votre aide! – sjaiswal