dca02024d9
Change-Id: Ie097044a2fd6467f4de531d7f2ba5fe1a2576f23
100 lines
2.8 KiB
Bash
Executable File
100 lines
2.8 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
|
|
echo "Installing chef"
|
|
DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
|
source $DIR/install.conf
|
|
if [ -f $DIR/env.conf ]; then
|
|
source $DIR/env.conf
|
|
else
|
|
echo "failed to load environment"
|
|
exit 1
|
|
fi
|
|
source $DIR/install_func.sh
|
|
|
|
echo "Installing chef related packages"
|
|
|
|
# create backup dir
|
|
sudo mkdir -p /root/backup/chef
|
|
|
|
sudo rpm -q chef-server
|
|
if [[ "$?" != "0" ]]; then
|
|
download -u "$CHEF_SRV" -u "$CHEF_SRV_HUAWEI" `basename $CHEF_SRV` install || exit $?
|
|
else
|
|
echo "chef-server has already installed"
|
|
fi
|
|
|
|
echo "reconfigure chef server"
|
|
# configure chef-server
|
|
sudo chef-server-ctl cleanse
|
|
mkdir -p /etc/chef-server
|
|
sudo cp -rn /etc/chef-server/chef-server.rb /root/backup/chef/
|
|
sudo rm -f /etc/chef-server/chef-server.rb
|
|
sudo cp -rf $COMPASSDIR/misc/chef-server/chef-server.rb /etc/chef-server/chef-server.rb
|
|
sudo chmod 644 /etc/chef-server/chef-server.rb
|
|
sudo chef-server-ctl reconfigure
|
|
sudo chef-server-ctl test
|
|
if [[ "$?" != "0" ]]; then
|
|
echo "chef-server-ctl test failed"
|
|
fi
|
|
|
|
echo "configure chef client and knife"
|
|
# configure chef client and knife
|
|
sudo rpm -q chef
|
|
if [[ "$?" != "0" ]]; then
|
|
download -u "$CHEF_CLIENT" -u "$CHEF_CLIENT_HUAWEI" `basename $CHEF_CLIENT` install || exit $?
|
|
else
|
|
echo "chef client has already installed"
|
|
fi
|
|
|
|
sudo mkdir -p ~/.chef
|
|
|
|
if [ ! -f /etc/chef-server/admin.pem ]; then
|
|
echo "/etc/chef-server/admin.pem does not exist"
|
|
exit 1
|
|
fi
|
|
|
|
if [ ! -f /etc/chef-server/chef-validator.pem ]; then
|
|
echo "/etc/chef-server/chef-validator.pem does not exist"
|
|
exit 1
|
|
fi
|
|
|
|
sudo knife configure -y -i --defaults -r ~/chef-repo -s https://$IPADDR:443 -u $USER --admin-client-name admin --admin-client-key /etc/chef-server/admin.pem --validation-client-name chef-validator --validation-key /etc/chef-server/chef-validator.pem <<EOF
|
|
$CHEF_PASSWORD
|
|
EOF
|
|
sudo sed -i "/node_name/c\node_name \'admin\'" /$USER/.chef/knife.rb
|
|
sudo sed -i "/client_key/c\client_key \'\/etc\/chef-server\/admin.pem\'" /$USER/.chef/knife.rb
|
|
|
|
|
|
sudo rm -rf /var/chef
|
|
sudo mkdir -p /var/chef/cookbooks/
|
|
sudo cp -r $ADAPTERS_HOME/chef/cookbooks/* /var/chef/cookbooks/
|
|
if [ $? -ne 0 ]; then
|
|
echo "failed to copy cookbooks to /var/chef/cookbooks/"
|
|
exit 1
|
|
fi
|
|
sudo mkdir -p /var/chef/roles/
|
|
sudo cp -r $ADAPTERS_HOME/chef/roles/* /var/chef/roles/
|
|
if [ $? -ne 0 ]; then
|
|
echo "failed to copy roles to /var/chef/roles/"
|
|
exit 1
|
|
fi
|
|
|
|
# Fix after bug 1397309 is fixed by upgrading chef-server
|
|
# work around by reducing concurrency to 1
|
|
knife cookbook upload --all --cookbook-path /var/chef/cookbooks
|
|
if [[ "$?" != "0" ]]; then
|
|
echo "failed to add cookbooks"
|
|
exit 1
|
|
else
|
|
echo "cookbooks are added to chef server"
|
|
fi
|
|
|
|
knife role from file /var/chef/roles/*.json
|
|
if [[ "$?" != "0" ]]; then
|
|
echo "failed to add roles"
|
|
exit 1
|
|
else
|
|
echo "roles are added to chef server"
|
|
fi
|