To use Upptime as an uptime monitor and status website generator, you start by creating a repository using the template on GitHub.
Create a repository from the template
You can click on the following link to generate a repository using the template: Create a new repository from
upptime/upptime. Alternately, you can follow these steps:
- Visit the Upptime repository on GitHub: https://github.com/upptime/upptime
- Click on the "Use this template" button on the top-right
- Enter a name for your new repository and check "Include all branches"
- Click on "Create repository from template"
For more details on how to create repositories using template, read the article on the GitHub website: Creating a repository from a template.
After creating your repository
The following steps apply to your new repository, not the upptime/upptime template repository.
To get a static status website, you have to enable GitHub Pages on your new repository.
- Go to your repository settings page
- Scroll to "GitHub Pages" settings
- Under "Source", change "None" to
- In the folder dropdown, select
- Skip the "Theme Chooser" option
- Click on "Save"
After saving, you will see confirmation text "Your site is ready to be published at...". For more information on enabling GitHub Pages, see the article on the GitHub website: Configuring a publishing source for your GitHub Pages site.
If you don't want to have a publicly-available status website, you don't have to enable publishing. If that is the case, you can also choose to keep your repository private. It is not possible to publish a status website from a private repository without using an API proxy with authentication. See #54 and the Configuration for
apiBaseUrl to learn how to set up a status website from your private repository.
Add repository secrets
All sensitive information required, such as API keys, are provided as environment variables. These are stored as GitHub repository secrets (see Creating and storing encrypted secrets).
To make commits and publish your website, Upptime requires a personal access token (PAT) with the
workflow scope, stored as a repository secret
GH_PAT. You can create a personal access token by following these steps:
- Click on your profile picture on the top-right corner and select "Settings"
- In the left sidebar, select "Developer settings"
- In the left sidebar, click "Personal access tokens"
- Click "Generate new token"
- Select the "repo" and "workflow" scopes
- Click "Generate token"
After generating your token, copy it (you will not see it again). Then, add it as a repository secret:
- In your Upptime repository, select "Settings"
- In the left sidebar, click "Secrets"
- Press the button "New repository secret"
- Enter the name of the secret as
- Paste your personal access token into the Value field
- Be sure there are no spaces before or after the token and/or linebreaks after your token
- Save your PAT by selecting "Add secret"
For more information on PATs, read article on the GitHub website: Creating a personal access token.
.upptimerc.yml file is used as the central configuration store. In that file, you can specify which endpoints you want to monitor and configure your status website. For more information, visit Configuration.
You can start by adding your endpoints under
If you're not using a custom domain, you can remove the line starting with
cname: and instead add the GitHub repository name:
Then, your status page may be hosted on https://user.github.io/repo/, where
user is your GitHub username and
repo is your repository name.
Viewing GitHub Actions workflows
After updating the configuration file, Upptime should run workflows using GitHub Actions to update your
README.md and generate API endpoints and graphs. To view the status, click on the "Actions" tab in your repository. You should see pending or complete workflows. If you don't, you can manually trigger the "Setup CI" using the Triggers article.
If you've forked the Upptime repository or have rules to disable Actions by default, you'll have to manually enable GitHub Actions, but this should probably not be your case.
Now that you have your Upptime instance fully set up, you should follow these best practices when adding details to outage incidents.
- Upptime will automatically open a new issue when an outage occurs
- If you haven't identified the cause of this outage, you can add a comment like: "Investigating: We're currently investigating the cause of this outage, and we'll update the details here shortly."
- Then, you can add some comments with the details of the outage, and change the name of the issue with the details of the outage
- The issue will be automatically closed when the site comes back up, so you can add a last comment with a postmortem of the outage