grafana/README.md

175 lines
5.6 KiB
Markdown
Raw Normal View History

[Grafana](https://grafana.com) [![Circle CI](https://circleci.com/gh/grafana/grafana.svg?style=svg)](https://circleci.com/gh/grafana/grafana) [![Go Report Card](https://goreportcard.com/badge/github.com/grafana/grafana)](https://goreportcard.com/report/github.com/grafana/grafana) [![codecov](https://codecov.io/gh/grafana/grafana/branch/master/graph/badge.svg)](https://codecov.io/gh/grafana/grafana)
2014-07-14 13:53:20 -05:00
================
2017-03-13 15:32:28 -05:00
[Website](https://grafana.com) |
2015-03-25 06:17:22 -05:00
[Twitter](https://twitter.com/grafana) |
2017-03-13 17:05:47 -05:00
[Community & Forum](https://community.grafana.com)
2013-01-25 22:10:28 -06:00
2015-03-25 06:03:20 -05:00
Grafana is an open source, feature rich metrics dashboard and graph editor for
2015-11-12 06:50:57 -06:00
Graphite, Elasticsearch, OpenTSDB, Prometheus and InfluxDB.
2014-07-14 13:53:20 -05:00
2019-02-11 03:57:32 -06:00
<!---
2017-03-13 15:32:28 -05:00
![](http://docs.grafana.org/assets/img/features/dashboard_ex1.png)
2019-02-11 03:57:32 -06:00
-->
2015-03-29 06:39:51 -05:00
2014-08-12 02:24:58 -05:00
## Installation
2019-02-11 03:57:32 -06:00
Head to [docs.grafana.org](http://docs.grafana.org/installation/) for documentation or [download](https://grafana.com/get) to get the latest release.
2014-08-12 02:24:58 -05:00
## Documentation & Support
2015-03-29 06:30:03 -05:00
Be sure to read the [getting started guide](http://docs.grafana.org/guides/gettingstarted/) and the other feature guides.
2014-01-20 03:57:59 -06:00
2014-08-12 02:24:58 -05:00
## Run from master
If you want to build a package yourself, or contribute - here is a guide for how to do that. You can always find
2017-03-13 15:32:28 -05:00
the latest master builds [here](https://grafana.com/grafana/download)
2015-03-29 06:30:03 -05:00
### Dependencies
- Go (Latest Stable)
- bra [`go get github.com/Unknwon/bra`]
- Node.js LTS
- yarn [`npm install -g yarn`]
### Get the project
**The project located in the go-path will be your working directory.**
2015-03-29 06:30:03 -05:00
2016-02-10 05:08:04 -06:00
```bash
2017-09-07 08:26:08 -05:00
go get github.com/grafana/grafana
cd $GOPATH/src/github.com/grafana/grafana
```
### Building
#### The backend
```bash
2016-09-15 06:09:33 -05:00
go run build.go setup
2015-12-03 05:03:06 -06:00
go run build.go build
2015-03-29 06:30:03 -05:00
```
#### Frontend assets
2015-03-29 06:30:03 -05:00
*For this you need Node.js (LTS version).*
2015-03-29 06:30:03 -05:00
2016-02-10 05:08:04 -06:00
```bash
yarn install --pure-lockfile
```
### Run and rebuild on source change
#### Backend
To run the backend and rebuild on source change:
```bash
$GOPATH/bin/bra run
```
#### Frontend
Rebuild on file change, and serve them by Grafana's webserver (http://localhost:3000):
```bash
2019-02-19 14:15:36 -06:00
yarn start
```
Build the assets, rebuild on file change with Hot Module Replacement (HMR), and serve them by webpack-dev-server (http://localhost:3333):
```bash
2019-02-19 14:15:36 -06:00
yarn start:hot
# OR set a theme
2019-02-19 14:15:36 -06:00
env GRAFANA_THEME=light yarn start:hot
```
*Note: HMR for Angular is not supported. If you edit files in the Angular part of the app, the whole page will reload.*
Run tests and rebuild on source change:
2016-02-10 05:08:04 -06:00
```bash
yarn jest
2015-03-29 06:30:03 -05:00
```
**Open grafana in your browser (default: e.g. `http://localhost:3000`) and login with admin user (default: `user/pass = admin/admin`).**
2015-03-29 06:30:03 -05:00
### Building a Docker image
2018-08-06 07:04:41 -05:00
There are two different ways to build a Grafana docker image. If your machine is setup for Grafana development and you run linux/amd64 you can build just the image. Otherwise, there is the option to build Grafana completely within Docker.
Run the image you have built using: `docker run --rm -p 3000:3000 grafana/grafana:dev`
#### Building on linux/amd64 (fast)
2018-08-06 07:04:41 -05:00
1. Build the frontend `go run build.go build-frontend`
2. Build the docker image `make build-docker-dev`
The resulting image will be tagged as `grafana/grafana:dev`
#### Building anywhere (slower)
Choose this option to build on platforms other than linux/amd64 and/or not have to setup the Grafana development environment.
1. `make build-docker-full` or `docker build -t grafana/grafana:dev .`
The resulting image will be tagged as `grafana/grafana:dev`
Notice: If you are using Docker for MacOS, be sure to set the memory limit to be larger than 2 GiB (at docker -> Preferences -> Advanced), otherwise `grunt build` may fail.
## Development
2015-03-29 06:30:03 -05:00
### Dev config
Create a custom.ini in the conf directory to override default configuration options.
You only need to add the options you want to override. Config files are applied in the order of:
1. grafana.ini
1. custom.ini
2015-03-29 06:30:03 -05:00
In your custom.ini uncomment (remove the leading `;`) sign. And set `app_mode = development`.
### Running tests
#### Frontend
Execute all frontend tests
```bash
2018-08-14 05:40:07 -05:00
yarn test
```
2018-08-14 02:28:08 -05:00
Writing & watching frontend tests
2018-08-14 05:40:07 -05:00
- Start watcher: `yarn jest`
- Jest will run all test files that end with the name ".test.ts"
#### Backend
```bash
# Run Golang tests using sqlite3 as database (default)
2018-05-08 11:14:38 -05:00
go test ./pkg/...
# Run Golang tests using mysql as database - convenient to use /docker/blocks/mysql_tests
2018-05-08 11:14:38 -05:00
GRAFANA_TEST_DB=mysql go test ./pkg/...
# Run Golang tests using postgres as database - convenient to use /docker/blocks/postgres_tests
2018-05-08 11:14:38 -05:00
GRAFANA_TEST_DB=postgres go test ./pkg/...
```
### Datasource and dashboard provisioning
[Here](https://github.com/grafana/grafana/tree/master/devenv) you can find helpful scripts and docker-compose setup
that will populate your dev environment for quicker testing end experimenting.
2015-04-29 15:35:03 -05:00
## Contribute
2017-10-12 04:30:01 -05:00
If you have any ideas for improvement or have found a bug, do not hesitate to open an issue.
And if you have time, clone this repo and submit a pull request to help me make Grafana
2019-02-19 14:15:36 -06:00
the kickass metrics & devops dashboard we all dream about!
2019-01-10 01:37:40 -06:00
Read the [contributing](https://github.com/grafana/grafana/blob/master/CONTRIBUTING.md) guide then check the [`beginner friendly`](https://github.com/grafana/grafana/issues?q=is%3Aopen+is%3Aissue+label%3A%22beginner+friendly%22) label to find issues that are easy and that we would like help with.
2014-01-20 03:57:59 -06:00
2017-10-12 04:30:01 -05:00
## Plugin development
Checkout the [Plugin Development Guide](http://docs.grafana.org/plugins/developing/development/) and checkout the [PLUGIN_DEV.md](https://github.com/grafana/grafana/blob/master/PLUGIN_DEV.md) file for changes in Grafana that relate to
plugin development.
2017-10-12 04:30:01 -05:00
2014-08-12 02:24:58 -05:00
## License
2017-10-12 04:30:01 -05:00
Grafana is distributed under [Apache 2.0 License](https://github.com/grafana/grafana/blob/master/LICENSE).
2017-10-12 04:30:01 -05:00