<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: The Alpha Spot</title>
    <description>The latest articles on DEV Community by The Alpha Spot (@thealphaspot).</description>
    <link>https://dev.to/thealphaspot</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2943483%2F46cf72f2-dd1c-4cdd-bb7e-d9a64e215ca3.png</url>
      <title>DEV Community: The Alpha Spot</title>
      <link>https://dev.to/thealphaspot</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/thealphaspot"/>
    <language>en</language>
    <item>
      <title>Create JAMstack Next.js + Github Pages Blog in 2025 (Step-by-Step Guide)</title>
      <dc:creator>The Alpha Spot</dc:creator>
      <pubDate>Fri, 21 Mar 2025 21:36:27 +0000</pubDate>
      <link>https://dev.to/thealphaspot/create-jamstack-nextjs-github-pages-blog-in-2025-step-by-step-guide-kjd</link>
      <guid>https://dev.to/thealphaspot/create-jamstack-nextjs-github-pages-blog-in-2025-step-by-step-guide-kjd</guid>
      <description>&lt;h2&gt;
  
  
  Introduction
&lt;/h2&gt;

&lt;p&gt;JAMstack is a modern web development architecture that focuses on speed, security, and scalability by pre-generating content, leveraging serverless functions, and maintaining a decoupled structure. Rather than relying on traditional back-end servers, JAMstack websites generate static HTML in advance and enhance interactivity through JavaScript and APIs. This approach leads to lightning-fast performance and improved security, as there's no direct connection to a back-end server.  &lt;/p&gt;

&lt;p&gt;A powerful framework for building JAMstack applications is Next.js, a React-based framework that supports Static Site Generation (SSG) and Incremental Static Regeneration (ISR) — both perfect for blogs. Next.js also offers built-in SEO optimizations, dynamic routing, and an intuitive developer experience.  &lt;/p&gt;

&lt;p&gt;For hosting and deployment, &lt;strong&gt;GitHub Pages&lt;/strong&gt; is an excellent choice. This free hosting service from GitHub allows users to publish static websites straight from a repository. Supporting HTML, CSS, and JavaScript, it's ideal for personal portfolios, project documentation, static blogs, and simple web apps. With GitHub Actions, deployment can be automated by pushing code to a designated branch.  &lt;/p&gt;

&lt;h2&gt;
  
  
  What You'll Learn in This Guide
&lt;/h2&gt;

&lt;p&gt;This comprehensive guide will take you through the process of creating a fully functional JAMstack blog with Next.js and deploying it on GitHub Pages. By the end, you’ll have:  &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Set up a Next.js project with all required dependencies
&lt;/li&gt;
&lt;li&gt;Built a blogging system using MDX (Markdown + React components)
&lt;/li&gt;
&lt;li&gt;Optimized your blog for performance, speed, and SEO
&lt;/li&gt;
&lt;li&gt;Successfully deployed blog on GitHub Pages&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Understanding JAMstack
&lt;/h2&gt;

&lt;p&gt;JAMstack stands for &lt;strong&gt;JavaScript, APIs, and Markup&lt;/strong&gt;. Unlike traditional websites that generate pages dynamically on the server at request time, JAMstack sites &lt;strong&gt;pre-render content&lt;/strong&gt; as static files and use JavaScript and APIs to introduce dynamic features.  &lt;/p&gt;

&lt;h2&gt;
  
  
  Why Choose JAMstack?
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Exceptional performance&lt;/strong&gt; – Since content is pre-generated, pages load almost instantly, creating a seamless user experience.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Enhanced security&lt;/strong&gt; – Without a server or database, common threats like SQL injections, brute-force attacks, and plugin vulnerabilities are eliminated.
&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Affordable hosting&lt;/strong&gt; – GitHub Pages offers a free tier along with budget-friendly paid plans, making it a cost-effective option.
&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Why Next.js for Your Blog?
&lt;/h2&gt;

&lt;p&gt;Next.js is an outstanding framework for modern blogging because it provides performance, flexibility, and an enjoyable development experience.  &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Blazing-fast page loads&lt;/strong&gt; – Thanks to &lt;strong&gt;SSG (Static Site Generation),&lt;/strong&gt; your blog is pre-built for optimal speed.
&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;SEO-friendly&lt;/strong&gt; – Fast and easy implementation of meta tags, structured data, and sitemap generation.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;MDX support&lt;/strong&gt; – Write posts in Markdown while embedding interactive React components effortlessly.
&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Why Deploy on Github Pages?
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Zero-cost hosting for static sites&lt;/li&gt;
&lt;li&gt;Automatic deployments &amp;amp; Git integration&lt;/li&gt;
&lt;li&gt;DDoS protection and security advantages&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Prerequisites Before Starting
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Node.js v18.18.0 or higher&lt;/li&gt;
&lt;li&gt;GitHub account&lt;/li&gt;
&lt;li&gt;Basic knowledge of React &amp;amp; Next.js&lt;/li&gt;
&lt;li&gt;Purchased Domain&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Setting Up the Next.js Blog
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Step 1&lt;/strong&gt;: Create a Next.js project with pre-built folder structure for a blog.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx create-next-app &lt;span class="nt"&gt;--example&lt;/span&gt; blog-starter blog-starter-app
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;Step 2&lt;/strong&gt;: Once the project is installed successfully you should see all of the newly created files and folders:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fihf2vc463n6fikrhh49g.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fihf2vc463n6fikrhh49g.png" alt="Step 2" width="800" height="429"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 3&lt;/strong&gt;: Create a new file called next.config.js and put this content inside:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="cm"&gt;/**
 * @type {import('next').NextConfig}
 */&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;nextConfig&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="na"&gt;output&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;export&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;images&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="na"&gt;unoptimized&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="na"&gt;basePath&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;/&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;assetPrefix&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;/&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;span class="p"&gt;};&lt;/span&gt;

