From 3e2bf545e873080854b9ada4f408be1e03f4a6bc Mon Sep 17 00:00:00 2001 From: leslitagordita Date: Tue, 9 Apr 2019 15:13:07 -0400 Subject: [PATCH 1/7] Draft: Host static site on OS --- .../hugo-index.png | Bin 0 -> 255777 bytes .../host-static-site-object-storage/index.md | 258 ++++++++++++++++++ 2 files changed, 258 insertions(+) create mode 100644 docs/platform/object-storage/host-static-site-object-storage/hugo-index.png create mode 100644 docs/platform/object-storage/host-static-site-object-storage/index.md diff --git a/docs/platform/object-storage/host-static-site-object-storage/hugo-index.png b/docs/platform/object-storage/host-static-site-object-storage/hugo-index.png new file mode 100644 index 0000000000000000000000000000000000000000..7d9f32d3eb7d37e8e23037a25de45026f6d22e72 GIT binary patch literal 255777 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%0A<<%3)A#k^OR64 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%0AA@)h!xMGmU)^}{BTdlXm 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 C!~b#s literal 0 HcmV?d00001 diff --git a/docs/platform/object-storage/host-static-site-object-storage/index.md b/docs/platform/object-storage/host-static-site-object-storage/index.md new file mode 100644 index 00000000000..0cb770e04d9 --- /dev/null +++ b/docs/platform/object-storage/host-static-site-object-storage/index.md @@ -0,0 +1,258 @@ +--- +author: + name: Linode Community + email: docs@linode.com +description: "Host a Static Site using Linode\'s Object Storage." +keywords: ['list','of','keywords','and key phrases'] +license: '[CC BY-ND 4.0](https://creativecommons.org/licenses/by-nd/4.0)' +published: 2019-04-09 +modified: 2019-04-09 +modified_by: + name: Linode +title: "Host a Static Site using Linode's Object Storage" +contributor: + name: Linode +external_resources: +- '[s3cmd Options and Commands](https://s3tools.org/usage)' +- '[s3cmd Sync How-To](https://s3tools.org/s3cmd-sync)' +--- +{{< note >}} +Object Storage is currently in a closed early access Beta, and as such you may not have access to Object Storage through the Cloud Manager or other tools. To gain access to the Early Access Program (EAP), visit the Linode EAP page. + +Additionally, because Object Storage is in Beta, there may be breaking changes to how you access and manage Object Storage. This guide will be updated to reflect these changes if and when they occur. +{{}} + +Static site generators are a popular solution for creating simple, fast, flexible, and attractive websites. You create your site content using markdown, an easy-to-learn and light-weight markup language and the static site generator handles converting your markdown files into static HTML files. + +Using Object Storage to host your static site means you do not have to worry about maintaining your site's infrastructure as you might when hosting a site on a traditional server. It is no longer necessary to perform typical server maintenance tasks, like software and package upgrades, web server configuration, and security upkeep. Object storage provides an HTTP REST gateway to objects, which means a unique URL over HTTP is available for every bucket object. Once your static site is built, making it available publicly over the internet is as easy uploading files to an Object Storage bucket. + +At a high-level, the required steps to host a static site using Object Storage are: + +1. Install the static site generator of your choice to your local computer. +1. Create the desired content and build the site. +1. Upload the static files to your Object storage bucket to make the content publicly available over the internet. + +This guide will use [Hugo](https://gohugo.io/) to demonstrate how to create a static site and host it on Linode's Object Storage. However, there are many static site generators to choose from --[Jekyll](https://jekyllrb.com/) and [Gatsby](https://www.gatsbyjs.org/) are other popular choices. The general steps outlined in this guide can be applied to host any static site on Linode's Object Storage. For more information on choosing a static site generator, see the [How to Choose a Static Site Generator](/docs/websites/static-sites/how-to-choose-static-site-generator/) guide. + +## Before You Begin + +1. Ensure you have read the How to Use Object Storage guide to familiarize yourself with Object Storage on Linode. Be sure you have completed the following steps outlined in that guide: + + - Created your Object Storage access and secret keys. + - Installed [s3cmd CLI](https://s3tools.org/download). + +1. [Install and configure Git](https://linode.com/docs/development/version-control/how-to-install-git-and-clone-a-github-repository/#install-and-configure-git) on your local computer. + +## Install the Hugo Static Site Generator + +Hugo is written in [Go](https://golang.org/) and known for being extremely fast. It is well-supported, [well-documented](https://gohugo.io/documentation/) and has an [active community](https://discourse.gohugo.io/). Some useful Hugo features include *shortcodes*, an easy way to include predefined templates inside of your markdown, and built-in *LiveReload*, which allows you to preview your site changes locally as you make them. + +1. Install the Hugo static site on your computer: + + **macOS** + + - Use the Homebrew package manager for macOS to install Hugo: + + brew install hugo + + **Linux/Ubuntu** + + - Determine your Linux kernel's architecture: + + uname -r + + Your output will resemble the following: + + {{< output >}} + 4.9.0-8-amd64 + {{}} + + - Navigate to [Hugo's GitHub releases page](https://github.com/gohugoio/hugo/releases) download the appropriate version for your platform. + + wget https://github.com/gohugoio/hugo/releases/download/v0.55.0/hugo_0.55.0_Linux-64bit.deb + + - Install the package using `dpkg`: + + sudo dpkg -i hugo*.deb + +1. Verify that Hugo has installed. You should see an output indicating your installed Hugo's version number: + + hugo version + +## Create a Hugo Site + +In this section, you will use the [Hugo CLI](https://gohugo.io/commands/) (command line interface) to create your Hugo site, initialize a Hugo theme, and add content. Hugo's CLI provides several useful commands for common tasks needed to build, configure, and interact with your Hugo site. + +1. Create a new Hugo site on your local computer: + + hugo new site example-site + +1. Move into your Hugo site's root directory. All commands in this section of the guide should be issued from your site's root directory. + + cd example-site + +1. You will use Git to add a theme to your Hugo site's directory. Initialize your Hugo site's directory as a Git repository: + + git init + +1. Install the [Ananke theme](https://github.com/budparr/gohugo-theme-ananke) as a submodule of your Hugo site's Git repository. [Git submodules](https://git-scm.com/book/en/v2/Git-Tools-Submodules) allow one Git repository to be stored as a subdirectory of another Git repository, while still being able to treat each repository separately. Note that the Ananke theme's repository will be located in the `~/example-site/themes/ananke` directory of your Hugo site. + + git submodule add https://github.com/budparr/gohugo-theme-ananke.git themes/ananke + + Hugo has many [available themes](https://themes.gohugo.io/) that can be installed as a submodule of your Hugo site's directory. + +1. Add the theme to your Hugo site's configuration file. The configuration file is located at the root of your Hugo site's directory. + + echo 'theme = "ananke"' >> config.toml + + To learn more about configuring Hugo, see their [official documentation](https://gohugo.io/getting-started/configuration/). + +1. Create a new content file for your site. This command will generate a markdown file with an auto-populated date and title. + + hugo new posts/my-first-post.md + + You should see a similar output. Note that the file is located in the `content/posts/` directory of your Hugo site: + + {{< output >}} + /home/username/example-site/content/posts/my-first-post.md created + {{}} + +1. Open the markdown file in the text editor of your choice to begin modifying its content. You will notice that the file contains *front matter*, which is metadata embedded in your content file within opening and closing `---`. + + Front matter is a powerful Hugo feature that provides a mechanism for passing data that is attached to a specific piece of content to Hugo's rendering engine. Hugo accepts front matter in TOML, YAML, and JSON formats. In this example, there is YAML front matter for the title, date, and draft state of the markdown file. + + Set your desired value for `title`. Then, set the `draft` state to `false` and add your content below the `---` in markdown syntax. The example below contains updated front matter with some example markdown. To learn markdown, consult [Hugo's suggested reading list](https://gohugo.io/content-management/formats/).: + + {{< file "/home/user/example-site/content/posts/my-first-post.md" >}} +--- +title: "My First Post" +date: 2019-04-11T11:25:11-04:00 +draft: false +--- + +# Host a Static Site on Linode's Object Storage + +There are many benefits to using a static site generator. Here is a list of a few of them: + +- Run your own website without having to manage a Linode. +- You don't need to worry about running a web server like Apache or NGINX. +- Static website performance is typically very fast. +- Use Git to version control your static website's content. + {{}} + +1. Once you have added the desired content, you can preview your changes by building and serving the site using Hugo's built-in webserver: + + hugo server + + You will see a similar output: + + {{< output >}} +                   | EN ++------------------+----+ + Pages | 11 + Paginator pages | 0 + Non-page files | 0 + Static files | 3 + Processed images | 0 + Aliases | 1 + Sitemaps | 1 + Cleaned | 0 + +Total in 7 ms +Watching for changes in /Users/lsalazar/hugo-obj/{content,data,layouts,static,themes} +Watching for config changes in /Users/lsalazar/hugo-obj/config.toml +Serving pages from memory +Running in Fast Render Mode. For full rebuilds on change: hugo server --disableFastRender +Web Server is available at http://localhost:1313/ (bind address 127.0.0.1) +Press Ctrl+C to stop + {{}} + + The output will provide a url to preview your site. Copy and paste the url into a browser to access the site. In the above example Hugo's web server url is `http://localhost:1313/`. + +1. When you are happy with your site's content you can *build* your site. This means Hugo will generate your site's static HTML files and store them in a `public` directory that it will create. The static files that are generated by Hugo are the files that you will upload to your Object Storage bucket to make your site accessible via the internet. + + hugo -v + + View the contents of your site's `public` directory: + + ls public + + Your output should resemble the following example. When you built the site, the markdown file you created and edited in steps 6 & 7 was used to generate its corresponding static HTML file in the `public/posts/my-first-post/index.html` directory. + + {{< output >}} + 404.html categories dist images index.html index.xml posts sitemap.xml tags + {{}} + + {{< disclosure-note "Track your Static Site Files with Git">}} + While it is not necessary to version control your local Hugo site files with Git in order to host a static site on Linode's Object Storage, it is recommended to do so. + + 1. Display the state of your current working directory (root of your Hugo site): + + git status + + 1. Stage all your files to be committed: + + git add -A + + 1. Commit all your changes and add a meaningful commit message: + + git commit -m 'Add my first post.' + + Once you have used Git to track your local Hugo site files, you can easily push them to a remote Git repository, like [GitHub](https://github.com/) or [GitLab](https://about.gitlab.com/). Storing your static site files on a remote Git repository opens up many possibilities for collaboration and automating your static site's deployment to Linode's Object storage. To learn more about Git, see the [Getting Started with Git](/docs/development/version-control/how-to-configure-git/) guide. + {{}} + +## Upload your Static Site to Linode's Object Storage + +Before proceeding with this section ensure that you have already created your Object Storage access and secret keys and have installed the s3cmd CLI. + +1. Create a new Object Storage bucket: + + s3cmd mb my-bucket + +1. Initialize your Object Storage bucket as a website. You must tell your bucket which file to server as the index page and the error page for your static site. This is done with the `--ws-index` and `--ws-error` options. In our Hugo example, the site's index file is `index.html` and the error file is `404.html`. Whenever a user visits your static site's URL, the Object Storage service will serve the `index.html` page. If a site visitor tries to access an invalid path, they will be presented with the `404.html` page. + + s3cmd ws-create --ws-index=index.html --ws-error=404.html s3://my-bucket + + The command will return the following message: + + {{< output >}} + Bucket 's3://my-bucket/': website configuration created. + {{}} + +1. Display information about your Object Storage's website configuration to obtain your site's URL: + + s3cmd ws-info s3://my-bucket + + You should see a similar output. Be sure to take not of your Object Storage bucket's URL: + + {{< output >}} + Bucket s3://ss-6/: Website configuration +Website endpoint: http://my-bucket.alpha-website.linodeobjects.com/ +Index document: index.html +Error document: 404.html + {{}} + + {{< note >}} + Linode's Object Storage early access Beta provides SSL enabled by default. This means you can access your Object Storage bucket using `https`, as well. + {{}} + +1. Use s3cmd's `sync` command to upload the contents of your static site's `public` directory to your Object storage bucket. This step will make your site available publicly on the internet. Ensure you are at your site's root directory `/home/user/example-site`. + + s3cmd --no-mime-magic --acl-public --delete-removed --delete-after sync public/ s3://my-bucket + + The following options are added to the sync command: + - `no-mime-magic`: tells Object Storage not to use file signatures when guessing the object's MIME-type. + - `acl-public`: this sets the access level control of the objects to public. + - `delete-removed`: deletes any destination objects with no corresponding source file. + - `delete-after`: deletes destination files that are no longer found at the source after all files are uploaded to the bucket. + +1. Use a browser to navigate to your Object Storage bucket's URL to view your Hugo site: + + ![Hugo Index Page](hugo-index.png) + + If needed, you can continue to update your static site locally and upload any changes using s3cmd's `sync` command from step 3 of this section. + +## *Optional* Next Steps + +After uploading your static site to Linode's Object Storage, you may want to use a custom domain for your site. To do this, you can add a CNAME entry to your domain's DNS record that aliases it to your Object Storage bucket's URL. To learn about DNS records on Linode, see the [DNS Records: An Introduction](/docs/networking/dns/dns-records-an-introduction/) guide. + From dd4363b542b8eeceb6e90ee8b75a5628ec4c960d Mon Sep 17 00:00:00 2001 From: Andy Stevens Date: Mon, 15 Apr 2019 15:02:35 -0400 Subject: [PATCH 2/7] Tech Edit --- .../host-static-site-object-storage/index.md | 40 ++++++++++--------- 1 file changed, 22 insertions(+), 18 deletions(-) diff --git a/docs/platform/object-storage/host-static-site-object-storage/index.md b/docs/platform/object-storage/host-static-site-object-storage/index.md index 0cb770e04d9..7153ed72975 100644 --- a/docs/platform/object-storage/host-static-site-object-storage/index.md +++ b/docs/platform/object-storage/host-static-site-object-storage/index.md @@ -22,24 +22,24 @@ Object Storage is currently in a closed early access Beta, and as such you may n Additionally, because Object Storage is in Beta, there may be breaking changes to how you access and manage Object Storage. This guide will be updated to reflect these changes if and when they occur. {{}} -Static site generators are a popular solution for creating simple, fast, flexible, and attractive websites. You create your site content using markdown, an easy-to-learn and light-weight markup language and the static site generator handles converting your markdown files into static HTML files. +Static site generators are a popular solution for creating simple, fast, flexible, and attractive websites. You create your site content using markdown, an easy-to-learn and light-weight markup language, and the static site generator handles converting your markdown files into static HTML files. -Using Object Storage to host your static site means you do not have to worry about maintaining your site's infrastructure as you might when hosting a site on a traditional server. It is no longer necessary to perform typical server maintenance tasks, like software and package upgrades, web server configuration, and security upkeep. Object storage provides an HTTP REST gateway to objects, which means a unique URL over HTTP is available for every bucket object. Once your static site is built, making it available publicly over the internet is as easy uploading files to an Object Storage bucket. +Using Object Storage to host your static site means you do not have to worry about maintaining your site's infrastructure as you might when hosting a site on a traditional server. It is no longer necessary to perform typical server maintenance tasks, like software and package upgrades, web server configuration, and security upkeep. Object storage provides an HTTP REST gateway to objects, which means a unique URL over HTTP is available for every object. Once your static site is built, making it available publicly over the internet is as easy uploading files to an Object Storage bucket. At a high-level, the required steps to host a static site using Object Storage are: 1. Install the static site generator of your choice to your local computer. -1. Create the desired content and build the site. -1. Upload the static files to your Object storage bucket to make the content publicly available over the internet. +2. Create the desired content and build the site. +3. Upload the static files to your Object storage bucket to make the content publicly available over the internet. -This guide will use [Hugo](https://gohugo.io/) to demonstrate how to create a static site and host it on Linode's Object Storage. However, there are many static site generators to choose from --[Jekyll](https://jekyllrb.com/) and [Gatsby](https://www.gatsbyjs.org/) are other popular choices. The general steps outlined in this guide can be applied to host any static site on Linode's Object Storage. For more information on choosing a static site generator, see the [How to Choose a Static Site Generator](/docs/websites/static-sites/how-to-choose-static-site-generator/) guide. +This guide will use [Hugo](https://gohugo.io/) to demonstrate how to create a static site and host it on Linode's Object Storage. However, there are many static site generators to choose from -- [Jekyll](https://jekyllrb.com/) and [Gatsby](https://www.gatsbyjs.org/) are other popular choices. The general steps outlined in this guide can be applied to host any static site on Linode's Object Storage. For more information on choosing a static site generator, see the [How to Choose a Static Site Generator](/docs/websites/static-sites/how-to-choose-static-site-generator/) guide. ## Before You Begin -1. Ensure you have read the How to Use Object Storage guide to familiarize yourself with Object Storage on Linode. Be sure you have completed the following steps outlined in that guide: +1. Ensure you have read the [How to Use Object Storage](/docs/platform/object-storage/how-to-use-object-storage) guide to familiarize yourself with Object Storage on Linode. Be sure you have completed the following steps outlined in that guide: - Created your Object Storage access and secret keys. - - Installed [s3cmd CLI](https://s3tools.org/download). + - Installed and configure [s3cmd CLI](https://s3tools.org/download). 1. [Install and configure Git](https://linode.com/docs/development/version-control/how-to-install-git-and-clone-a-github-repository/#install-and-configure-git) on your local computer. @@ -121,7 +121,7 @@ In this section, you will use the [Hugo CLI](https://gohugo.io/commands/) (comma Front matter is a powerful Hugo feature that provides a mechanism for passing data that is attached to a specific piece of content to Hugo's rendering engine. Hugo accepts front matter in TOML, YAML, and JSON formats. In this example, there is YAML front matter for the title, date, and draft state of the markdown file. - Set your desired value for `title`. Then, set the `draft` state to `false` and add your content below the `---` in markdown syntax. The example below contains updated front matter with some example markdown. To learn markdown, consult [Hugo's suggested reading list](https://gohugo.io/content-management/formats/).: + Set your desired value for `title`. Then, set the `draft` state to `false` and add your content below the `---` in markdown syntax. The example below contains updated front matter with some example markdown. To learn markdown, consult [Hugo's suggested reading list](https://gohugo.io/content-management/formats/): {{< file "/home/user/example-site/content/posts/my-first-post.md" >}} --- @@ -167,15 +167,15 @@ Web Server is available at http://localhost:1313/ (bind address 127.0.0.1) Press Ctrl+C to stop {{}} - The output will provide a url to preview your site. Copy and paste the url into a browser to access the site. In the above example Hugo's web server url is `http://localhost:1313/`. + The output will provide a URL to preview your site. Copy and paste the URL into a browser to access the site. In the above example Hugo's web server URL is `http://localhost:1313/`. 1. When you are happy with your site's content you can *build* your site. This means Hugo will generate your site's static HTML files and store them in a `public` directory that it will create. The static files that are generated by Hugo are the files that you will upload to your Object Storage bucket to make your site accessible via the internet. - hugo -v + hugo -v View the contents of your site's `public` directory: - ls public + ls public Your output should resemble the following example. When you built the site, the markdown file you created and edited in steps 6 & 7 was used to generate its corresponding static HTML file in the `public/posts/my-first-post/index.html` directory. @@ -190,11 +190,11 @@ Press Ctrl+C to stop git status - 1. Stage all your files to be committed: + 2. Stage all your files to be committed: git add -A - 1. Commit all your changes and add a meaningful commit message: + 3. Commit all your changes and add a meaningful commit message: git commit -m 'Add my first post.' @@ -205,11 +205,15 @@ Press Ctrl+C to stop Before proceeding with this section ensure that you have already created your Object Storage access and secret keys and have installed the s3cmd CLI. -1. Create a new Object Storage bucket: +1. Create a new Object Storage bucket, appending `s3://` to the beginning of the bucket's name: - s3cmd mb my-bucket + s3cmd mb s3://my-bucket -1. Initialize your Object Storage bucket as a website. You must tell your bucket which file to server as the index page and the error page for your static site. This is done with the `--ws-index` and `--ws-error` options. In our Hugo example, the site's index file is `index.html` and the error file is `404.html`. Whenever a user visits your static site's URL, the Object Storage service will serve the `index.html` page. If a site visitor tries to access an invalid path, they will be presented with the `404.html` page. + {{< note >}} +Buckets names must be unique within the Object Storage cluster. You might find the bucket name `my-bucket` is already in use, in which case you will need to choose a new bucket name. +{{}} + +1. Initialize your Object Storage bucket as a website. You must tell your bucket which files to serve as the index page and the error page for your static site. This is done with the `--ws-index` and `--ws-error` options. In our Hugo example, the site's index file is `index.html` and the error file is `404.html`. Whenever a user visits your static site's URL, the Object Storage service will serve the `index.html` page. If a site visitor tries to access an invalid path, they will be presented with the `404.html` page. s3cmd ws-create --ws-index=index.html --ws-error=404.html s3://my-bucket @@ -223,10 +227,10 @@ Before proceeding with this section ensure that you have already created your Ob s3cmd ws-info s3://my-bucket - You should see a similar output. Be sure to take not of your Object Storage bucket's URL: + You should see a similar output. Be sure to take note of your Object Storage bucket's URL: {{< output >}} - Bucket s3://ss-6/: Website configuration + Bucket s3://my-bucket/: Website configuration Website endpoint: http://my-bucket.alpha-website.linodeobjects.com/ Index document: index.html Error document: 404.html From 4b7d1249c3e254f09bf924cf8738f0bacd238b40 Mon Sep 17 00:00:00 2001 From: nmelehan Date: Tue, 23 Apr 2019 17:46:41 -0400 Subject: [PATCH 3/7] Copy edit Also updated terms.yml to prefer Markdown over markdown --- ci/vale/styles/Linode/Terms.yml | 1 + .../host-static-site-object-storage/index.md | 191 +++++++++++------- 2 files changed, 114 insertions(+), 78 deletions(-) diff --git a/ci/vale/styles/Linode/Terms.yml b/ci/vale/styles/Linode/Terms.yml index 74326d97d95..65a727b12fd 100644 --- a/ci/vale/styles/Linode/Terms.yml +++ b/ci/vale/styles/Linode/Terms.yml @@ -33,3 +33,4 @@ swap: yaml: YAML urls: URLs uris: URIs + markdown: Markdown diff --git a/docs/platform/object-storage/host-static-site-object-storage/index.md b/docs/platform/object-storage/host-static-site-object-storage/index.md index 7153ed72975..7a804f3a360 100644 --- a/docs/platform/object-storage/host-static-site-object-storage/index.md +++ b/docs/platform/object-storage/host-static-site-object-storage/index.md @@ -9,53 +9,70 @@ published: 2019-04-09 modified: 2019-04-09 modified_by: name: Linode -title: "Host a Static Site using Linode's Object Storage" +title: "Host a Static Site using Linode Object Storage" contributor: name: Linode external_resources: +- '[Hugo Documentation](https://gohugo.io/documentation/)' - '[s3cmd Options and Commands](https://s3tools.org/usage)' - '[s3cmd Sync How-To](https://s3tools.org/s3cmd-sync)' --- {{< note >}} -Object Storage is currently in a closed early access Beta, and as such you may not have access to Object Storage through the Cloud Manager or other tools. To gain access to the Early Access Program (EAP), visit the Linode EAP page. +Object Storage is currently in a closed early access Beta, and you may not have access to Object Storage through the Cloud Manager or other tools. To gain access to the Early Access Program (EAP), visit the Linode EAP page. Additionally, because Object Storage is in Beta, there may be breaking changes to how you access and manage Object Storage. This guide will be updated to reflect these changes if and when they occur. {{}} -Static site generators are a popular solution for creating simple, fast, flexible, and attractive websites. You create your site content using markdown, an easy-to-learn and light-weight markup language, and the static site generator handles converting your markdown files into static HTML files. +## Why Host a Static Site on Object Storage? -Using Object Storage to host your static site means you do not have to worry about maintaining your site's infrastructure as you might when hosting a site on a traditional server. It is no longer necessary to perform typical server maintenance tasks, like software and package upgrades, web server configuration, and security upkeep. Object storage provides an HTTP REST gateway to objects, which means a unique URL over HTTP is available for every object. Once your static site is built, making it available publicly over the internet is as easy uploading files to an Object Storage bucket. +[Static site generators](/docs/websites/static-sites/how-to-choose-static-site-generator/) are a popular solution for creating simple, fast, flexible, and attractive websites that are easy to update. You can contribute new pages and content to a static site in two steps: + +1. First, write the content for your site's new page using [Markdown](https://www.markdownguide.org), an easy-to-learn and light-weight markup language. + +1. Then, tell your static site generator to compile your Markdown (along with other relevant assets, like CSS styling, images, and JavaScript) into static HTML files. + +The second compilation step only needs to happen once for each time that you update your content. This is in contrast with a dynamic website framework like WordPress or Drupal, which will reference a relational database and compile your HTML every time a visitor loads your site. + +### Benefits of Hosting on Object Storage + +Traditionally, these static HTML files would be served by a web server (like [NGINX](/docs/web-servers/nginx/) or [Apache](/docs/web-servers/apache/)) running on a Linode. Using Object Storage to host your static site files means you do not have to worry about maintaining your site's infrastructure. It is no longer necessary to perform typical server maintenance tasks, like software upgrades, web server configuration, and security upkeep. + +Object Storage provides an HTTP REST gateway to objects, which means a unique URL over HTTP is available for every object. Once your static site is built, making it available publicly over the Internet is as easy uploading files to an Object Storage bucket. + +### Object Storage Hosting Workflow At a high-level, the required steps to host a static site using Object Storage are: -1. Install the static site generator of your choice to your local computer. -2. Create the desired content and build the site. -3. Upload the static files to your Object storage bucket to make the content publicly available over the internet. +1. [Install](#install-the-hugo-static-site-generator) the static site generator of your choice to your local computer. + +1. [Create](#create-a-hugo-site) the desired content and build the site (using your static site generator). + +1. [Upload](#upload-your-static-site-to-linode-s-object-storage) the static files to your Object Storage bucket to make the content publicly available over the Internet. -This guide will use [Hugo](https://gohugo.io/) to demonstrate how to create a static site and host it on Linode's Object Storage. However, there are many static site generators to choose from -- [Jekyll](https://jekyllrb.com/) and [Gatsby](https://www.gatsbyjs.org/) are other popular choices. The general steps outlined in this guide can be applied to host any static site on Linode's Object Storage. For more information on choosing a static site generator, see the [How to Choose a Static Site Generator](/docs/websites/static-sites/how-to-choose-static-site-generator/) guide. +This guide will use [Hugo](https://gohugo.io/) to demonstrate how to create a static site and host it on Linode Object Storage. However, there are [many other static site generators](https://www.staticgen.com) to choose from--[Jekyll](https://jekyllrb.com/) and [Gatsby](https://www.gatsbyjs.org/) are popular choices, and the general steps outlined in this guide could be adapted to them. For more information on choosing a static site generator, see the [How to Choose a Static Site Generator](/docs/websites/static-sites/how-to-choose-static-site-generator/) guide. ## Before You Begin -1. Ensure you have read the [How to Use Object Storage](/docs/platform/object-storage/how-to-use-object-storage) guide to familiarize yourself with Object Storage on Linode. Be sure you have completed the following steps outlined in that guide: +1. Read the [How to Use Object Storage](/docs/platform/object-storage/how-to-use-object-storage) guide to familiarize yourself with Object Storage on Linode. Specifically, be sure that you have: - Created your Object Storage access and secret keys. - - Installed and configure [s3cmd CLI](https://s3tools.org/download). + - Installed and configure the [s3cmd tool](https://s3tools.org/download). 1. [Install and configure Git](https://linode.com/docs/development/version-control/how-to-install-git-and-clone-a-github-repository/#install-and-configure-git) on your local computer. ## Install the Hugo Static Site Generator -Hugo is written in [Go](https://golang.org/) and known for being extremely fast. It is well-supported, [well-documented](https://gohugo.io/documentation/) and has an [active community](https://discourse.gohugo.io/). Some useful Hugo features include *shortcodes*, an easy way to include predefined templates inside of your markdown, and built-in *LiveReload*, which allows you to preview your site changes locally as you make them. +Hugo is written in [Go](https://golang.org/) and is known for being extremely fast to compile sites, even very large ones. It is well-supported, [well-documented](https://gohugo.io/documentation/), and has an [active community](https://discourse.gohugo.io/). Some useful Hugo features include [*shortcodes*](https://gohugo.io/content-management/shortcodes/), which are an easy way to include predefined templates inside of your Markdown, and built-in [*LiveReload*](https://gohugo.io/getting-started/usage/#livereload) web server, which allows you to preview your site changes locally as you make them. -1. Install the Hugo static site on your computer: +1. Install Hugo on your computer: - **macOS** + **macOS**: - Use the Homebrew package manager for macOS to install Hugo: brew install hugo - **Linux/Ubuntu** + **Linux/Ubuntu**: - Determine your Linux kernel's architecture: @@ -64,10 +81,10 @@ Hugo is written in [Go](https://golang.org/) and known for being extremely fast. Your output will resemble the following: {{< output >}} - 4.9.0-8-amd64 - {{}} +4.9.0-8-amd64 +{{}} - - Navigate to [Hugo's GitHub releases page](https://github.com/gohugoio/hugo/releases) download the appropriate version for your platform. + - Navigate to [Hugo's GitHub releases page](https://github.com/gohugoio/hugo/releases) and download the appropriate version for your platform. This example command downloads version 0.55, but a newer release may be available: wget https://github.com/gohugoio/hugo/releases/download/v0.55.0/hugo_0.55.0_Linux-64bit.deb @@ -75,62 +92,64 @@ Hugo is written in [Go](https://golang.org/) and known for being extremely fast. sudo dpkg -i hugo*.deb -1. Verify that Hugo has installed. You should see an output indicating your installed Hugo's version number: +1. Verify that Hugo is installed. You should see output indicating your installed Hugo's version number: hugo version ## Create a Hugo Site -In this section, you will use the [Hugo CLI](https://gohugo.io/commands/) (command line interface) to create your Hugo site, initialize a Hugo theme, and add content. Hugo's CLI provides several useful commands for common tasks needed to build, configure, and interact with your Hugo site. +In this section, you will use the [Hugo CLI](https://gohugo.io/commands/) (command line interface) to create your Hugo site, initialize a Hugo theme, and add content to your site. Hugo's CLI provides several useful commands for common tasks needed to build, configure, and interact with your Hugo site. -1. Create a new Hugo site on your local computer: +1. Create a new Hugo site on your local computer. This command will create a folder named `example-site` and scaffold [Hugo's directory structure](https://gohugo.io/getting-started/directory-structure/) inside it: hugo new site example-site -1. Move into your Hugo site's root directory. All commands in this section of the guide should be issued from your site's root directory. +1. Move into your Hugo site's root directory: cd example-site + {{< note >}} +All commands in this section of the guide should be issued from your site's root directory. +{{< /note >}} + 1. You will use Git to add a theme to your Hugo site's directory. Initialize your Hugo site's directory as a Git repository: git init -1. Install the [Ananke theme](https://github.com/budparr/gohugo-theme-ananke) as a submodule of your Hugo site's Git repository. [Git submodules](https://git-scm.com/book/en/v2/Git-Tools-Submodules) allow one Git repository to be stored as a subdirectory of another Git repository, while still being able to treat each repository separately. Note that the Ananke theme's repository will be located in the `~/example-site/themes/ananke` directory of your Hugo site. +1. Install the [Ananke theme](https://github.com/budparr/gohugo-theme-ananke) as a submodule of your Hugo site's Git repository. [Git submodules](https://git-scm.com/book/en/v2/Git-Tools-Submodules) allow one Git repository to be stored as a subdirectory of another Git repository, while still being able to maintain each repository's version control information separately. The Ananke theme's repository will be located in the `~/example-site/themes/ananke` directory of your Hugo site. git submodule add https://github.com/budparr/gohugo-theme-ananke.git themes/ananke - Hugo has many [available themes](https://themes.gohugo.io/) that can be installed as a submodule of your Hugo site's directory. + {{< note >}} +Hugo has many [available themes](https://themes.gohugo.io/) that can be installed as a submodule of your Hugo site's directory. +{{< /note >}} -1. Add the theme to your Hugo site's configuration file. The configuration file is located at the root of your Hugo site's directory. +1. Add the theme to your Hugo site's [configuration file](https://gohugo.io/getting-started/configuration/). The configuration file (`config.toml`) is located at the root of your Hugo site's directory. echo 'theme = "ananke"' >> config.toml - To learn more about configuring Hugo, see their [official documentation](https://gohugo.io/getting-started/configuration/). - -1. Create a new content file for your site. This command will generate a markdown file with an auto-populated date and title. +1. Create a new content file for your site. This command will generate a Markdown file with an auto-populated date and title: hugo new posts/my-first-post.md - You should see a similar output. Note that the file is located in the `content/posts/` directory of your Hugo site: +1. You should see a similar output. Note that the file is located in the `content/posts/` directory of your Hugo site: {{< output >}} - /home/username/example-site/content/posts/my-first-post.md created - {{}} - -1. Open the markdown file in the text editor of your choice to begin modifying its content. You will notice that the file contains *front matter*, which is metadata embedded in your content file within opening and closing `---`. +/home/username/example-site/content/posts/my-first-post.md created +{{}} - Front matter is a powerful Hugo feature that provides a mechanism for passing data that is attached to a specific piece of content to Hugo's rendering engine. Hugo accepts front matter in TOML, YAML, and JSON formats. In this example, there is YAML front matter for the title, date, and draft state of the markdown file. +1. Open the Markdown file in the text editor of your choice to begin modifying its content; you can copy and paste the example snippet into your file, which contains an updated *front matter* section at the top and some example Markdown body text. - Set your desired value for `title`. Then, set the `draft` state to `false` and add your content below the `---` in markdown syntax. The example below contains updated front matter with some example markdown. To learn markdown, consult [Hugo's suggested reading list](https://gohugo.io/content-management/formats/): + Set your desired value for `title`. Then, set the `draft` state to `false` and add your content below the `---` in Markdown syntax, if desired: - {{< file "/home/user/example-site/content/posts/my-first-post.md" >}} + {{< file "/home/username/example-site/content/posts/my-first-post.md" >}} --- title: "My First Post" date: 2019-04-11T11:25:11-04:00 draft: false --- -# Host a Static Site on Linode's Object Storage +# Host a Static Site on Linode Object Storage There are many benefits to using a static site generator. Here is a list of a few of them: @@ -138,86 +157,96 @@ There are many benefits to using a static site generator. Here is a list of a fe - You don't need to worry about running a web server like Apache or NGINX. - Static website performance is typically very fast. - Use Git to version control your static website's content. - {{}} +{{}} -1. Once you have added the desired content, you can preview your changes by building and serving the site using Hugo's built-in webserver: + {{< disclosure-note "About front matter" >}} +[*Front matter*](https://gohugo.io/content-management/front-matter/) is a collection of metadata about your content, and it is embedded at the top of your file within opening and closing `---` delimiters. + +Front matter is a powerful Hugo feature that provides a mechanism for passing data that is attached to a specific piece of content to Hugo's rendering engine. Hugo accepts front matter in TOML, YAML, and JSON formats. In the example snippet, there is YAML front matter for the title, date, and draft state of the Markdown file. These variables will be referenced and displayed by your Hugo theme. +{{< /disclosure-note >}} + +1. Once you have added your content, you can preview your changes by building and serving the site using Hugo's built-in webserver: hugo server - You will see a similar output: +1. You will see a similar output: {{< output >}}                    | EN +------------------+----+ - Pages | 11 - Paginator pages | 0 - Non-page files | 0 - Static files | 3 - Processed images | 0 - Aliases | 1 - Sitemaps | 1 - Cleaned | 0 + Pages              | 11 + Paginator pages    | 0 + Non-page files     | 0 + Static files       | 3 + Processed images   | 0 + Aliases            | 1 + Sitemaps           | 1 + Cleaned            | 0 Total in 7 ms -Watching for changes in /Users/lsalazar/hugo-obj/{content,data,layouts,static,themes} -Watching for config changes in /Users/lsalazar/hugo-obj/config.toml +Watching for changes in /home/username/example-site/{content,data,layouts,static,themes} +Watching for config changes in /home/username/example-site/config.toml Serving pages from memory Running in Fast Render Mode. For full rebuilds on change: hugo server --disableFastRender Web Server is available at http://localhost:1313/ (bind address 127.0.0.1) Press Ctrl+C to stop - {{}} +{{}} - The output will provide a URL to preview your site. Copy and paste the URL into a browser to access the site. In the above example Hugo's web server URL is `http://localhost:1313/`. +1. The output will provide a URL to preview your site. Copy and paste the URL into a browser to access the site. In the above example Hugo's web server URL is `http://localhost:1313/`. -1. When you are happy with your site's content you can *build* your site. This means Hugo will generate your site's static HTML files and store them in a `public` directory that it will create. The static files that are generated by Hugo are the files that you will upload to your Object Storage bucket to make your site accessible via the internet. +1. When you are happy with your site's content you can *build* your site: hugo -v - View the contents of your site's `public` directory: + Hugo will generate your site's static HTML files and store them in a `public` directory that it will create inside your project. The static files that are generated by Hugo are the files that you will upload to your Object Storage bucket to make your site accessible via the Internet. + +1. View the contents of your site's `public` directory: ls public - Your output should resemble the following example. When you built the site, the markdown file you created and edited in steps 6 & 7 was used to generate its corresponding static HTML file in the `public/posts/my-first-post/index.html` directory. + Your output should resemble the following example. When you built the site, the Markdown file you created and edited in steps 6 and 7 was used to generate its corresponding static HTML file in the `public/posts/my-first-post/index.html` directory. {{< output >}} 404.html categories dist images index.html index.xml posts sitemap.xml tags {{}} {{< disclosure-note "Track your Static Site Files with Git">}} - While it is not necessary to version control your local Hugo site files with Git in order to host a static site on Linode's Object Storage, it is recommended to do so. +It's not necessary to version control your site files in order to host them on Object Storage, but we still recommended that you do so: - 1. Display the state of your current working directory (root of your Hugo site): +1. Display the state of your current working directory (root of your Hugo site): git status - 2. Stage all your files to be committed: +2. Stage all your files to be committed: git add -A - 3. Commit all your changes and add a meaningful commit message: +3. Commit all your changes and add a meaningful commit message: git commit -m 'Add my first post.' - Once you have used Git to track your local Hugo site files, you can easily push them to a remote Git repository, like [GitHub](https://github.com/) or [GitLab](https://about.gitlab.com/). Storing your static site files on a remote Git repository opens up many possibilities for collaboration and automating your static site's deployment to Linode's Object storage. To learn more about Git, see the [Getting Started with Git](/docs/development/version-control/how-to-configure-git/) guide. - {{}} +Once you have used Git to track your local Hugo site files, you can easily push them to a remote Git repository, like [GitHub](https://github.com/) or [GitLab](https://about.gitlab.com/). Storing your static site files on a remote Git repository opens up many possibilities for collaboration and automating your static site's deployment to Linode Object Storage. To learn more about Git, see the [Getting Started with Git](/docs/development/version-control/how-to-configure-git/) guide. +{{}} -## Upload your Static Site to Linode's Object Storage +## Upload your Static Site to Linode Object Storage -Before proceeding with this section ensure that you have already created your Object Storage access and secret keys and have installed the s3cmd CLI. +Before proceeding with this section ensure that you have already created your Object Storage access and secret keys and have installed the s3cmd tool. -1. Create a new Object Storage bucket, appending `s3://` to the beginning of the bucket's name: +1. Create a new Object Storage bucket; prepend `s3://` to the beginning of the bucket's name: s3cmd mb s3://my-bucket {{< note >}} -Buckets names must be unique within the Object Storage cluster. You might find the bucket name `my-bucket` is already in use, in which case you will need to choose a new bucket name. +Buckets names must be unique within the Object Storage cluster. You might find the bucket name `my-bucket` is already in use by another Linode customer, in which case you will need to choose a new bucket name. {{}} -1. Initialize your Object Storage bucket as a website. You must tell your bucket which files to serve as the index page and the error page for your static site. This is done with the `--ws-index` and `--ws-error` options. In our Hugo example, the site's index file is `index.html` and the error file is `404.html`. Whenever a user visits your static site's URL, the Object Storage service will serve the `index.html` page. If a site visitor tries to access an invalid path, they will be presented with the `404.html` page. +1. Initialize your Object Storage bucket as a website. You must tell your bucket which files to serve as the index page and the error page for your static site. This is done with the `--ws-index` and `--ws-error` options: s3cmd ws-create --ws-index=index.html --ws-error=404.html s3://my-bucket - The command will return the following message: + In our Hugo example, the site's index file is `index.html` and the error file is `404.html`. Whenever a user visits your static site's URL, the Object Storage service will serve the `index.html` page. If a site visitor tries to access an invalid path, they will be presented with the `404.html` page. + +1. The command will return the following message: {{< output >}} Bucket 's3://my-bucket/': website configuration created. @@ -227,7 +256,7 @@ Buckets names must be unique within the Object Storage cluster. You might find t s3cmd ws-info s3://my-bucket - You should see a similar output. Be sure to take note of your Object Storage bucket's URL: +1. You should see a similar output. Be sure to take note of your Object Storage bucket's URL: {{< output >}} Bucket s3://my-bucket/: Website configuration @@ -237,26 +266,32 @@ Error document: 404.html {{}} {{< note >}} - Linode's Object Storage early access Beta provides SSL enabled by default. This means you can access your Object Storage bucket using `https`, as well. - {{}} +The Linode Object Storage early access Beta provides SSL enabled by default. This means you can access your Object Storage bucket using `https`, as well. +{{}} -1. Use s3cmd's `sync` command to upload the contents of your static site's `public` directory to your Object storage bucket. This step will make your site available publicly on the internet. Ensure you are at your site's root directory `/home/user/example-site`. +1. Use s3cmd's `sync` command to upload the contents of your static site's `public` directory to your Object Storage bucket. This step will make your site available publicly on the Internet. Ensure you are in your site's root directory on your computer (e.g. `/home/username/example-site`): s3cmd --no-mime-magic --acl-public --delete-removed --delete-after sync public/ s3://my-bucket - The following options are added to the sync command: - - `no-mime-magic`: tells Object Storage not to use file signatures when guessing the object's MIME-type. - - `acl-public`: this sets the access level control of the objects to public. - - `delete-removed`: deletes any destination objects with no corresponding source file. - - `delete-after`: deletes destination files that are no longer found at the source after all files are uploaded to the bucket. + | Option                          | Description | + |--------|-------------| + | `no-mime-magic` | Tells Object Storage not to use file signatures when guessing the object's MIME-type. | + | `acl-public` | Sets the access level control of the objects to public. | + | `delete-removed` | Deletes any destination objects with no corresponding source file. | + | `delete-after` | Deletes destination files that are no longer found at the source after all files are uploaded to the bucket. | 1. Use a browser to navigate to your Object Storage bucket's URL to view your Hugo site: ![Hugo Index Page](hugo-index.png) - If needed, you can continue to update your static site locally and upload any changes using s3cmd's `sync` command from step 3 of this section. + {{< note >}} +It may take a minute or two after your s3cmd sync completes for the page to appear at your bucket's website URL. +{{< /note >}} + +1. If needed, you can continue to update your static site locally and upload any changes using s3cmd's `sync` command from step 3 of this section. -## *Optional* Next Steps +## (Optional) Next Steps -After uploading your static site to Linode's Object Storage, you may want to use a custom domain for your site. To do this, you can add a CNAME entry to your domain's DNS record that aliases it to your Object Storage bucket's URL. To learn about DNS records on Linode, see the [DNS Records: An Introduction](/docs/networking/dns/dns-records-an-introduction/) guide. +After uploading your static site to Linode Object Storage, you may want to use a custom domain for your site. To do this, you can add a CNAME entry to your domain's DNS records that aliases it to your Object Storage bucket's website URL. To learn about managing DNS records on Linode, see the [DNS Manager](/docs/platform/manager/dns-manager/) and [DNS Records: An Introduction](/docs/networking/dns/dns-records-an-introduction/) guides. +As noted before, it's possible to trigger automatic deployments to the Object Storage service when you push new content updates to GitHub or GitLab. This is done by leveraging a CI/CD (continuous integration/continuous delivery) tool like [Travis CI](https://travis-ci.org). Essentially, you would build your Hugo site within the Travis environment and then run the `s3cmd sync` command from it to your bucket. \ No newline at end of file From 6b6f020623a12d880596483a20b68f303bd1d7a7 Mon Sep 17 00:00:00 2001 From: hzoppetti Date: Tue, 11 Jun 2019 12:37:15 -0400 Subject: [PATCH 4/7] removed link to other object storage guide until that one is added --- .../object-storage/host-static-site-object-storage/index.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/platform/object-storage/host-static-site-object-storage/index.md b/docs/platform/object-storage/host-static-site-object-storage/index.md index 7a804f3a360..7cc75483284 100644 --- a/docs/platform/object-storage/host-static-site-object-storage/index.md +++ b/docs/platform/object-storage/host-static-site-object-storage/index.md @@ -53,7 +53,7 @@ This guide will use [Hugo](https://gohugo.io/) to demonstrate how to create a st ## Before You Begin -1. Read the [How to Use Object Storage](/docs/platform/object-storage/how-to-use-object-storage) guide to familiarize yourself with Object Storage on Linode. Specifically, be sure that you have: +1. Read the [How to Use Object Storage]() guide to familiarize yourself with Object Storage on Linode. Specifically, be sure that you have: - Created your Object Storage access and secret keys. - Installed and configure the [s3cmd tool](https://s3tools.org/download). From b7112352787bb928959871f659d0ccd2036cf69b Mon Sep 17 00:00:00 2001 From: hzoppetti Date: Tue, 11 Jun 2019 14:21:17 -0400 Subject: [PATCH 5/7] updating 4 guides with cap Markdown re Object Storage guide updated rules --- .../index.md | 6 +++--- .../index.md | 2 +- .../jupyter-notebook-on-jekyll/index.md | 12 ++++++------ docs/linode-writers-formatting-guide/index.md | 6 +++--- 4 files changed, 13 insertions(+), 13 deletions(-) diff --git a/docs/applications/configuration-management/automate-a-static-site-deployment-with-salt/index.md b/docs/applications/configuration-management/automate-a-static-site-deployment-with-salt/index.md index 74f40126841..1aeee6a1783 100644 --- a/docs/applications/configuration-management/automate-a-static-site-deployment-with-salt/index.md +++ b/docs/applications/configuration-management/automate-a-static-site-deployment-with-salt/index.md @@ -34,7 +34,7 @@ Setting up these mechanisms offers an array of benefits: ## Development and Deployment Workflow -The static site generator used in this guide is [Hugo](https://gohugo.io), a fast framework written in Go. Static site generators compile [markdown](https://en.wikipedia.org/wiki/Markdown) or other content files into HTML files. This guide can easily be adapted to other frameworks. +The static site generator used in this guide is [Hugo](https://gohugo.io), a fast framework written in Go. Static site generators compile [Markdown](https://en.wikipedia.org/wiki/Markdown) or other content files into HTML files. This guide can easily be adapted to other frameworks. Two Git repositories will be created: one will track changes to the Hugo site, and the other will track Salt's configuration files. Remote repositories will be created for both on GitHub. @@ -482,7 +482,7 @@ The Salt minion's formula needs to be updated in order to serve the Hugo site. S - Install Git and clone the Hugo site repository from GitHub. -- Install Hugo and build the HTML files from the markdown content. +- Install Hugo and build the HTML files from the Markdown content. - Update the NGINX configuration to serve the built site. @@ -993,7 +993,7 @@ Hook rules were not satisfied.⏎ hugo new post/test-post.md -1. This command creates a new partially filled in markdown document in `content/post/`. Open this file in your editor, remove the `draft: true` line from the [*frontmatter*](https://gohugo.io/content-management/front-matter/), and add some body text: +1. This command creates a new partially filled in Markdown document in `content/post/`. Open this file in your editor, remove the `draft: true` line from the [*frontmatter*](https://gohugo.io/content-management/front-matter/), and add some body text: {{< file "example-hugo-site/content/post/test-post.md" >}} --- diff --git a/docs/applications/project-management/how-to-create-a-private-python-package-repository/index.md b/docs/applications/project-management/how-to-create-a-private-python-package-repository/index.md index 486318c8ff2..2cf8bfa45d7 100644 --- a/docs/applications/project-management/how-to-create-a-private-python-package-repository/index.md +++ b/docs/applications/project-management/how-to-create-a-private-python-package-repository/index.md @@ -85,7 +85,7 @@ def hello_word(): {{< /file >}} -5. The `setup.cfg` file lets PyPI know the README is a markdown file: +5. The `setup.cfg` file lets PyPI know the README is a Markdown file: {{< file "setup.cfg" >}} [metadata] diff --git a/docs/applications/project-management/jupyter-notebook-on-jekyll/index.md b/docs/applications/project-management/jupyter-notebook-on-jekyll/index.md index 1c7ad7cc365..d1fc768992a 100644 --- a/docs/applications/project-management/jupyter-notebook-on-jekyll/index.md +++ b/docs/applications/project-management/jupyter-notebook-on-jekyll/index.md @@ -140,7 +140,7 @@ The steps in this section can be completed from either your local machine or fro This section demonstrates some common features of a Jupyter Notebook that can be rendered as HTML on a Jekyll blog. There are four types of outputs from a Jupyter Notebook cell covered here: MathJex through LaTeX in Markdown, an HTML table, console output, and graphs from a plotting function. The Iris dataset will be used as an example to generate the output in this guide. -1. Open the notebook of interest, or use the code below to create an example notebook. Run all of the relevant cells so that the output you want to display on your Jekyll blog is visible on the page. Navigate to `File > Download As > Markdown (.md)`. The markdown file will save to the default `Downloads` folder of the browser. +1. Open the notebook of interest, or use the code below to create an example notebook. Run all of the relevant cells so that the output you want to display on your Jekyll blog is visible on the page. Navigate to `File > Download As > Markdown (.md)`. The Markdown file will save to the default `Downloads` folder of the browser. ![Jupyter Menu](jupyter_menu.png "Jupyter Menu") @@ -175,11 +175,11 @@ sns.pairplot(x_vars=["petal-length"], y_vars=["petal-width"], data=iris, hue="cl {{< /file >}} -3. Inside the `_posts` folder of the Jekyll project, create a new markdown file called `YYYY-MM-DD-example-post.md`. If the date format is incorrect, the post may not be displayed on the blog: +3. Inside the `_posts` folder of the Jekyll project, create a new Markdown file called `YYYY-MM-DD-example-post.md`. If the date format is incorrect, the post may not be displayed on the blog: touch YYYY-MM-DD-example-post.md -4. The markdown file should begin with three dashes and contain headers which provide information for Jekyll to populate the post with the appropriate page data. The date must be in the format specified. The hours, minutes, seconds, and timezone adjustment are optional: +4. The Markdown file should begin with three dashes and contain headers which provide information for Jekyll to populate the post with the appropriate page data. The date must be in the format specified. The hours, minutes, seconds, and timezone adjustment are optional: {{< file "YYYY-MM-DD-example-post.md" yaml >}} --- @@ -193,7 +193,7 @@ categories: {{< /file >}} -5. Copy the contents of the markdown file exported from Jupyter into the new post. +5. Copy the contents of the Markdown file exported from Jupyter into the new post. To do this from the command line, use: @@ -253,11 +253,11 @@ margin-bottom: 0; } ### Add an Image in Jekyll -Adding an image through markdown requires having the images stored in the project directory. +Adding an image through Markdown requires having the images stored in the project directory. 1. Move all of the images exported from Jupyter into the `/assets/images` folder. -2. Modify the references to images within the markdown to the appropriate path. Wrap the path in two curly braces and double quotes. +2. Modify the references to images within the Markdown to the appropriate path. Wrap the path in two curly braces and double quotes. {{< file "YYYY-MM-DD-example-post.md" >}} ![png]({{ "/assets/images/example_notebook_5_0.png" }}) diff --git a/docs/linode-writers-formatting-guide/index.md b/docs/linode-writers-formatting-guide/index.md index 7978a8ae1e2..807fecc0c0d 100644 --- a/docs/linode-writers-formatting-guide/index.md +++ b/docs/linode-writers-formatting-guide/index.md @@ -28,7 +28,7 @@ We only accept new guides and authors through our guide submission process. To a ## General Layout -Linode Guides & Tutorials are written in [Markdown](https://en.wikipedia.org/wiki/Markdown). Our documentation site uses [Hugo](https://gohugo.io), a static site generator. Hugo-specific markdown formatting notes are given [further below](#markdown-formatting). +Linode Guides & Tutorials are written in [Markdown](https://en.wikipedia.org/wiki/Markdown). Our documentation site uses [Hugo](https://gohugo.io), a static site generator. Hugo-specific Markdown formatting notes are given [further below](#markdown-formatting). ### Header @@ -209,7 +209,7 @@ If you wish to provide links to external sites for the user to review after goin ### Extend Markdown Using Shortguides -Using shortcodes, it is possible to extend a markdown file with another. For common tasks such as basic software installation, consider using the `content` shortcode. This allows our library to maintain consistent and up to date installation instructions for frequently used tools such as Python, MySQL, and Docker. +Using shortcodes, it is possible to extend a Markdown file with another. For common tasks such as basic software installation, consider using the `content` shortcode. This allows our library to maintain consistent and up to date installation instructions for frequently used tools such as Python, MySQL, and Docker. Markdown files intended to be inserted into multiple guides are called shortguides. To create a shortguide, create a directory with the name of your shortguide anywhere within `docs/`, and then create an index.md within the directory for your content (e.g. `example-shortguide-name/index.md`). @@ -270,7 +270,7 @@ Adding `os: ["mac", "linux", "windows"]` to the front matter inserts a jQuery sc The shortcode should contain two parameters: filepath and operating system. -For example, `{{}}` will insert a markdown snippet that will only be visible when the Mac button is in the active state. +For example, `{{}}` will insert a Markdown snippet that will only be visible when the Mac button is in the active state. ### Files and File Excerpts From 271d5717a01b6e4806b130dba874089bc3702150 Mon Sep 17 00:00:00 2001 From: hzoppetti Date: Tue, 11 Jun 2019 14:40:19 -0400 Subject: [PATCH 6/7] updated endpoint url --- .../object-storage/host-static-site-object-storage/index.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/platform/object-storage/host-static-site-object-storage/index.md b/docs/platform/object-storage/host-static-site-object-storage/index.md index 7cc75483284..691da03abed 100644 --- a/docs/platform/object-storage/host-static-site-object-storage/index.md +++ b/docs/platform/object-storage/host-static-site-object-storage/index.md @@ -260,7 +260,7 @@ Buckets names must be unique within the Object Storage cluster. You might find t {{< output >}} Bucket s3://my-bucket/: Website configuration -Website endpoint: http://my-bucket.alpha-website.linodeobjects.com/ +Website endpoint: http://us-east.linodeobjects.com/ Index document: index.html Error document: 404.html {{}} From 3b3459aa14e81982d465eae2cc9c0bdce7031ca1 Mon Sep 17 00:00:00 2001 From: hzoppetti Date: Tue, 11 Jun 2019 16:54:35 -0400 Subject: [PATCH 7/7] updated url to offical object storage for static site pages --- .../object-storage/host-static-site-object-storage/index.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/platform/object-storage/host-static-site-object-storage/index.md b/docs/platform/object-storage/host-static-site-object-storage/index.md index 691da03abed..1621335ef6f 100644 --- a/docs/platform/object-storage/host-static-site-object-storage/index.md +++ b/docs/platform/object-storage/host-static-site-object-storage/index.md @@ -260,7 +260,7 @@ Buckets names must be unique within the Object Storage cluster. You might find t {{< output >}} Bucket s3://my-bucket/: Website configuration -Website endpoint: http://us-east.linodeobjects.com/ +Website endpoint: http://website-us-east-1.linodeobjects.com/ Index document: index.html Error document: 404.html {{}}