zabbix.sh 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #!/bin/sh
  2. echo -e '
  3. _ _ _
  4. _____ _| |__| |__(_)__
  5. |_ / _` | `_ \ `_ \ / _|
  6. /__\__,_|_.__/_.__/_\__|
  7. '
  8. . bin/checkroot.sh
  9. # get the current position
  10. _cwd="$(pwd)"
  11. # check for assets forlder
  12. _assets="$_cwd/assets"
  13. if [ ! -d "$_assets" ]; then
  14. _assets="$_cwd/../assets"
  15. if [ ! -d "$_assets" ]; then
  16. echo "!! can't find assets directory !!"
  17. exit
  18. fi
  19. fi
  20. echo -n "do you want to limit zabbix-agent to 3.4? [y|n] "
  21. read yn
  22. if [ "$yn" = "Y" ] || [ "$yn" = "y" ]; then
  23. echo -e "Stick with zabbix-agent 3.4"
  24. echo "http://dl-cdn.alpinelinux.org/alpine/v3.8/main" >> /etc/apk/repositories
  25. echo -e "zabbix-agent<3.4.99" >> /etc/apk/world
  26. apk update
  27. fi
  28. apk add zabbix-agent
  29. # configure
  30. echo -n "Please provide the current server's public ip : "
  31. read _cur_ip
  32. echo -n "Please provide the zabbix-server's ip : "
  33. read _ip
  34. echo -n "Please provide the hostname of this agent : "
  35. read _host_name
  36. echo -n "Please provide the mysql root password : "
  37. read _root_mysql_passwd
  38. # configure zabbix agent
  39. sed -i "s#Server=127.0.0.1#Server=$_ip#g" /etc/zabbix/zabbix_agentd.conf
  40. sed -i "s#ServerActive=127.0.0.1#ServerActive=$_ip#g" /etc/zabbix/zabbix_agentd.conf
  41. sed -i "s#Hostname=Zabbix server#Hostname=$_host_name#g" /etc/zabbix/zabbix_agentd.conf
  42. _agent_conf_d="/etc/zabbix/zabbix_agentd.d"
  43. mkdir $_agent_conf_d
  44. sed -i "s|#\ Include=$|Include= $_agent_conf_d|g" /etc/zabbix/zabbix_agentd.conf
  45. # apk
  46. # check for alpine security updates
  47. # # MYSQL
  48. # # https://serverfault.com/questions/737018/zabbix-user-parameter-mysql-status-setting-home
  49. # # create zabbix user home
  50. # mkdir /var/lib/zabbix
  51. # # generate random password for zabbix mysql user
  52. # _passwd="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c12)"
  53. # # add mysql credentials to zabbix home
  54. # printf "[client]\n
  55. # user=zabbix\n
  56. # password=$_passwd" > /var/lib/zabbix/.my.cnf
  57. # # create zabbix mysql user
  58. # mysql -uroot -p"$_root_mysql_passwd" -e "CREATE USER 'zabbix' IDENTIFIED BY '$_passwd';"
  59. # mysql -uroot -p"$_root_mysql_passwd" -e "GRANT USAGE ON *.* TO 'zabbix'@'localhost' IDENTIFIED BY '$_passwd';"
  60. # # add zabbix-agent parameter
  61. # cp "$_assets"/zabbix/userparameter_mysql.conf "$_agent_conf_d"/
  62. # NGINX
  63. # https://github.com/sfuerte/zbx-nginx
  64. # nginxconf already included in default.nginxconf asset
  65. sed -i "s/# allow CURRENT-SERVER-IP/allow $_cur_ip/g" /etc/nginx/conf.d/default.conf
  66. cp "$_assets"/zabbix/userparameter_nginx.conf "$_agent_conf_d"/
  67. mkdir /etc/zabbix/zabbix_agentd.scripts
  68. cp "$_assets"/zabbix/scripts/nginx-stat.py /etc/zabbix/zabbix_agentd.scripts/
  69. chmod +x /etc/zabbix/zabbix_agentd.scripts/nginx-stat.py
  70. echo -n "This is box is a proxmox CT? [Y|n] "
  71. read yn
  72. yn=${yn:-y}
  73. if [ "$yn" = "Y" ] || [ "$yn" = "y" ]; then
  74. cp "$_assets"/zabbix/proxmox-ct.conf "$_agent_conf_d"/
  75. fi
  76. # allow comm. port with zabbix-server
  77. ufw allow from "$_ip" to any port 22
  78. ufw allow from "$_ip" to any port 10050
  79. # ufw allow from "$_ip" to any port 10051
  80. rc-update add zabbix-agentd
  81. service zabbix-agentd restart
  82. echo -e "Zabbix-agent installed and configured, please add the host $_host_name in your zabbix-server"
  83. echo -e "And import requested templates in assets/zabbix/templates/"
  84. # echo -e "zabbix user mysql password is $_passwd"