-
Notifications
You must be signed in to change notification settings - Fork 551
如何使用 CircleCI 进行 Gatsby 的持续部署
Today we're going to introduce how to use CircleCI for Continuous Deployment on GitHub Pages.
CircleCI is a CI tool much like Travis CI. But their configurations has many differences. You may find it troublesome first using it.
If you're too busy to read the official doc. This tutorial would be very helpful for you to use as a quick cheatsheet.
Open CircleCI official website and login with your GitHub account.
Check the switch button of the repos you want to manage on CircleCI.
Create a config file for CircleCI named config.yml
in your project root or .circleci
directory.
Firstly you need to set your build environment, this depends on your project language and dependencies:
version: 2
jobs:
build:
docker:
- image: circleci/node:latest
If you want to specify certain branch that fires ci task, you could use filters
:
filters:
branches:
only: master
Then you can configure the commands you want to run on your virtual machine, the commands can be divided by steps
:
steps:
- run:
name: Install some stuff
command: <do-some-stuff>
- run:
name: Deploy if tests pass and branch is Master
command: <my-deploy-commands>
I'm using Gatsby to build my doc site. Here is a full template:
version: 2
jobs:
build:
docker:
- image: circleci/node:latest
filters:
branches:
only: master
steps:
- add_ssh_keys:
fingerprints:
- "xx:xx:xx:xx:11:22:33:44:55:66:77:88:99:xx:xx:xx"
- checkout
- restore_cache:
keys:
- dependencies-{{ checksum "package.json" }}
# fallback to using the latest cache if no exact match is found
- dependencies-
- run:
name: Install
command: yarn install
- save_cache:
paths:
- node_modules
key: dependencies-{{ checksum "package.json" }}
- run:
name: Gatsby build site
command: yarn build
- run:
name: Prepare shell commands
command: cp .scripts/gatsby-deploy.sh ../ && chmod +x ../gatsby-deploy.sh
- run:
name: Run deploy scripts
command: ../gatsby-deploy.sh
For me I have to authorize CircleCI to update gh-pages
automatically. The default ssh key generated before only got the read permission. So we have to add a read/write deployment key manually.
Generate a new ssh key
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
Follow the command-line interactions you'll get two ssh key files id_rsa
& id_rsa.pub
(remember to change the default file location or your local ssh key would be overwritten).
Upload ssh key
-
Upload the
id_rsa.pub
on your GitHub repo settings athttps://github.com/<your_name>/<your_repo>/settings/keys
-
Go to
https://circleci.com/gh/<your_name>/<your_repo>/edit#ssh
on CircleCI and add the private keyid_rsa
that you just created. Entergithub.com
in the Hostname field and press the submit button.
Add ssh key to your config file
Use add_ssh_keys
to set the ssh key you've just added to enable it when running deploy scripts.
- add_ssh_keys:
fingerprints:
- "xx:xx:xx:xx:11:22:33:44:55:66:77:88:99:xx:xx:xx"
Now CircleCI gets the permission to write to your repository, you can use whatever git
commands to manipulate your repo:
git pull
yarn build
git checkout gh-pages
# Add site files...
git push
That's all. You're good to go now. grab a cup of coffee and sit down watch the CircleCI runs.
© 2017 从零学习前端开发 翻译组