Apache cassandra

Clone this repo:
  1. 06395ed ninja-fix to 'Blog Cassandra Usage Report 2020' after staging check: fixing blockquotes and images, from Melissa Logan by mck · 12 days ago master
  2. 9e024b2 Blog Cassandra Usage Report 2020 by Melissa Logan · 2 weeks ago
  3. f211daf Fix 2020-09-03-improving-resiliency.markdown – Reordered post images by mck · 4 weeks ago
  4. 287cc17 Fix 2020-09-03-improving-resiliency.markdown – Reordered post images by Melissa Logan · 4 weeks ago
  5. ed73115 ninja-fix: date amd image links on src/_posts/2020-09-03-improving-resiliency.markdown by mck · 4 weeks ago

Apache Cassandra website

Development Cycle

Making changes to the website is done with the following steps.

  1. Test changes locally
  2. Commit changes in src/ to a fork and branch, and create a pull request
  3. Get the pull request reviewed and merged to master
  4. Preview the rendered site on https://cassandra.staged.apache.org/ (wait til ci-cassandra.apache.org has deployed it)
  5. Merge asf-staging to asf-site
  6. View the rendered site on https://cassandra.apache.org/

To test changes before committing, it is a requirement that you build the website locally. Building the Apache Cassandra website takes a number of steps. To make things easier we have provided a Docker container which can build the full website in two simple commands and have it ready to commit via git. If you are interested in the process head over to the README in src directory.

Building Prerequisites

To build and run the Docker container you will need Docker version or greater. If you need a copy of the site code you will need git as well.

Building the site

If you need a copy of the site code run this command:

$ git clone https://github.com/apache/cassandra-website.git
$ cd ./cassandra-website

To build the website run the following commands from within the ./cassandra-website directory (assuming you used the above clone command):

$ docker-compose build cassandra-website
$ docker-compose run cassandra-website

:warning: Tip: In order to prevent root-owned modified files in your repository, the container user, build, is set up with a default UID=1000:GID=1000, which is usually the first user configured on a linux machine. If your local user is different you should set up the container user with your local host user's UID:GID, replace the above with:

$ docker-compose build --build-arg UID=$(id -u) --build-arg GID=$(id -g) cassandra-website
$ docker-compose run cassandra-website

Go make yourself a cup of coffee, this will take a while...

Once building has completed, the site content will be in the ./cassandra-website/content directory ready to be tested.

Previewing the site

The fastest way to preview the site is to run the following:

$ docker-compose up preview

Then view the site on http://localhost:8000

If you want to preview the site as you are editing it run this command:

$ docker-compose build cassandra-website
$ docker-compose up cassandra-website-serve

For information about the site layout see the Layout section of README in the src directory.

How ci-cassandra.apache.org continuously deploys to cassandra.staged.apache.org

The cassandra-website job on ci-cassandra.apache.org performs the following steps to CD master builds to cassandra.staged.apache.org

git checkout asf-staging
git reset --hard origin/master
docker-compose build --build-arg UID=$(id -u) --build-arg GID=$(id -g) cassandra-website
docker-compose run cassandra-website
#git status
git add content/ src/doc/
git commit -a -m "generate docs for $(git rev-parse --short HEAD)"
#git show --stat HEAD
git push -f origin asf-staging

Publishing to cassandra.apache.org :: Merging asf-staging to asf-site

Updating the main website, after verifying the staged website, involves copying the asf-staging branch to asf-site. A normal git merge is not used, because the asf-staging is forced updated after each ci-cassandra.apache.org build. Instead make live the staged website by copying the asf-staging to the asf-site branch.

git fetch origin
git switch asf-site
git reset --hard origin/asf-staging
git push -f origin asf-site