&lt;span class="nx"&gt;module&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;exports&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;nextConfig&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;Step 4&lt;/strong&gt;: Run the following commands:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="nb"&gt;cd &lt;/span&gt;blog-starter-app
npm run build
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Once the build is completed, you should see the folder &lt;strong&gt;/out&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F0b2y50kyncaamekxz6th.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F0b2y50kyncaamekxz6th.png" alt="Step 4" width="800" height="429"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Now let's test that the build is working properly.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="nb"&gt;cd &lt;/span&gt;out
npx serve
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Open &lt;a href="http://localhost:3000" rel="noopener noreferrer"&gt;http://localhost:3000&lt;/a&gt; in your browser and verify that the blog is working.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 5&lt;/strong&gt;: Create a private Github repo.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fc2yrngqx9gwosd2p4j9e.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fc2yrngqx9gwosd2p4j9e.png" alt="Create Repo" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Follow the instructions on how to commit and push your code to the repo.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F6xwqf5t7a6tf7mqzi8bm.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F6xwqf5t7a6tf7mqzi8bm.png" alt="Repo" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 6&lt;/strong&gt;: Go to the &lt;strong&gt;Actions&lt;/strong&gt; tab and search for &lt;code&gt;next&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F0jbj4k4izkr8oz020edh.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F0jbj4k4izkr8oz020edh.png" alt="Actions" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 7&lt;/strong&gt;: Click on &lt;strong&gt;Configure&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fko1s6fy823b4twghyhz4.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fko1s6fy823b4twghyhz4.png" alt="Configure Next" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 8&lt;/strong&gt;: Click on &lt;strong&gt;Commit changes&lt;/strong&gt;, choose to commit to the main branch and click &lt;strong&gt;Commit changes&lt;/strong&gt; again.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fysouidkbwcz69vonjfd2.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fysouidkbwcz69vonjfd2.png" alt="Commit" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 9&lt;/strong&gt;: Go to the &lt;strong&gt;Actions&lt;/strong&gt; tab again and wait for the build to finish.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fj0ii2ew280lwhye8mioj.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fj0ii2ew280lwhye8mioj.png" alt="deployment" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 10&lt;/strong&gt;: Go to the repository &lt;strong&gt;Settings&lt;/strong&gt; then select &lt;strong&gt;Pages&lt;/strong&gt;. You should be able to see that your site was deployed successfully.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F6m64fwnvhs1vgouv4ag6.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F6m64fwnvhs1vgouv4ag6.png" alt="pages" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 11&lt;/strong&gt;: Copy the URL, open your registrar and go to the domain DNS settings&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 12&lt;/strong&gt;: Add a new record. Check the &lt;a href="https://docs.github.com/en/pages/configuring-a-custom-domain-for-your-github-pages-site/managing-a-custom-domain-for-your-github-pages-site#dns-records-for-your-custom-domain" rel="noopener noreferrer"&gt;Github's documentation for setting up custom domains&lt;/a&gt;. For this article I chose to use a subdomain.&lt;/p&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Scenario&lt;/th&gt;
&lt;th&gt;DNS Record Type&lt;/th&gt;
&lt;th&gt;DNS Record Name&lt;/th&gt;
&lt;th&gt;DNS Record Value&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;subdomain&lt;/td&gt;
&lt;td&gt;CNAME&lt;/td&gt;
&lt;td&gt;SUBDOMAIN.example.com&lt;/td&gt;
&lt;td&gt;USERNAME.github.io&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9v5ek5sgtd4rembw3705.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9v5ek5sgtd4rembw3705.png" alt="Subdomain" width="800" height="103"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 13&lt;/strong&gt;: Add your custom domain in GitHub pages.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F4eifmcrc8adw3ys5jffx.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F4eifmcrc8adw3ys5jffx.png" alt="Github subdomain" width="800" height="369"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step 14&lt;/strong&gt;: Open your custom domain and verify that the site is loading properly.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fv2y01h9qd0ar82qjjip0.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fv2y01h9qd0ar82qjjip0.png" alt="final" width="800" height="429"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Each time you push changes to the production branch, an automatic build will be triggered and once the build is completed, you will see your changes live.&lt;/p&gt;

&lt;p&gt;If you liked this tutorial, please check out my blog and find more useful articles and tutorials &lt;a href="https://thealphaspot.com" rel="noopener noreferrer"&gt;@thealphaspot&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;If you prefer a blog with CMS make sure you read &lt;a href="https://thealphaspot.com/articles/how-i-created-my-own-blog/" rel="noopener noreferrer"&gt;this article&lt;/a&gt; first, so you don't fall for my mistakes.&lt;/p&gt;

</description>
      <category>programming</category>
      <category>webdev</category>
      <category>react</category>
      <category>nextjs</category>
    </item>
  </channel>
</rss>
