You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

220 lines
7.6 KiB

  1. #!/bin/bash
  2. # Licensed under the Apache License, Version 2.0 (the "License"); you may
  3. # not use this file except in compliance with the License. You may obtain
  4. # a copy of the License at
  5. #
  6. # http://www.apache.org/licenses/LICENSE-2.0
  7. #
  8. # Unless required by applicable law or agreed to in writing, software
  9. # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  10. # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  11. # License for the specific language governing permissions and limitations
  12. # under the License.
  13. if [[ -e /etc/os-release ]]; then
  14. # NOTE(berendt): support for CentOS/RHEL/openSUSE/SLES will be added in the future
  15. source /etc/os-release
  16. INSTALL_DATABASE=0
  17. INSTALL_FAAFO=0
  18. INSTALL_MESSAGING=0
  19. RUN_API=0
  20. RUN_DEMO=0
  21. RUN_WORKER=0
  22. URL_DATABASE='sqlite:////tmp/sqlite.db'
  23. URL_ENDPOINT='http://127.0.0.1'
  24. URL_MESSAGING='amqp://guest:guest@localhost:5672/'
  25. while getopts e:m:d:i:r: FLAG; do
  26. case $FLAG in
  27. i)
  28. case $OPTARG in
  29. messaging)
  30. INSTALL_MESSAGING=1
  31. ;;
  32. database)
  33. INSTALL_DATABASE=1
  34. ;;
  35. faafo)
  36. INSTALL_FAAFO=1
  37. ;;
  38. esac
  39. ;;
  40. r)
  41. case $OPTARG in
  42. demo)
  43. RUN_DEMO=1
  44. ;;
  45. api)
  46. RUN_API=1
  47. ;;
  48. worker)
  49. RUN_WORKER=1
  50. ;;
  51. esac
  52. ;;
  53. e)
  54. URL_ENDPOINT=$OPTARG
  55. ;;
  56. m)
  57. URL_MESSAGING=$OPTARG
  58. ;;
  59. d)
  60. URL_DATABASE=$OPTARG
  61. ;;
  62. *)
  63. echo "error: unknown option $FLAG"
  64. exit 1
  65. ;;
  66. esac
  67. done
  68. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  69. sudo apt-get update
  70. elif [[ $ID = 'fedora' ]]; then
  71. # fedora currently not tested nor supported
  72. sudo dnf update -y
  73. fi
  74. if [[ $INSTALL_DATABASE -eq 1 ]]; then
  75. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  76. sudo DEBIAN_FRONTEND=noninteractive apt-get install -y mysql-server python-mysqldb
  77. # HSFD changes for Ubuntu 18.04
  78. sudo sed -i -e "/bind-address/d" /etc/mysql/mysql.conf.d/mysqld.cnf
  79. #sudo sed -i -e "/bind-address/d" /etc/mysql/my.cnf
  80. sudo service mysql restart
  81. elif [[ $ID = 'fedora' ]]; then
  82. # fedora currently not tested nor supported
  83. sudo dnf install -y mariadb-server python-mysql
  84. printf "[mysqld]\nbind-address = 127.0.0.1\n" | sudo tee /etc/my.cnf.d/faafo.conf
  85. sudo systemctl enable mariadb
  86. sudo systemctl start mariadb
  87. else
  88. echo "error: distribution $ID not supported"
  89. exit 1
  90. fi
  91. sudo mysqladmin password password
  92. sudo mysql -uroot -ppassword mysql -e "CREATE DATABASE IF NOT EXISTS faafo; GRANT ALL PRIVILEGES ON faafo.* TO 'faafo'@'%' IDENTIFIED BY 'password';"
  93. URL_DATABASE='mysql://root:password@localhost/faafo'
  94. fi
  95. if [[ $INSTALL_MESSAGING -eq 1 ]]; then
  96. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  97. sudo apt-get install -y rabbitmq-server
  98. # fixes for rabbitmq setup
  99. sudo rabbitmqctl add_user faafo guest
  100. sudo rabbitmqctl set_user_tags faafo administrator
  101. sudo rabbitmqctl set_permissions -p / faafo ".*" ".*" ".*"
  102. elif [[ $ID = 'fedora' ]]; then
  103. # fedora currently not tested nor supported
  104. sudo dnf install -y rabbitmq-server
  105. sudo systemctl enable rabbitmq-server
  106. sudo systemctl start rabbitmq-server
  107. else
  108. echo "error: distribution $ID not supported"
  109. exit 1
  110. fi
  111. fi
  112. if [[ $INSTALL_FAAFO -eq 1 ]]; then
  113. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  114. # TODO: needs to be updated for Ubuntu >= 20.04
  115. sudo apt-get install -y python-dev python-pip supervisor git zlib1g-dev libmysqlclient-dev python-mysqldb
  116. # Following is needed because of
  117. # https://bugs.launchpad.net/ubuntu/+source/supervisor/+bug/1594740
  118. if [ $(lsb_release --short --codename) = xenial ]; then
  119. # Make sure the daemon is enabled.
  120. if ! systemctl --quiet is-enabled supervisor; then
  121. systemctl enable supervisor
  122. fi
  123. # Make sure the daemon is started.
  124. if ! systemctl --quiet is-active supervisor; then
  125. systemctl start supervisor
  126. fi
  127. fi
  128. elif [[ $ID = 'fedora' ]]; then
  129. # fedora currently not tested nor supported
  130. sudo dnf install -y python-devel python-pip supervisor git zlib-devel mariadb-devel gcc which python-mysql
  131. sudo systemctl enable supervisord
  132. sudo systemctl start supervisord
  133. #elif [[ $ID = 'opensuse' || $ID = 'sles' ]]; then
  134. # sudo zypper install -y python-devel python-pip
  135. else
  136. echo "error: distribution $ID not supported"
  137. exit 1
  138. fi
  139. # HSFD changed to local repo
  140. git clone https://gogs.informatik.hs-fulda.de/srieger/cloud-computing-msc-ai-examples
  141. cd cloud-computing-msc-ai-examples/faafo
  142. # following line required by bug 1636150
  143. sudo pip install --upgrade pbr
  144. # in m1.tiny instance during cloud-init the following pip install can experience OOM kill
  145. # setup swap to prevent that
  146. sudo dd if=/dev/zero of=/swap bs=1M count=512
  147. sudo chmod 600 /swap
  148. sudo mkswap /swap
  149. sudo swapon /swap
  150. sudo pip install -r requirements.txt
  151. sudo python setup.py install
  152. sudo sed -i -e "s#transport_url = .*#transport_url = $URL_MESSAGING#" /etc/faafo/faafo.conf
  153. sudo sed -i -e "s#database_url = .*#database_url = $URL_DATABASE#" /etc/faafo/faafo.conf
  154. sudo sed -i -e "s#endpoint_url = .*#endpoint_url = $URL_ENDPOINT#" /etc/faafo/faafo.conf
  155. fi
  156. if [[ $RUN_API -eq 1 ]]; then
  157. faafo_api="
  158. [program:faafo_api]
  159. command=$(which faafo-api)
  160. priority=10
  161. startretries=0"
  162. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  163. echo "$faafo_api" | sudo tee -a /etc/supervisor/conf.d/faafo.conf
  164. elif [[ $ID = 'fedora' ]]; then
  165. # fedora currently not tested nor supported
  166. echo "$faafo_api" | sudo tee -a /etc/supervisord.d/faafo.ini
  167. else
  168. echo "error: distribution $ID not supported"
  169. exit 1
  170. fi
  171. fi
  172. if [[ $RUN_WORKER -eq 1 ]]; then
  173. faafo_worker="
  174. [program:faafo_worker]
  175. command=$(which faafo-worker)
  176. priority=20
  177. startretries=0"
  178. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  179. echo "$faafo_worker" | sudo tee -a /etc/supervisor/conf.d/faafo.conf
  180. elif [[ $ID = 'fedora' ]]; then
  181. # fedora currently not tested nor supported
  182. echo "$faafo_worker" | sudo tee -a /etc/supervisord.d/faafo.ini
  183. else
  184. echo "error: distribution $ID not supported"
  185. exit 1
  186. fi
  187. fi
  188. if [[ $RUN_WORKER -eq 1 || $RUN_API -eq 1 ]]; then
  189. sudo supervisorctl reload
  190. sleep 5
  191. fi
  192. if [[ $RUN_DEMO -eq 1 && $RUN_API -eq 1 ]]; then
  193. faafo --endpoint-url $URL_ENDPOINT --debug create
  194. fi
  195. else
  196. exit 1
  197. fi