为了获得高可用性的服务,需要对单台部署grafana的服务器进行扩充。
这个过程中需要做两件事:
- 配置一个公共数据库,使所有的grafana服务器可以将配置写入公共数据库中而不是存在本地;
- 选用一个会话存储方案,这一步可以通过让负载均衡启用会话保持功能解决
数据库配置
grafana为数据库提供多种可选方案,包括:mysql,postgresql,sqlite3(default)。
配置文件为:
1 | vi /etc/grafana/grafana.ini |
配置项为database部分:
1 | [database] |
仅需要为grafana开辟一个数据库即可,数据表和字段将在用户新建一个dashboard后自动写入。
会话策略
grafana支持将回话保存在磁盘/数据库中,这两种保存方法对应着两种策略:会话保持和无状态会话。
会话保持
配合负载均衡,将同一用户的请求转发到相同的服务器上。这样工作量最小,但是也会出现某台服务器负载较其他服务器更高的情况。
无状态回话
grafana将用户的会话保存在数据库中,这样同一用户的会话也将会被分发到各个服务器中处理,这种方式需要在数据库中提前预设一张数据表,在grafana.ini中的session部分有关于此项的配置信息。
方案步骤
- 新建一个数据库,为grafana新建可操作用户
- 部署N台grafana服务器,修改各服务器的grafana.ini文件,写入数据库相关配置信息,重启grafana-server。
- 将配置好的grafana服务器挂载到负载均衡中,开启会话保持
- 访问负载均衡的IP,获得高可用的grafana服务