With the demise of Openshift Online and its free tier, I was looking for somewhere else to host my blog. Even though it’s a Jekyll blog, it does some image resizing, so I can’t use Github’s native builder. I should be able to use Travis CI though, then push them to another Github repository for Pages hosting.
The Travis instructions for Github Pages instructions suggest you use Github personal access tokens for authentication, but that seems to give write access to all of my Github repositories - which I don’t want to do.
You will need the command line client installed and logged in.
Generate a key pair for Travis to use when pushing
ssh-keygen -t rsa -b 4096 -f travis-key
Don’t commit the generated files!
Create a repository on Github for the generated site to be pushed to. In that repository, go to Settings, Deploy keys, then Add deploy key. Copy in
travis-key.pubwhich you generated in the previous step, check “Enable write access”, then add the key.
The private key should be encrypted. From the blog repository:
travis encrypt-file -r 33d/blog travis-key
travis-keyis one of the files created earlier by
This command will suggest you add a line to your
before_installsection - do that.
Put at the end of
before_install, to stop
ssh-addcomplaining about the key’s permissions:
- chmod 400 ../travis-key
Add this to
.travis.yml, to perform the Git push:
after_success: - eval "$(ssh-agent -s)" - ssh-add ../travis-key - git clone email@example.com:33d/blog-pages.git target - cp -pr _site/* target - git -C target checkout -b gh-pages - git -C target add . - git -C target commit -m "$( date --utc --iso-8601=seconds )" - git -C target push --force origin gh-pages
I use a different repository for this, because I don’t want the build artifacts clogging the blog repository.
You can see my completed