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.

216 lines
7.4 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. elif [[ $ID = 'fedora' ]]; then
  99. # fedora currently not tested nor supported
  100. sudo dnf install -y rabbitmq-server
  101. sudo systemctl enable rabbitmq-server
  102. sudo systemctl start rabbitmq-server
  103. else
  104. echo "error: distribution $ID not supported"
  105. exit 1
  106. fi
  107. fi
  108. if [[ $INSTALL_FAAFO -eq 1 ]]; then
  109. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  110. # TODO: needs to be updated for Ubuntu >= 20.04
  111. sudo apt-get install -y python-dev python-pip supervisor git zlib1g-dev libmysqlclient-dev python-mysqldb
  112. # Following is needed because of
  113. # https://bugs.launchpad.net/ubuntu/+source/supervisor/+bug/1594740
  114. if [ $(lsb_release --short --codename) = xenial ]; then
  115. # Make sure the daemon is enabled.
  116. if ! systemctl --quiet is-enabled supervisor; then
  117. systemctl enable supervisor
  118. fi
  119. # Make sure the daemon is started.
  120. if ! systemctl --quiet is-active supervisor; then
  121. systemctl start supervisor
  122. fi
  123. fi
  124. elif [[ $ID = 'fedora' ]]; then
  125. # fedora currently not tested nor supported
  126. sudo dnf install -y python-devel python-pip supervisor git zlib-devel mariadb-devel gcc which python-mysql
  127. sudo systemctl enable supervisord
  128. sudo systemctl start supervisord
  129. #elif [[ $ID = 'opensuse' || $ID = 'sles' ]]; then
  130. # sudo zypper install -y python-devel python-pip
  131. else
  132. echo "error: distribution $ID not supported"
  133. exit 1
  134. fi
  135. # HSFD changed to local repo
  136. git clone https://gogs.informatik.hs-fulda.de/srieger/cloud-computing-msc-ai-examples
  137. cd cloud-computing-msc-ai-examples/faafo
  138. # following line required by bug 1636150
  139. sudo pip install --upgrade pbr
  140. # in m1.tiny instance during cloud-init the following pip install can experience OOM kill
  141. # setup swap to prevent that
  142. sudo dd if=/dev/zero of=/swap bs=1M count=512
  143. sudo chmod 600 /swap
  144. sudo mkswap /swap
  145. sudo swapon /swap
  146. sudo pip install -r requirements.txt
  147. sudo python setup.py install
  148. sudo sed -i -e "s#transport_url = .*#transport_url = $URL_MESSAGING#" /etc/faafo/faafo.conf
  149. sudo sed -i -e "s#database_url = .*#database_url = $URL_DATABASE#" /etc/faafo/faafo.conf
  150. sudo sed -i -e "s#endpoint_url = .*#endpoint_url = $URL_ENDPOINT#" /etc/faafo/faafo.conf
  151. fi
  152. if [[ $RUN_API -eq 1 ]]; then
  153. faafo_api="
  154. [program:faafo_api]
  155. command=$(which faafo-api)
  156. priority=10
  157. startretries=0"
  158. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  159. echo "$faafo_api" | sudo tee -a /etc/supervisor/conf.d/faafo.conf
  160. elif [[ $ID = 'fedora' ]]; then
  161. # fedora currently not tested nor supported
  162. echo "$faafo_api" | sudo tee -a /etc/supervisord.d/faafo.ini
  163. else
  164. echo "error: distribution $ID not supported"
  165. exit 1
  166. fi
  167. fi
  168. if [[ $RUN_WORKER -eq 1 ]]; then
  169. faafo_worker="
  170. [program:faafo_worker]
  171. command=$(which faafo-worker)
  172. priority=20
  173. startretries=0"
  174. if [[ $ID = 'ubuntu' || $ID = 'debian' ]]; then
  175. echo "$faafo_worker" | sudo tee -a /etc/supervisor/conf.d/faafo.conf
  176. elif [[ $ID = 'fedora' ]]; then
  177. # fedora currently not tested nor supported
  178. echo "$faafo_worker" | sudo tee -a /etc/supervisord.d/faafo.ini
  179. else
  180. echo "error: distribution $ID not supported"
  181. exit 1
  182. fi
  183. fi
  184. if [[ $RUN_WORKER -eq 1 || $RUN_API -eq 1 ]]; then
  185. sudo supervisorctl reload
  186. sleep 5
  187. fi
  188. if [[ $RUN_DEMO -eq 1 && $RUN_API -eq 1 ]]; then
  189. faafo --endpoint-url $URL_ENDPOINT --debug create
  190. fi
  191. else
  192. exit 1
  193. fi